好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

TDD:MS自带的单元测试 之 线程模型和执行顺序

TDD:MS自带的单元测试 之 线程模型和执行顺序

TDD:MS自带的单元测试 之 线程模型和执行顺序

背景

我一直在呼喊“不要靠假设编程”,可是我却常常这么做。我用单元测试就是一种基于假设进行编程的反面教材,今天就下决心弄明白它。

主要想弄明白两个问题:

执行的所有单元测试方法的线程模型,是单线程?是多线程? 执行的一个类型的所有单元测试方法会创建一个实例?还是一个单元测试方法创建一个实例? 执行的所有单元测试方法的执行顺序,哪些是随机?哪些是固定?

实验

实验材料

实验结果

  1  第1步,AssemblyInitialize in Thread:16 ,the unittest hashcode is:
   2  第2步,单元测试类C__ClassInitialize in Thread:16 ,the unittest hashcode is:
   3  第3步,单元测试类C__TestInitialize in Thread:16,the unittest hashcode is:55310967
  4  第4步,单元测试类C__单元测试方法C1 in Thread:16,the unittest hashcode is:55310967
  5  第5步,单元测试类C__TestCleanup in Thread:16,the unittest hashcode is:55310967
  6  第6步,单元测试类C__TestInitialize in Thread:16,the unittest hashcode is:16887489
  7  第7步,单元测试类C__单元测试方法C2 in Thread:16,the unittest hashcode is:16887489
  8  第8步,单元测试类C__TestCleanup in Thread:16,the unittest hashcode is:16887489
  9  第9步,单元测试类B__ClassInitialize in Thread:16 ,the unittest hashcode is:
  10  第10步,单元测试类B__TestInitialize in Thread:16,the unittest hashcode is:13872596
 11  第11步,单元测试类B__单元测试方法B1 in Thread:16,the unittest hashcode is:13872596
 12  第12步,单元测试类B__TestCleanup in Thread:16,the unittest hashcode is:13872596
 13  第13步,单元测试类B__TestInitialize in Thread:16,the unittest hashcode is:17876636
 14  第14步,单元测试类B__单元测试方法B2 in Thread:16,the unittest hashcode is:17876636
 15  第15步,单元测试类B__TestCleanup in Thread:16,the unittest hashcode is:17876636
 16  第16步,单元测试类A__ClassInitialize in Thread:16 ,the unittest hashcode is:
  17  第17步,单元测试类A__TestInitialize in Thread:16,the unittest hashcode is:45630738
 18  第18步,单元测试类A__单元测试方法A1 in Thread:16,the unittest hashcode is:45630738
 19  第19步,单元测试类A__TestCleanup in Thread:16,the unittest hashcode is:45630738
 20  第20步,单元测试类A__TestInitialize in Thread:16,the unittest hashcode is:34828481
 21  第21步,单元测试类A__单元测试方法A2 in Thread:16,the unittest hashcode is:34828481
 22  第22步,单元测试类A__TestCleanup in Thread:16,the unittest hashcode is:34828481
 23  第23步,单元测试类C__ClassCleanup in Thread:16 ,the unittest hashcode is:
  24  第24步,单元测试类B__ClassCleanup in Thread:16 ,the unittest hashcode is:
  25  第25步,单元测试类A__ClassCleanup in Thread:16 ,the unittest hashcode is:
  26  第26步,AssemblyCleanup in Thread:16,the unittest hashcode is:

实验结论 单线程执行。 每个单元测试方法都会创建一个实例。 [AssemblyInitialize]最先执行。 [AssemblyCleanup]最后执行。 [TestInitialize]在每个单元测试方法执行之前都会执行。 [TestCleanup]在每个单元测试方法执行之后都会执行。 [ClassInitialize]在实例该单元测试类的第一个实例时执行。 [ClassCleanup]在[AssemblyCleanup]之前执行,执行顺序与[ClassInitialize]相反。

备注

还有两个问题没有得出结论:一、单元测试类型的执行顺序;二、单元测试方法的执行顺序。好在单元测试最好不要依赖这个顺序,因此我就不做实验了。

作者: Leo_wl

    

出处: http://www.cnblogs.com/Leo_wl/

    

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

版权信息

查看更多关于TDD:MS自带的单元测试 之 线程模型和执行顺序的详细内容...

  阅读:45次

上一篇: C#析构器的一个Bug

下一篇:Zachman框架