postman使用

2019-03-21  本文已影响0人  小手是只猫

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

上一篇下一篇

猜你喜欢

热点阅读