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

本文通过实验探究了单元测试的执行流程,包括线程模型、实例创建方式及各类初始化与清理方法的执行时机等关键信息。

背景

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

主要想弄明白两个问题:

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

实验

实验材料

实验结果

 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:

实验结论

    1. 单线程执行。
    2. 每个单元测试方法都会创建一个实例。
    3. [AssemblyInitialize]最先执行。
    4. [AssemblyCleanup]最后执行。
    5. [TestInitialize]在每个单元测试方法执行之前都会执行。
    6. [TestCleanup]在每个单元测试方法执行之后都会执行。
    7. [ClassInitialize]在实例该单元测试类的第一个实例时执行。
    8. [ClassCleanup]在[AssemblyCleanup]之前执行,执行顺序与[ClassInitialize]相反。

备注

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

 

转载于:https://www.cnblogs.com/happyframework/archive/2013/05/03/3055027.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值