Postman 官网地址:
https://www.getpostman.com/pricing
可以通过上方tab边上的+号,新建多个请求。接口设计区从上到下分为请求区和响应区
新建测试集: New按钮->Collection 或 直接点击测试集列表上方的新建测试集按钮
子文件夹:子文件夹的属性中同样拥有描述,授权,请求前脚本,和请求后断言(没有变量,一个请求集的变量统一管理),实现了不同范围(Scope)的Fixture功能。
请求集导出:请求集可以导出并发送给别人(不携带环境信息),别人通过导入来使用你的接口
请求集分享: 请求集直接分享给别人(双方都需要注册)
当请求URL中参数很多时,不方便进行添加和查看,可以点击Params按钮,以表格的方式添加变量及值,从表格添加后,变量和值会自动添加到URL中
注意:选择不同的请求,会自动在Header中添加Content-Type信息
1 |
tests["HTTP状态码200"]=responseCode.code == 200; |
1 |
tests["状态码200"] = responseBody.has("登录成功"|"你已经登录,无需重复登录"); |
接口样例
POST
https://demo.fastadmin.net/admin/index/login.html
用户名/密码: username:admin password:123456
1 |
var jsonData = JSON.parse(responseBody); //获取body中返回的所有参数 |
接口样例 GET http://www.tuling123.com/openapi/api?key=ec961279f453459b9248f0aeb6600bbe&info=你好
Postman尝试通过列出编辑器旁边常用的片段来简化过程。您可以选择要添加的代码段,并将相应的代码添加到测试编辑器中。
在postman中,可以利用tests将接口返回的response设置为环境变量,供后续接口使用(类似参数化的概念)
1 |
var jsonData =JSON.parse(responseBody); //获取body中返回的所有参数 |
https://learning.getpostman.com/docs/postman/scripts/test_examples/
1 |
//设置环境变量 |
1 |
pm.globals.set("variable_key", "variable_value"); //设置一个全局变量 |
1 |
pm.variables.get("variable_key"); |
1 |
tests["Body matches string"] = responseBody.has("string_you_want_to_search"); |
1 |
tests["Body is correct"] = responseBody === "哈哈哈"; //必须完全匹配 |
1 |
var data = JSON.parse(responseBody); |
JSON.parse()方法,把json字符串转化为对象。parse()会进行json格式的检查是一个安全的函数。
如:检查json中某个数组元素的个数(这里检测programs的长度)
1 |
var data = JSON.parse(responseBody); |
1 |
//getResponseHeader()方法会返回header的值,如果该值存在的话 |
1 |
tests["Response time is less than 200ms"] = responseTime < 200; |
1 |
tests["Response time is acceptable"] = _.inRange(responseTime, 100, 1001); |
1 |
tests["Status code is 200"] = responseCode.code === 200; |
1 |
tests["Status code name has string"] = responseCode.name.has("Created"); |
1 |
tests["Successful POST request"] = responseCode.code === 201 || responseCode.code === 202; |
1 |
var schema = { "items": { "type": "boolean" }}; |
1 |
var Json = JSON.parse(request.data); |
假设requestBody中有”version”:”1.0”;这个值,如果想获取到version的value值,代码如下
1 |
var Json = JSON.parse(request.data); |
1 |
JSON.parse() //【从一个字符串中解析出json对象】--把string转对象 |
1 |
pm.sendRequest("https://postman-echo.com/get", function (err, response) { |
1 |
var jsonObject = xml2Json(responseBody); |
1 |
var Jsondata = JSON.parse(responseBody); |
1 |
//设置下一个要执行的请求 |
postman.setNextRequest()一些重点:
* 指定后续请求的名称或ID,集合运行器将负责其余的请求。
* 它可以用在预请求或测试脚本中。如果有多个赋值,则考虑最后一个赋值。
* 如果postman.setNextRequest()请求中不存在,则集合运行器默认为线性执行并移至下一个请求