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等方式去实现。

被测对象和依赖对象/服务的关系

Local&Remote Mock

  • LocalMock相当于使用Mock对象替换依赖对象。
  • RemoteMock相当于使用MockServer替换真实的HTTP/RPC Server。

Mock工具

1.EasyMock

EasyMock简介和代码示例

2.Mockito

Mockito简介和代码示例

3.PowerMock
PowerMock



作者:测试你个头
链接:https://www.jianshu.com/p/3944c0b82f30

猜你喜欢

转载自blog.csdn.net/wangmaohong0717/article/details/82770949