我有一位同事为用随机数据填充其字段的对象编写单元测试。他的理由是它提供了更广泛的测试范围,因为它会测试很多不同的值,而普通测试只使用一个静态值。
我给了他很多不同的理由来反对这一点,主要是:
另一位同事补充道:
还有其他人可以添加我可以给他的其他理由来让他停止这样做吗?
(或者,这是一种可接受的编写单元测试的方法,而我和我的其他同事错了吗?)
有一个妥协。你的同事实际上是在做某事,但我认为他做错了。我不确定完全随机测试是否非常有用,但它肯定不是无效的。
程序(或单元)规范是一种假设,即存在一些满足它的程序。程序本身就是该假设的证据。单元测试应该是试图提供反证据来反驳程序按照规范工作。
现在,您可以手动编写单元测试,但这确实是一项机械任务。它可以自动化。您所要做的就是编写规范,一台机器可以生成大量单元测试,试图破坏您的代码。
我不知道您使用的是什么语言,但请参见此处:
Java http://functionaljava.org/
Scala(或 Java) http://github.com/rickynils/scalacheck
Haskell http://www.cs.chalmers.se/~rjmh/QuickCheck/
.NET:http: //blogs.msdn.com/dsyme/archive/2008/08/09/fscheck-0-2.aspx
这些工具会将您格式良好的规范作为输入,并使用自动生成的数据自动生成尽可能多的单元测试。他们使用“缩小”策略(您可以调整)来找到最简单的测试用例来破坏您的代码并确保它很好地覆盖边缘用例。
祝测试愉快!