单元测试踩坑指南

实习期间做单元测试,一开始都靠往数据库硬塞数据,后来发现这样做就算本地能通过,在线上通不过,故开始学习,发现遇到的问题网上基本上没有,希望整理一些以后如果有人遇到我遇到的坑,可以直接跨过去。

什么是单元测试?
粗略地说,单元测试是用来测试功能代码的代码,它和功能代码隔离。
单元测试有什么好处?
a.可以重复自动地运行测试代码;
b.可以在比人工点击测试更细的粒度上做测试。
Mock
在单元测试中,模拟对象可以模拟复杂的、真实的(非模拟)对象的行为, 如果真实的对象无法放入单元测试中,使用模拟对象就很有帮助。
首先我们要搞清楚为什么要使用Mock来模拟对象:
1.首先我们做的是单元测试,不是集成测试,所以我们所有的测试关注点都应该在当前的类内,如果类中需要调用一些其他类的东西,那么我们就需要对其进行Mock,当执行该语句时直接返回一个模拟值(自己构造的虚假的值)。
2.真实的对象的行为时不确定的(例如,当前的时间或当前的温度)
3.真实对象的行为很难触发(例如,网络错误)
4.涉及到数据库的操作的,如果是数据库的增删改查,应该建立内存型数据库H2,防止脏数据污染数据库。
5.真实对象可能还不存在
6.真实对象可能包含不能用作测试(而不是为实际工作)的信息和方法。
7.真实的对象是用户界面,或包括用户界面在内
8.真实对象很难搭建起来

例如,一个可能会在特定的时间响铃的闹钟程序可能需要外部世界的当前时间。要测试这一点,测试一直要等到闹铃时间才知道闹钟程序是否正确地响铃。如果使用一个模拟对象替代真实的对象,可以变成提供一个闹铃时间(不管是否实际时间),这样就可以隔离地测试闹钟程序。

常见的Mock框架主要有3种:
Mockito,EasyMock,PowerMock
Mockito和EasyMock从使用者角度来看,没什么区别。Mockito对Spring支持更加友好,Spring官方也是推荐使用Mockito。所以建议优先使用Mockito.
PowerMock对Mockito和EasyMock进行了扩充,做了一些脏活累活。比如:抑制构造函数,抑制函数,抑制静态初始化块,Mock静态方法等等。Mockito无法Mock静态方法,静态类等等,所以遇到这些一定要使用PowerMock。
下面介绍Mockito和PowerMock的踩坑指南:
Mockito:https://www.jianshu.com/p/0f1bde330c17
PowerMock:https://www.jianshu.com/p/44fcadaf041d
以及相关的一个Assert断言的简单应用:https://www.jianshu.com/p/3f2be2af12a4](https://www.jianshu.com/p/3f2be2af12a4

参考文献:
1.维基百科 https://zh.wikipedia.org/wiki/%E6%A8%A1%E6%8B%9F%E5%AF%B9%E8%B1%A1

你可能感兴趣的:(单元测试踩坑指南)