单元测试是什么

单元测试是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确,通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特定函数的行为。

单元测试的好处

1,单元测试不但会使你的工作完成得更轻松,而且会令你的设计变得更好,大大减少你花在调试上面的时间
2,提高代码质量
3,减少bug,快速定位bug
4,放心地修改、重构
5,显得专业(玩笑话)

写单元测试要注意什么

1,不能只测试一条正确执行路径,要考虑到所有可能的情况
2,要确保所有测试都能够通过,避免间接损害
3,如果一个函数复杂到无法单测,那就说明模块的抽象有问题
4,配置不是单元测试的难点,难点是mock(后文讲),做单元测试需要伪造被测函数用到的大部分函数

间接损害:在整个系统中,当某一部分加入了新特性,或者修复了一个bug之后,给系统的其他(与前面可能是互不相关的)部分引入了一个新的bug(或者损害)。如果无视这种损害并且继续开发的话,那么将可能带来一个很危险的问题,最后可能会导致整个系统崩溃,并且没人能够修复。

为什么写单元测试(为什么会拒绝单元测试)

编写单元测试太花时间了?考虑下面问题:

1,对于所编写的代码,你在调试上面画了多少时间?
2,对于以前你自认为正确的代码,而实际上这些代码却存在重大的bug,你花了多少时间在重新确认这些代码上面?
3,对于一个别人报告的bug,你花了多少时间才找出导致这个bug的源码位置?
对于那些没有使用单元测试的程序员而言,上面这些问题所耗费的时间的递增速度是很快的,而且随着项目深入,递增速度会变得更快;而另一方面,适当的单元测试却可以很大程度地减少这些时间,从而为你腾出足够的时间来编写所有的单元测试——甚至可能还有剩余的空闲时间。

运行测试的时间太长?

一般合适的测试是不会让这种情况发生的。
有些真的会花很长时间的,可以把耗时的测试和其他测试分开。

不清楚代码的行为?

如果实在不清楚代码的行为,那么现在应该也不是应该编码的时候。

代码都能编译通过啊?

ok,你的代码语法正确,应该也是可以运行的。但是代码的行为和你的预期是一样的么?

1
2
3
4
5
6
public void addItem(Object itemObject){
List myList = new List;
myList.add(itemObject);
myList.add(itemObject);
...
}

你真的想把同一个对象加到 list 两次么?或许是,或许不是,但是编译器并不能告诉你代码是否完成了你所期望的功能。

下一章单元测试整理(二)——断言篇,首个单元测试程序将介绍使用断言对代码段进行测试!