wiremock使用入门
wiremock 简介
WireMock是一个开源的测试工具,支持HTTP响应存根、请求验证、代理/拦截、记录和回放。最直接的用法:
- 为Web/移动应用构建Mock Service
- 快速创建Web API原型
- 模拟Web Service中错误返回
- 录制HTTP请求和回放
生成mock API的方式
生成mock api有两种方式:一种是新建mapping文件,另一种是通过wiremock的api. 其中第一种可以永久保存下来,第二种是暂时生成API,待下次build container后,会被清除. 下面详细介绍一下两种方式:
新建Mapping文件生成mock API
一个Mock的api对应一个json文件,放在mapping/下,文件格式如下:
{ "request": { "url": "/QueryPWIDByLoginname", "method": "POST", "bodyPatterns": [ { "equalToJson": "{ \"loginName\":\"17317920860\"}", "ignoreArrayOrder": true, "ignoreExtraElements": true } ] }, "response": { "status": 200, "body": "{\"code\":\"0\",\"data\":{\"AccountID\":\"\",\"LoginNameType\":\"2\",\"LoginStatus\":\"1\",\"PWID\":\"300111000156276629\",\"PWIDType\":\"wanda\",\"Status\":\"1\",\"SysFrom\":\"wandacloud\"},\"msg\":\"success\"}", "headers": { "Content-Type": "application/json; charset=utf-8", "Date": "Fri, 18 Aug 2017 07:05:05 GMT" } } }
mapping文件可以手动写,也可以通过wiremock的record功能生成.
record 功能生成mapping
wiremock Server提供了record UI, 访问地址: http://10.214.169.111:31703/__admin/recorder/
下面以登录注册模块QueryPWIDByLoginname功能为例,打开record UI, 需要mock的URL填入,http://10.214.169.111:30303,点击 Record按钮. 之后发向http://10.214.169.111:30303的请求,可以用http://10.214.169.111:31703来代理例如,应发送请求:
访问:
curl -X POST "http://10.214.169.111:31703/QueryPWIDByLoginname" -H "accept: application/vnd.response+json" -H "content-type: application/json" -d "{ \"loginName\": \"17317920860\"}"
返回:
{"code":"0","data":{"AccountID":"","LoginNameType":"2","LoginStatus":"1","PWID":"300111000156276629","PWIDType":"wanda","Status":"1","SysFrom":"wandacloud"},"msg":"success"}
点击Stop按钮,结果如下:
2.调用wiremock的api获取录制内容:使用curl/浏览器等方式获取:http://10.214.169.111:31703/__admin/mappings
3.将request和response部分拷贝到一个mapping目录下的一个新json文件, 上传git,完成.
使用wiremock admin rest api生成mock API
/__admin/mappings
POST http://10.214.169.111:31703/__admin/mappings
body:
{ "request": { "method": "GET", "url": "/fromAPI" }, "response": { "status": 200, "body": "Hello world - API!", "headers": { "Content-Type": "text/plain" } } }