在能熟练使用postman运行接口请求后,会遇到一些问题。例如:

  • 我们的web网站一共有几十个接口,测试的时候如果要切换环境,这个时候要每个接口都要修改url的根路径,一个一个的改也太麻烦了;
  • 还有时候我们经常需要用到上一个接口的返回值,来作为下一个接口的数据来使用,要怎么把参数传递过去呢;
  • 作为接口测试的话,验证接口返回结果是否正确,需要断言来判定这个接口的运行结果是否符合期望,这个时候又该怎么做。

在postman中,这些问题都有解决方案,下面跟我一起来看一下吧。

参考文档:https://learning.getpostman.com/docs/postman/scripts/test_examples/

一、设置全局(环境)变量

  postman中可以设置全局和环境变量,以便可以存储一些例如:url、token值、测试参数等数据。

变量的设置

是通过key-value的形式来存储。

例如:url:http://test.baidu.com

变量的使用:

通过{{变量key}}来调用关键字获取值

例如:{{url}},可以放在需要填写参数的任何位置。

如何创建变量:

  点击postman界面右边的齿轮,在弹窗中可以选择创建全局变量、导入变量文件、创建环境变量。

postman传入RequestParam对象_测试工程师

添加变量:

  全局变量在创建后,任何时候都可以获取到,而环境变量只有在设置为当前环境时,才会获取到此环境中的变量。这个看个人需要来设置是全局变量还是环境变量,例如我把url、账号密码设为环境变量,因为有切换不同环境的需要。

添加全局变量:

postman传入RequestParam对象_postman_02

添加环境变量

postman传入RequestParam对象_postman_03

变量的引用:

  如图所示,是一个环境变量的设置和引用,当鼠标悬浮在我们引用的变量{{key}}上时,会显示当前变量的值。

postman传入RequestParam对象_postman_04

二、参数传递和断言

  在postman中有专门的代码区域,可以通过js代码语言来实现一些自定义操作。在Pre-request Script区域,是请求发送前的代码区,比如我们需要对密码进行md5加密后发送,就可以使用js中的方法先进行加密。在Tests区域中,可以通过获取返回参数的值进行断言,断言失败的接口会显示为false结果。

如何进行参数传递:

  比如支付接口,需要上一个下单接口返回的订单号来作为入参。

  这个时候,首先要在下单接口的Tests区域中,获取到返回数据的订单号,然后存储为全局变量;

  接着在支付接口中,入参中的订单号值填写为我们设置的全局变量,这样就实现了一次参数传递。

postman传入RequestParam对象_测试类型_05

下面我们来看一下这些方法都该怎么写:

2.1变量的设置

这些方法是在postman中对全局(环境)变量的操作方法。

获取变量

  • 获取全局变量:

        pm.globals.get(“variable_key”);

  • 获取当前环境变量:
    pm.environment.get(“variable_key”);
  • 获取普通变量:
    pm.variables.get(“variable_key”);

设置变量

  • 设置全局变量:
    pm.globals.set(“variable_key”, “variable_value”);
  • 设置当前环境变量:
    pm.environment.set(“variable_key”, “variable_value”);

清空变量值

  • 清空当前环境变量:
    pm.environment.unset(“variable_key”);
  • 清空全局变量:
    pm.globals.unset(“variable_key”);

2.2返回数据的判断

这里需要注意的是,网上有一些教程比较老了,例如这种形式的写法:

tests[“Status code is 200”] = responseCode.code === 200;

这样的写法官方文档中已经表示不推荐使用,而是推荐统一的js书写格式。

  • 判断返回状态码
pm.test(“返回状态码为200”, function () {
  pm.response.to.have.status(200);
});
  • 判断返回header中是否有“Content-Type”字段
pm.test(“Content-Type字段存在”, function () {
  pm.response.to.have.header(“Content-Type”);
});
  • 判断接口返回内容匹配一个字符串
pm.test(“返回内容匹配字符串”, function () {
pm.response.to.have.body(“response_body_string”);
});
  • 判断返回参数中包含某个字符串
pm.test(“字符串包含在返回值中”, function () {
pm.expect(pm.response.text()).to.include(“想要搜索的字符串”);
});
  • 判断接口响应时间
pm.test(“接口响应时间小于200ms”, function () {
pm.expect(pm.response.responseTime).to.be.below(200);
});
  • 把responseBody转为json字符串
var Jsondata =JSON.parse(responseBody);
  • 把xml格式返回转换为json格式
var jsonObject = xml2Json(responseBody);
  • 获取并判断返回参数的值
//假设返回参数为:{“code” : 0}
pm.test(“断言code字段值是否为0”,function(){
  var jsonData = pm.response.json(); 
        //创建一个变量,值为返回参数(json格式)
  pm.expect(jsonData.code).to.eql(0); 
         //判断返回参数中code字段值为0
});