mock模拟接口测试_「测试」 - 接口测试 & mock工具Moco

在日常接口测试的工作中,经常需要依赖其他系统的API,但是联调不常有,只能自己通过mock完成数据依赖。

对于Java栈的mock工具,ThoughtWorks的前工程师郑烨编写了Moco工具,并开源在GitHub,Moco repo:https://github.com/dreamhead/moco。

Moco的优点:

  1. 支持http、https、socket
  2. 支持设置headers、cookies、statuscode
  3. 支持GET、POST、PUT、DELETE请求
  4. 只需JRE环境即可运行
  5. 支持热更新
  6. 支持json、xml、text、file数据格式
  7. 能与JUnit、Maven、Gradle集成

Moco的缺点:

Moco的使用很简单,配置也很方便。但也仅仅是能Stub出接口,模拟出简单的场景。

如果接收到请求后需要做一些处理,如需查询数据库、运算、或者一些复杂的操作,就无能为力了。

但是在工作中,还是可以作为一个稳定的mock工具长期部署,应用于测试中的。

一、独立使用(standalone)

只需要根据mock要求,完成mock.json的配置,启动即可。

vim 

启动Moco,java -jar moco-runner-0.12.0-standalone.jar http -p 8080 -c mock.json

TIPS:更多的启动参数,参看GitHub文档。

A、设定URI

JSON中无法添加注释,利用description字段可以清楚的说明接口的功能。

[
    

B、设定请求方式

带参数GET请求,http://localhost:8088/getparam?id=1&status=100,参数通过queries设置k-v对。

[
    

带参数POST请求,参数通过forms设置k-v对,需要通过工具发送POST请求。

[
    

C、设定Headers及请求返回为JSON

[
    

D、设定Cookies

如果不获取cookies,直接访问http://localhost:8088/get/with/cookies,则返回失败;如果首先访问http://localhost:8088/getcookies,获取到服务器cookies,再访问http://localhost:8088/get/with/cookies,不用额外设定cookies也可以获得正确返回。

[
    

E、重定向

[
    

F、返回类型为file内容

对于比较大的JSON,可以通过文件方式返回。

[
    

G、HTTPS

通过Java的keytools生成密钥,具体生成方式参考tomcat-https,启动moco时指定密钥文件即可。

java -jar moco-runner-0.12.0-standalone.jar https -p 8080 -c mock.json --https tomcat.keystore --cert 123456 --keystore 123456

ae4907d9598ac705efbcdeb71f233237.png

H、支持多重文件引入(类似nginx的conf)

Moco支持在配置文件中引入其他配置文件,对于按照URI分组的可以通过子JSON的方式进行mock的组织,更加便于阅读和管理。

启动参数,需要从-c修改为-g,如果只想引入多个配置,可以不适用context字段。

根JSON内容如下:

[
    

子JSON如下:

# 

I、正则表达式

支持正则方式对URI进行返回。

[
    

J、延迟返回

[
    

K、template

以上的请求参数的值和返回值都是固定的,从0.8版本之后,Moco提供了template功能,可以动态返回一些参数值。

[
    

template支持以下语法。

"template": "${req.version}"
"template": "${req.method}"
"template": "${req.content}"
"template": "${req.headers['foo']}"
"template": "${req.queries['foo']}"
"template": "${req.forms['foo']}"
"template": "${req.cookies['foo']}"

请求https://localhost:8088/getInfo?name=isisiwish,返回isisiwish。

更多request的设置,查看GitHub文档。

二、JUnit

Moco也支持API方式运行,可以轻松通过Maven和JUnit集成。

<dependencies>
    

代码:

@Test

A、大量请求模拟

实际测试工作中,会有很多接口需要mock,需要引入新的jar包。

<dependency>
    

MocoJunitRunner加载resources下的JSON配置文件,然后自动构建一个mock的服务器。

public 

更多和JUnit的结合,查看GitHub文档。


其他mock工具:

azagniotov/stubby4j

http://www.mbtest.org/

http://wiremock.org/docs/getting-started/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值