单元测试之Mock
- 为什么需要Mock.
- 真实对象具有不确定的行为.所以会产生不可预测的结果.
- 真实对象很难被创建.
- 真实对象的某些行为很难被触发(如网络错误).
- 真实对象令程序的运行速度很慢.
- 真实对象有(或者是)用户界面.
- 测试需要询问真实对象它是如何被调用的.
- 真实对象实际上并不存在.例如其它小组开发的模块.
- 使用Mock的3个步骤
- 使用一个接口来描述该对象.
- 为产品代码实现该接口.
- 以测试为目的,在Mock对象中实现该接口.
- Test Double
- Dummy.被传递但是从不被实际使用的对象.通常用于填充参数列表.
- Fake.含有实际实现的对象.但通常使用一些不适用于实际项目的捷径(内存数据库).
- Stubs.对调用提供一些预设的响应.通常不会调用代码中实际调用会执行的代码.可以用来记录关于调用的信息.(Email中可以记录发送过的邮件).
- Mocks.预先编写的对象.接受特殊的调用,返回特定的预期行为.
- Mock的四个步骤:setup,exercise,verify,teardown.
- 只有Mock是进行行为测试验证.
- 主要对象和次要对象
- 单元测试中,我们通常关注的是主要测试对象的功能和行为.
- 对于主要测试对象涉及到的次要对象尤其是一些依赖,我们仅仅关注主要测试对象和次要测试对象的交互.
- 比如是否调用,何时调用,调用的参数,调用的次序,以及返回的结果或者异常等.
- 但是次要对象是如何执行这次调用的,并不关心.
- 因此,使用mock对象或者stub对象来替代真实的次要对象,从而模拟真实场景来进行对主要测试对象的测试.
- 测试工具
- 在.Net下大部分工具都是使用动态类型来进行Mock,因此,只能Mock接口或者overriable成员.
- 而TypeMock直接使用inject方式,即使是sealed或者不可覆盖方法也能进行Mock.
- 通常,如果发现必须要覆盖不可覆盖的方法才能够进行测试,那么很可能是设计问题.
- Mock行为依赖风险
- 被模型对象的行为必须与真实对象的行为完全一致.
- 开发者对API不够了解;被模拟对象的行为发生了改变(重构,添加新功能导致的).都可能引起错误假设(与真实对象行为不一致).错误假设会引入缺陷,并留下非法测试.
- 非法测试:看起来像测试,运行起来也是测试.但是几乎没有价值,几乎不会失败.
- Mock的优点
- Mock对象的行为简单,唯一.一旦设置好setup后总是返回同一值.
- Mock对象的行为可以预期,如果调用到了不希望调用的方法会让测试失败.若方法被调用了,还可以验证参数.
- 可以Mock一些在真实环境中难以模拟或者出现的错误或者异常.
- Mock是一种白盒测试方式.Mock对象的setup过程就是目标代码实现细节的设计过程.
- 接口为使用者而设计.所以当接口还未被实现时,Mock可以验证使用者是如何使用接口的.
- Mock的缺陷
- Mock对象的行为依赖风险.在对真实对象进行重构的时候,容易带来该问题.
- Mock对象的setup过程可能过于繁重.
- 另一个角度,过于复杂的Mock对象的setup过程,说明真实对象承担了过多的职责.
- 分出更多职责清晰的小类,可以避免这种情况.
- Mock对象的setup过程含有过多的语义.
- Mock对象的行为定义.调用方法的返回值;调用方法时的Throw Exception;给调用方法时传递的参数发送消息.
- Test Case期望assert的内容.方法是否被调用以及被调用的次数.调用方法时的参数是否合法.
单元测试之Mock的更多相关文章
- python笔记24-unittest单元测试之mock.patch
前言 上一篇python笔记23-unittest单元测试之mock对mock已经有初步的认识, 本篇继续介绍mock里面另一种实现方式,patch装饰器的使用,patch() 作为函数装饰器,为您创 ...
- python文档2-unittest单元测试之mock.patch
介绍mock里面另一种实现方式,patch装饰器的使用,patch() 作为函数装饰器,为您创建模拟并将其传递到装饰函数 patch简介 1.unittest.mock.patch(target,ne ...
- CoreCRM 开发实录 —— 单元测试之 Mock UserManager 和 SignInManager
单元测试的核心就是:只测试眼前的逻辑.这就要求所有的依赖项都要使用仿类来代替,也就是所谓的 Mock Object.在测试 ProfileRepository 和 AccountController ...
- python笔记23-unittest单元测试之mock
什么是mock unittest.mock是一个用于在Python中进行单元测试的库,Mock翻译过来就是模拟的意思,顾名思义这个库的主要功能是模拟一些东西. 它的主要功能是使用mock对象替代掉指定 ...
- python文档1-unittest单元测试之mock
什么是mock unittest.mock是一个用于在Python中进行单元测试的库,Mock翻译过来就是模拟的意思,顾名思义这个库的主要功能是模拟一些东西.它的主要功能是使用mock对象替代掉指定的 ...
- java单元测试之Mock静态方法
1 public final class AmountUtil { public static String CustomFormatWith2Digits(int amount) { return ...
- 玩转单元测试之Testing Spring MVC Controllers
玩转单元测试之 Testing Spring MVC Controllers 转载注明出处:http://www.cnblogs.com/wade-xu/p/4311657.html The Spri ...
- 玩转单元测试之WireMock -- Web服务模拟器
玩转单元测试之WireMock -- Web服务模拟器 WireMock 是一个灵活的库用于 Web 服务测试,和其他测试工具不同的是,WireMock 创建一个实际的 HTTP服务器来运行你的 We ...
- [转载]单元测试之道(使用NUnit)
首先来看下面几个场景你是否熟悉 1.你正在开发一个系统,你不断地编码-编译-调试-编码-编译-调试……终于,你负责的功能模块从上到下全部完成且编译通过!你长出一口气,怀着激动而又忐忑的心情点击界面上的 ...
随机推荐
- (转) Arcgis for js加载百度地图
http://blog.csdn.net/gisshixisheng/article/details/44853709 概述: 在前面的文章里提到了Arcgis for js加载天地图,在本节,继续讲 ...
- icheck使用
1.使用: <link rel="stylesheet" href="css/skins/all.css">或者<link rel=" ...
- linux backtrace()详细使用说明,分析Segmentation fault
linux backtrace()详细使用说明,分析Segmentation fault 在此之前,开发eCos应用程序时,经常碰到程序挂掉后,串口打印输出一大串让人看不懂的数据.今天才明白,原来这些 ...
- Python——Numpy基础知识(一)
一.Numpy的引入 1.标准的Python 中用列表(list)保存一组值,可以当作数组使用.但由于列表的元素可以是任何对象,因此列表中保存的是对象的指针.对于数值运算来说,这种结构显然比较浪费内存 ...
- [jzoj 5782]【NOIP提高A组模拟2018.8.8】 城市猎人 (并查集按秩合并+复杂度分析)
传送门 Description 有n个城市,标号为1到n,修建道路花费m天,第i天时,若gcd(a,b)=m-i+1,则标号为a的城市和标号为b的城市会建好一条直接相连的道路,有多次询问,每次询问某两 ...
- 在LINUX系统上通过LINUX命令安装mysql数据库和JDK环境
此示例通过Winscp工具和Xshell已验证通过 安装示例1: 在Centos6.5上安装JDK-10.0.2版本 检查LINUX系统是否有自带或者安装过的JDK版本:Java -version 查 ...
- 07.网络编程-4.HTTP
HTTP是一种无状态的协议,无状态是指Web浏览器和Web服务器之间不需要建立持久的连接,这意味着当一个客户端向服务器端发出请求,然后Web服务器返回响应(response),连接就被关闭了,在服务器 ...
- PHP AES cbc模式 pkcs7 128加密解密
今天在对接一个第三方接口的时候,对方需要AES CBC模式下的加密.这里简单写一个demo class Model_Junjingbao extends Model { private static ...
- lucene_09_solrj的使用
什么是solrj solrj 是访问Solr 服务的java客户端,提供索引(增删改)和搜索(查)的请求方法,Solrj 通常在嵌入在业务系统中,通过Solrj的API接口操作Solr服务,如下图: ...
- C#的WaitHandle : 管理多线程状态
有时候,我们创建了多线程,需要知道是否都完成了各自的工作.比如说,开启了多线程的下载,如何终止所有的线程并且在确保所有线程都终止之后才继续执行程序的退出呢? public partial class ...