好的测试所具有的品质
好的测试应该具有以下的品质:
l 自动化
l 彻底性
l 可重复性
l 独立性
l 专业性
第一、 自动化
自动化的含义:调用自动化和检查结果自动化
调用自动化,因为单元测试是一个重复的过程,经常需要进行,因此尽量做到在IDE中经行,通过点击一个按钮就可以实现测试。对于测试的条件(如数据库,网络连接,窗体等)都应该让他成为单元测试的一部分。
检查自动化,测试必须自己能够检查测试是通过了还是失败了。不需要认为看输出结果来判断。
第二、 彻底性
好的单元测试是彻底的,它们测试了所有可能会出问题的情况。
两个极端的例子:1>对于行代码,每个分支和每个可能抛出的异常。2>仅仅测试了最有可能的地方如边界条件,残缺和畸形的数据等。
第三、 可重复
每个测试都应该独立于其他所有的测试,而且还必须独立于周围的环境,目标是测试能够一次又一次的执行,产生同样的结果。
第四、独立性
测试应该具有较强的针对性,确保你一次只测试一样东西。这并不意味一次测试只能使用一个测试函数,而是说一次测试应该专注于产品中的一个测试函数,或者实现一个功能的一组测试函数。
独立性还意味着测试没有依赖于任何其他的测试,不希望当前测试依赖于前面的测试。
第五、 专业性
测试代码必须使用和产品代码相同的专业水准来编写。也应该采用封装,降低耦合。测试代码也需要封装成类和函数。如果积累了相关的测试方法就可以封装成函数。
测试代码需要有侧重点,不是对代码的什么地方都测试,如类的简单属性就可以不测。
正常情况下,测试代码会和产品代码量相差不大。
最后对测试进行测试。
对代码经行单元测试从而确信软件能共正常运行是目前最好的方案,但是如果编写的测试有bug,那往往为带来很大的麻烦。以下两件事可以帮助你确定测试代码是真确的。
l 修正bug的时候,同时改进测试。
l 通过引入bug来证明测试。