网站首页 > 技术文章 正文
一、mock类型
1、方法级别 mock:mock 的对象是一个函数调用,例如获取系统环境变量。
2、类级别 mock:mock 的对象是一个类,例如一个 HTTP server。
3、接口级别 mock:mock 的对象是一个 API 接口。
4、服务级别 mock:mock 的对象是整个服务。比如前端工程师自测试时,可以讲后端整个服务都 mock 掉,这其实等同于将后端的所有接口都 mock。
二、接口mock注入的五种方式
使用mock进行接口测试时,一般要做两件事情,即打桩和调桩。
打桩就是创建mock桩,指定 API 请求内容及其映射的mock响应内容;所谓调桩就是被测服务来请求mock桩并接收mock响应。
事实上,在打桩和调桩之间还有一件重要的事情,即mock桩的注入(mock injection)。
1、什么是mock注入?
mock的本质就是用模拟桩来替换真实的依赖。所谓mock桩注入就是阻断被测服务与真实服务之间的链路,建立被测服务与mock之间的链路过程。
2、如何注入mock?
总的来说mock桩的注入方式与架构、被测服务的架构等因素相关。常见的mock 桩注入方式包括但不限于以下五种。
(1)API 请求构造
在mock接口中被测服务是API的请求方,即客户端;依赖服务是API的响应方,即服务端。根据mock工作的位置,mock可以分为客户端mock和服务端mock。
客户端mock:mock 在被测服务内部工作,直接拦截被测服务的API请求方法(比如 HTTP Client方法),在被测服务调用API请求方法时,直接从方法内部返回预定义的mock响应。
服务端mock:mock在被测服务外部工作,作为HTTP服务器接收被测服务发送的API请求,并返回预定义的mock响应。
客户端mock的注入其实就是改造被测服务的API请求方法,即在API请求方法中加入mock 处理逻辑。当满足某些条件时执行mock分支,不满足时执行真实分支。
可以通过两种方式实现,一种是直接改造源代码,另一种是利用字节码增强技术对字节码进行改造(Java 语言)。
API请求改造这种注入方式适用于客户端mock,优势是性能极好,不足是实现成本较高。
(2)本地配置
对于服务端mock,打桩之后会生成唯一的mock桩地址。被测服务要想调用这个桩需要知道桩地址,如何让被测服务知道桩地址呢?一种最直接的方法就是被测服务提供一个依赖服务地址配置项,在需要使用mock时将依赖服务地址修改成mock地址。
本地配置的优势是实现简单,不足之处是修改配置项需要重启被测服务,在需要进行mock 服务与真实服务切换时不方便。
(3)配置中心
在服务端mock中,为了避免修改依赖服务地址配置项导致被测服务重启,可以采用配置中心(如 Spring Cloud Config Server)存储和管理依赖服务地址配置,或者使用注册中心(如 Spring Cloud Eureka)记录服务与服务地址的映射关系。
使用配置或者注册中心时,mock注入的方法是修改配置中心,将依赖服务地址改成mock地址。这种注入方法不需要重启被测服务,但是从配置改变到配置生效可以存在一定的延时。
(4)反向代理
在微服务架构下,被测服务与依赖服务之间可能不是直连的,而是经过了一层反向代理,例如API网关。在这种情况下,被测服务是通过调用API网关来间接调用依赖服务的接口。
在 API 网关模式下,mock注入的具体做法就是修改API网关配置,将依赖服务API网关接口绑定的地址改成mock地址。
这种注入的优势是对被测服务无侵入,并且实现更细粒度(接口级)的mock。当然,根据 API网关的实现不同,仍然可能存在一定的时延。
(5)前向代理
服务端mock除了作为HTTP服务器,还可以兼备HTTP代理的功能,这种架构又叫做mock 代理,例如mock server proxy。对于mock代理来说,它不仅能够返回mock响应,而且能够在需要的时候将API请求转发给依赖服务,并将依赖服务的真实响应返回给被测服务。
使用前向代理模式,mock注入的方式是将被测服务的依赖地址或网络代理修改为mock地址,这种注入方法需要重启被测服务,其优势是能够实现细粒度的mock,并且能够根据录制的真实响应自动生成mock。
五种方式对比如下:
三、mock两大功能
mock两大功能:(1)记录真实的调用信息;(2)生成模拟的返回信息;
对于测试用例来说,不仅关心mock是否返回了期望的结果,还需要关心SUT是否以期望的方式调用了mock对象。
如果SUT没有以期望的方式调用,比如:没有传参或者参数不对,那么SUT就存在问题。
mock需要详细记录来自SUT的调用信息,并提供给用例来校验。
四、常用 mock 工具
1、单元测试级别
easymock、jMock、Mockito、Unitils Mock、PowerMock、JMockit等。
2、接口测试级别
接口级别的mock工具完成的主要功能是对一个用户的请求,模拟server返回一个接口的响应数据。常用的有:
- Wiremock
- Mockserver
- Moco
- Mock.js
- RAP
猜你喜欢
- 2025-06-28 代码小白的网页制作神器(如何用代码制作网页)
- 2025-06-28 java版gRPC实战之三:服务端流(java 服务端)
- 2025-06-28 Cursor 开发完N个大型项目后的硬核经验
- 2025-06-28 领导说:“做个设计评审吧”(设计开发的五个阶段的评审内容)
- 2025-06-28 使用Swager API Docs和easy-mock生成模拟数据
- 2025-06-28 强大的mock数据生成工具--apipost
- 2025-06-28 Mock.js 实用教程:快速上手模拟数据生成
- 2025-06-28 五分钟教你用NodeJS手写一个Mock数据服务器
- 2024-10-06 想要mock你的网络请求?还不快来学习Charles
- 2024-10-06 测试工具链—— AnyProxy搭建HTTP(S)代理服务器构建Mock服务(一)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)