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]相反。

備注

還有兩個問題沒有得出結論:一、單元測試類型的執行順序;二、單元測試方法的執行順序。好在單元測試最好不要依賴這個順序,因此我就不做實驗了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM