zoukankan      html  css  js  c++  java
  • 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]相反。

    备注

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

  • 相关阅读:
    android升级gradle到3.4.1
    django1.10.3下admin后台管理老是显示object
    django 1.10.3 admin后台管理设置显示中文
    Linux查看版本信息
    Centos下查看mysql的版本
    Linux centos6.7网卡配置
    Linux centos 防火墙篇
    MYSQL ERROR 1045 (28000) Access denied for user (using password YES)问题的解决
    centos7中的网卡名称相关知识
    redis编译和安装出现错误
  • 原文地址:https://www.cnblogs.com/happyframework/p/3055027.html
Copyright © 2011-2022 走看看