美文网首页
postman使用

postman使用

作者: 小手是只猫 | 来源:发表于2019-03-21 15:22 被阅读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

    相关文章

      网友评论

          本文标题:postman使用

          本文链接:https://www.haomeiwen.com/subject/setrlqtx.html