前言:
请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i
简介:
Postman是一个接口测试工具,在做接口测试的时候,Postman相当于一个客户端,它可以模拟用户发起的各类HTTP请求,将请求数据发送至服务端,获取对应的响应结果, 从而验证响应中的结果数据是否和预期值相匹配;并确保开发人员能够及时处理接口中的bug,进而保证产品上线之后的稳定性和安全性。 它主要是用来模拟各种HTTP请求的(如:get/post/delete/put..等等),Postman与浏览器的区别在于有的浏览器不能输出Json格式,而Postman更直观接口返回的结果。
背景:
当我们使用Postman做接口测试时,不免某些接口请求前需要获取token参数,验证请求是否有效。
问题引申:当我们获取到token后需要手动添加到请求头里面,一旦token过期了,需要重新获取token,需要手动替换请求头中的token。周而复始麻烦的很!!!
解决思路:设置Postman中全局变量,将参数返回值token设置全局变量,便于其他接口调用
Test 简介
在 postman 中封装了我们常见的断言(Tests),当然 Tests 除了可以作为断言,还可以当做后置处理器
- 获取当前接口的响应,传递给下一个接口
- 控制多个接口间的执行顺序
一、【登入接口】获取token
1.1 设置全局变量
设置全局参数,添加请求【登入接口】的请求参数
1.2 调用全局参数
二、【查询接口】并入token
2.1 【查询接口】token验证
2.2 【登录接口】中使用Tests语句自动添加环境变量
//把返回值解析成json字符串 var res = JSON.parse(responseBody) //参数填充 postman.setEnvironmentVariable(\"authorization\",res.value.token); //简写 //pm.environment.set(\"authorization\", res.value.token); //自动设置值 //postman.setGlobalVariable(\"authorization\",res.value.token)
发送请求运行后,再次查看【登入请求】,全局参数已自动添加token值
2.3 【查询接口】中引用参数值
引用参数值,实现每执行【登入接口】请求,完成token自动赋值替换
Tests 中常用方法
//1、设置环境变量 postman.setEnvironmentVariable(\"key\", \"value\"); 或 pm.environment.set(\"key\", \"value\"); //2、设置全局变量 postman.setGlobalVariable(\"gv\", \"111111\"); 或 pm.globals.set(\"g\", \"2222\"); //3、检查resonse body中是否包含某个string tests[\"结果:Body matches string\"] = responseBody.has(\"string_you_want_to_search\"); 或 pm.test(\"结果:Body is correct\", function () { pm.response.to.have.body(\"response_body_string\"); }); //4、验证Status code状态响应码是否是某个值 tests[\"Successful POST request\"] = responseCode.code === 200 || responseCode.code === 202; 或 pm.test(\"Successful POST request\", function () { pm.expect(pm.response.code).to.be.oneOf([200,202]); });
Pre-request Script 简介
- Pre-request Script是集合中请求发送之前需要执行的代码片段
- 请求参数中包含一个随机数或者请求header中包括一个时间戳,或者你的请求参数需要加密
一、【登录接口】请求发起前处理
使用Pre-request Script语句对密码进行加密请求
var body_json = { \"userCode\" : \"admin\", \"passwd\" : \"123456\" } pwd = body_json[\"passwd\"] // 获取passwd的值 var pwd = CryptoJS.MD5(pwd).toString() // md5加密pwd变量 body_json[\"passwd\"] = pwd // 设置passwd为加密后的密码 console.log(body_json) var body_str = JSON.stringify(body_json) // converts objects to strings pm.environment.set(\'request_body\', body_str) // 把处理后的body赋值给参数request_body,在body中输入{{request_body}}
样例:
Pre-request Script 中常用方法
// 清除全局变量 pm.globals.unset(\"variable_key\"); // 清除环境变量 pm.environment.unset(\"variable_key\"); // 获取全局变量 pm.globals.get(\"variable_key\"); //获取一个变量 pm.variables.get(\"variable_key\"); // 获取环境变量 pm.environment.get(\"variable_key\"); //发送一个请求 pm.sendRequest(\"https://postman-echo.com/get\", function (err, response) { console.log(response.json()); }); //设置环境变量 pm.globals.set(\"variable_key\", \"variable_value\");
总结:
我是南国以南i记录点滴每天成长一点点,学习是永无止境的!转载请附原文链接!!!
参考链接、参考链接、
来源:https://www.cnblogs.com/bgyb/p/16158571.html
本站部分图文来源于网络,如有侵权请联系删除。