Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/zhangfei19841004/zmock

zmock--http接口的mock平台
https://github.com/zhangfei19841004/zmock

http mock mock-server test test-automation zmock zson

Last synced: 2 days ago
JSON representation

zmock--http接口的mock平台

Awesome Lists containing this project

README

        

zmock功能
====

模拟出一个不存在的http接口,根据请求参数的不同返回对应的数据。

zmock应用场景
====

1. 在接口文档写好后,就可以mock出一个接口,以便于客户端开发,且测试人员也可以开始写测试用例。mock出来的接口也相当于一种契约,服务端与客户端都必须遵守这个mock出来的契约。
2. 当系统中有第三方接口,在做性能测试时,可以mock第三方接口,作为性能测试的档板。
3. 其它。

zmock介绍
====

1. 开发语言及框架:java,spring,easyui
2. web容器:tomcat
3. 部署方式:
* 将打包好的zmock.war更名为ROOT.war
* 将ROOT.war放在tomcat的webapps目录下面
* 启动tomcat
4. 设置
* 打开http://ip:port/zmock/index?role=whosyourdaddy
![](https://testerhome.com/uploads/photo/2017/65fb7aa1-0baf-45ab-8251-cf939d193163.png!large)
* 填写mock数据保存目录,作为一个workspace。在https://github.com/zhangfei19841004/zmock 中有一个data目录,建议将mock数据保存目录指向这个data目录,里面有已经写好的mock接口,可以作为参考。
* 一般情况下用http://ip:port/zmock/index访问即可

zmock平台使用说明
====
> 接口文档:
请求链接:/api/info/v1
请求方法:post
请求参数示例:{"name":"zhang","age":30}
请求参数说明:

| 参数名 | 参数类型 | 是否必需 | 示例值 |
| --------- | ------------ | ------------ | --------- |
| name | string | 是 | zhang |
| age | int | 是 | 30 |

响应说明:
1. 当name的值为空或者age的值小于等于0时,响应:
{"retCode":"300","retMsg":"参数不正确"}
2. 当name的值为zhan时,响应:
{"retCode":"301","retMsg":"数据不存在"}
3. 当name值为zhang且age的值为18时,响应:
{"retCode":"301","retMsg":"数据不存在"}
4. 其它情况下,响应:
{"retCode":"200","retMsg":"ok.","data":{}}

***

> 以上是一份简单的接口文档,公司不同,文档的要求不同,但我相信大家都应该能看懂这份文档,现在,我们根据这份文档来mock一个http接口出来:
1. 点击左上角的+号:

![](https://testerhome.com/uploads/photo/2017/a33a5327-5cd6-4595-b07b-5fc74eb66800.png!large)

2. 确定后,在菜单中选择或输入测试DEMO,在mock请求URL中填写:

![](https://testerhome.com/uploads/photo/2017/22f6c283-e3dc-47b9-932a-36abaad5cedd.png!large)

3. mock请求方法选择POST:

![](https://testerhome.com/uploads/photo/2017/08c0c485-4c63-401a-81a0-6962f377a3a1.png!large)

4. 在mock请求参数模板中:

![](https://testerhome.com/uploads/photo/2017/c3859752-e489-4b0b-be04-9f4816388fe0.png!large)

5. 在mock规则定义中点击新增:

![](https://testerhome.com/uploads/photo/2017/36cb97ff-d047-4d77-8deb-b05c445d9b13.png!large)

6. 再增加一条规则:

![](https://testerhome.com/uploads/photo/2017/a5ee19b8-ea28-4e82-ab31-139f1460e602.png!large)

7. 最后一条规则:

![](https://testerhome.com/uploads/photo/2017/7b49cded-db16-43cc-a756-9321023373df.png!large)

8. 保存后,mock就完成了

***

> mock完成后,我们来测试一下这个http接口:

![](https://testerhome.com/uploads/photo/2017/2b9e84f0-4f98-4bf8-aa2b-10cce7e26c24.png!large)

![](https://testerhome.com/uploads/photo/2017/ddebdc65-a7da-4483-8965-67d6279b4055.png!large)

![](https://testerhome.com/uploads/photo/2017/904419a6-bbb0-452b-bdd5-be840b28cd2f.png!large)

![](https://testerhome.com/uploads/photo/2017/81f9c94b-fea0-4834-80bd-f859b5840102.png!large)

zmock的特点
====
1. 请求参数模板的定义。根据请求参数模板,来判断请求参数是否正确。
mock请求参数模板说明:
* .*表示请求参数为任意字符串,用于POST BODY
* 如username=&password=表示POST表单提交或GET请求
* 如{"username":"","password":""}表示POST BODY为JSON串
2. mock规则利用表达示来定义。比如/name,/age,这是json路径,具体的请参考:https://github.com/zhangfei19841004/zson
表达示所支持的比较符有:
== != > >= < <= in contains
表达示方便扩展,如有需要,自行扩展即可。
支持的连接符有:and or (),其中()的优先级最高,支持括号里套括号。
3. 采用文件异步保存数据的方式,且数据都放在内存里,保证接口的响应速度。
4. zmock脚本说明
* zmock脚本采用jexl表达示,具体请参考:[jexl官网](http://commons.apache.org/proper/commons-jexl/)
* 内置对象有:headers,params,response

zmock地址
====
* github: https://github.com/zhangfei19841004/zmock
* 体验地址:http://101.200.48.144:8080/zmock/index

作者联系方式
====
* QQ:408129370