Mock概念介绍
-
mock的定义(what):
mock是在测试过程中,对于一些不容易构造/获取的对象,创建一个mock对象来模拟对象的行为
为什么要使用mock(why):
在做单元测试过程中,经常会有以下的场景:
class A 依赖 class B
class B 依赖 class C和class D
class C 依赖 ...
class D 依赖 ...
1.被测对象依赖的对象构造复杂
我们想对class A进行单元测试,需要构造大量的class B、C、D等依赖对象,他们的构造过程复杂(体现在构造步骤多、耗时较长),这时我们可以利用mock去构造虚拟的class B、C、D对象用于class A的测试,因为我们只是想测试class A的行为是否符合预期,我们并不需要测试依赖对象。
2.被测单元依赖的模块尚未开发完成,而被测对象需要依赖模块的返回值进行测试:
----- 比如service层的代码中,包含对dao层的调用,但dao层代码尚未开发
----- 比如web的前端依赖后端接口获取数据进行联调测试,但后端接口并未开发完成
- 哪些时机和场合需要使用mock(when&where)
1.单元测试/接口测试中测试对象依赖其他对象,这些对象的构造复杂、耗时或者根本无法构造(未交付)
2.我们只测试对象内部逻辑的质量,不关心依赖对象的逻辑正确性和稳定性
- 是否应该在测试中使用mock,投入产出比如何(how much)
我们可以基于以下2个原则去做mock,这样的mock的投入产出比是最高的
1.不需要对所有的依赖对象/服务进行mock,只对那些构造步骤复杂、构造耗时较长、不稳定的依赖对象/服务进行mock。
2.如果做分层测试(比如分层自动化),高层的测试设计可以基于以下假设:低层的测试已保证低层对象的质量,高层对低层的依赖可以mock,无需关心所依赖的低层对象的质量。
- Local Mock和Remote Mock
Local Mock和Remote Mock的区别在于依赖对象的行为调用是本地/远程调用
1.Mock本地依赖对象
如果依赖对象的调用是本地调用,就属于Local Mock。EasyMock/Mockito都可以实现对本地依赖对象的Mock。
2.Remote Mock
如果被测对象依赖对象的是一些远程服务(HTTP/RPC服务),就属于Remote Mock,Remote Mock一般实现对指定的服务/接口、客户端(消费者)进行Mock。可以通过Mock Server等方式去实现。
- LocalMock相当于使用Mock对象替换依赖对象。
- RemoteMock相当于使用MockServer替换真实的HTTP/RPC Server。
Mock工具
1.EasyMock
Mockito简介和代码示例
2.Mockito
EasyMock简介和代码示例
3.PowerMock
PowerMock