单元测试的属性
除了单元测试方法的 [TestMethod()] 属性及其包容类的 [TestClass()] 属性之外,可使用其他属性启用特定的单元测试功能。在这些属性中,最主要的属性有 [TestInitialize()] 和 [TestCleanup()]。使用标记有 [TestInitialize()] 的方法对将要在其中运行单元测试的环境的各个方面进行准备;这样做的目的在于为单元测试的运行建立已知的状态。例如,可以使用 [TestInitialize()] 方法复制、更改或创建测试中将要使用的某些数据文件。
在运行完某个测试后,可通过标记有 [TestCleanup()] 的方法将环境返回到已知状态;这可能意味着需要删除文件夹中的文件,或将某个数据库返回到已知状态。例如,在测试了订单录入应用程序中使用的某个方法后,可将库存数据库重置为初始状态。此外,建议您在 [TestCleanup()] 或 ClassCleanup 方法中使用清除代码,而不要在终结器方法(~Constructor)中使用此代码。从终结器方法引发的异常不会被捕捉到,并且会导致无法预料的结果。
用于建立调用顺序的属性
对于程序集:在加载程序集之后以及卸载程序集之前,将调用 AssemblyInitialize和 AssemblyCleanup。
对于类:在加载类之后以及卸载类之前,将调用 ClassInitialize 和 ClassCleanup。
对于测试方法:在每个测试方法加载以及卸载之前,将调用TestInitialize 和TestCleanup。
什么是VsUnit 的TestContext 类
测试上下文类的属性存储有关当前测试运行的信息。例如,TestContext.DataRow 和 TestContext.DataConnection 属性包含测试用于数据驱动的单元测试的信息。
其他
用于对测试进行标识和排序的属性;
测试配置类;
用于生成报告的属性;
用于专用访问器的类。
测试哪些内容:Right-BICEP
Right----------结果是否正确?
B---------------是否所有的边界条件都是正确的?
I----------------能查一下反向关联吗?
C---------------能用其他手段交叉检查一下结果吗?
E---------------你是否可以强制错误条件发生?
P---------------是否满足性能要求?
● RIGHT:结果是否正确
如果代码能运行正确,如何才知道它是正确的呢?
1、使用更明确的设计文档
2、真实环境数据
3、????
● B:边界条件
尽可能的至少各种特殊或者意外的情况,测试程序是否能正常工作,如:
◇ 完全伪造或者不一致的输入数据,如叫做“(*@Q!&#?±的文件。
◇ 格式错误的数据,如错误格式的邮件地址。
◇ 空值或不完整的值。
◇ 一些与意料中的合理值相去甚远的值,如年纪为10000。
◇ 如果要求是一个不允许出现重复数值的list,但传入一个有重复数值的list。
◇ 要求是一个有序的list,但传入一个无序的list。
◇ 处理的顺序是错误的,或者与期望的次序不一致。如未登录系统就尝试打印。
● B:边界条件的-CORRECT
Conformance(一致性)值是否和预期的一致
Ordering(顺序性)值是否应该的那样有序或者无序
Range(区间性)值是否位于合理范围
Reference(依赖性)代码是否引用了一些代码本身控制范围之外的资源
Existence(存在性)值是否存在(是否非空,非零,在集合中等等)
Cardinality(基数性)是否恰好有足够的值
Time(相对或绝对的时间性)所有事情的发生是否有序?是否在正确的时间?是否恰好及时?
● I:检查反向关联
通常一些结果可以使用反向的逻辑关系来验证它们是否正确,如:计算a*b的函数,测试方法如下:
Public void UsingInverse(){ double x = MyMath.AB(4,4); Assert.AreEqual<double>(x,4*4); } |
● C:使用其他手段实现交叉检查
计算一个结果可以存在多个算法,同一个算法可以使用稳定的版本来校验新改进的版本,如:
Public void UsingStd(){ double number = 23214.01; double result1 = MyMath.旧方法(number1); double result2 = MyMath.新方法(number1); Assert.AreEqual<double>(result1,result2); } |
● E:强制产生错误条件
真实运行环境各种出乎意料的事情都可能发生,如断电,断网等等。在测试中模拟这些情况可以使用Mock对象来实现。
● P:性能特性
如数据采集的功能,在十个网站上进行采集工作很正常,那么在1000个网站上或更多的网站上进行采集它的速度如何?是否写个单元测试?