postman使用
1.如何判断接口是否请求成功
2.如何进行接口批量、定期测试
3.如何处理依赖接口问题(比如商品下单的接口必须要求先登录)
接口结果判断
首先,既然是自动化测试,那么我们肯定需要工具 (Postman) 或者代码能帮我们直接判断结果是否符合预期。那么在接口测试上,大体就两个思路:
判断请求返回的 code 是否符合预期
判断请求返回的内容中是否包含预期的内容(关键字)
postman:
获取返回数据的头部信息:postman.getResponseHeader("")
设置全局变量:postman.setGlobalVariable("variable_key", "variable_value");
snippets中提供的代码模版
1.Status code : Code is 200
//根据返回的 Code 判断请求情况
tests["Status code is 200"] = responseCode.code === 200;
2.Response body: Contains string
//判断返回的内容中是否存在“关键字”。(tests 的 key 可修改,将不再强调)
tests["Body matches string"] = responseBody.has("这里可以改为你要判断的关键字内容");
//如上文提到的:
// 判断结果中是否存在 access_token 关键字
tests["has access_token"] = responseBody.has("access_token")
3.Response body: is equal to string
//判断返回内容是否跟预期完全相等。
tests["Body is correct"] = responseBody === "这里可以改为你的预期内容";
4.Response body: JSON value check
//上文提到,responseBody 为字符串类型,支持转为 Json 格式
var jsonData = JSON.parse(responseBody);
tests["Your test name"] = jsonData.value === 100;
5.Response time is less than 200ms
//判断请求时长是否小于200ms ,具体时长按情况自定义
tests["Response time is less than 200ms"] = responseTime < 200;
*tests特定写法、断言显示的内容就是【】中的字符串,可随意编写
集合(批量)测试
Environment :用于切换接口运行的环境
Iteration :用于设置接口一共要运行的次数。这里我设置了 3 次,可以在右边的 RESULTS 中看出,每个接口都被运行了 3 次。
Delay : 设置每次运行接口之间的时间间隔,单位为毫秒。
Data File : 上传测试数据文件
使用变量
引用一个变量的语法:{{变量名}},我们将账户和密码字段的参数值都设置为变量:{{username}} 、{{password}} 。修改完直接点击运行 (Send) 当然是不行的,因为目前这两个变量还未被赋值,不过我们可以在 Pre-request Script 面板中进行赋值操作:
Pre-request Script
Pre-request Script 与 Tests 类似,区别在于:Pre-request Script 中的脚本是在执行请求之前运行,而Tests 中的脚本则是在请求完成之后执行。所以,我们可以在 Pre-request Script 功能区中用脚本先个上面两个变量进行赋值,如:
//设置全局变量
postman.setGlobalVariable("username", "wuhui2224");
postman.setGlobalVariable("password", "123456");
测试数据集
Data File , 在运行集合前的这个选项就是用来上传测试数据(文件)以赋值给相应变量的。我们先以 CSV 格式的测试数据为例:
username,password
wuhui2224,123456
zhangsheng,222222
数据格式类似表格,第一行表示对应的变量名,下面 2 行表示 2 组账号密码数据,我们保存一份内容为上述示例数据后缀名为.csv 的文件
定期任务
Postman 提供了一个 Monitors (监视器)功能,支持我们提交一个测试任务,安装设置的定时器进行运行,如每小时测试一次
请求依赖问题
大部分依赖问题其实本质上就是一个接口间数据传递的问题,比如调用登录接口后返回一个标识,假设为 token ,那么我们请求下订单接口时只要一起携带 token 参数进行请求即可。
1.保证接口调用顺序
2.将接口A返回的数据传递给后续的接口B、C、D
自定义执行顺序
当然,如果只有默认的一个执行顺序的话,通常没法满足我们复杂的业务需求,所以 Postman 为我们提供了一个函数:postman.setNextRequest("填写你要跳转的接口名") ,支持我们跳转到指定接口继续执行,举个例子:
我们在运行完 Request1 接口成功后,不需要再运行 Request2 而是直接跳至 Request3 ,那么我可以在 Request1 接口的 Tests 功能区中执行跳转代码
这里需要注意几点:
1.postman.setNextRequest() 只在运行集合测试的时候生效,也就是说我们单独运行 (Send) 接口Request1 时,函数是不起作用的。
2.当我们运行集合测试成功从 Request1 -> Request3 后,如果 Request3 后面还有接口,那么后面的接口仍然继续按默认顺序执行,即图中的接口 Request4 仍会被执行。
3.指定的跳转接口必须属于同一个集合中。
4.setNextRequest() 函数不管在 Tests 脚本中何处被调用,它都只在当前脚本最后才被真正执行。比如我们将图中的第二行与第一行互调后,那么在运行跳转函数后第二行代码仍会被执行。
Postman 中的操作
1.我们目录中已保证 Request1 接口优先执行
2.Request1 中 Tests 的代码情况:
if(responseCode.code === 200 && responseBody.has("access_token")){
//如果 code 为 200, 并且返回的数据中存在 access_token 关键字,则认为登录成功
tests["login"] = true;
//将返回的内容转为 json 格式,并且取到 access_token 内容,添加到环境变量中
var jsonData = JSON.parse(responseBody);
//access_token的取值方式视具体的 json 数据结构而定
postman.setEnvironmentVariable("token",jsonData.result.access_token);
//跳转到 Request3 接口
postman.setNextRequest("Request3")
}else{
tests["login"] = false;
//登录失败,可以选择跳转到对应失败后的处理接口进行测试
//postman.setNextRequest("Other Request")
}
3.在接口 Request3 中使用变量 token ,具体使用方式时接口参数规则而定
原文:https://blog.csdn.net/cai_iac/article/details/81030619