postman中接口常用断言--详解

我们检验一个测试点是否通过,一般会将我们心理预期的结果与实际结果进行比对,如果结果一致则证明测试通过,如果结果不一致,则证明测试不通过,这即是我们经常所说的断言。

在 postman 中封装了我们常见的断言(Tests),当然 Tests 除了可以作为断言,还可以当做后置处理器,经常应用于:
【1】获取当前接口的响应,传递给下一个接口
【2】控制多个接口间的执行顺序。
在这里插入图片描述

postman 中封装的常见断言

1.断言响应码(最常用)

在tests框内输入如下命令 ,验证响应码是否为200(常见的有200,301,401,404等)

pm.test("Status code is 200", function () {
    pm.response.to.have.status(200);
});

2.断言响应是否包含某个字符串

pm.test("Body matches string", function () {
    pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});

3.断言响应为json体时的某个key对应的值(“name == 张三”)

pm.test("Your test name", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData["data"][1].name).to.eql("张三");
});

4.断言响应时间(响应时间小于500ms)

pm.test("Response time is less than 200ms", function () {
    pm.expect(pm.response.responseTime).to.be.below(500);
});

5.检查实际获取的响应体(即 Body 信息)与预期结果的响应体是否一致;

pm.test("Body is correct", function () {
    pm.response.to.have.body("response_body_string");
});
  1. 将json返回值添加到环境变量中,供其他用例使用
var jsonData = pm.response.json();
pm.environment.set("variable_key", "variable_value");

需要注意的点:postman 获取断言时,任何响应都必须转为 JsonData 对象。例如 我们想获取如下响应信息中键值为 name 的值:

{
  "reponse": {
    "person": {
      "name": "张三",
      "age": 18
    }
  }
}

此时我们这样做

//第一步将响应转为 jsonData 对象
jsonData = pm.response.json();
//第二步通过 . 获取到我们想要的 name 的值
var age = jsonData.reponse.person.name;

由此我们可以任意获取响应中的字段,进而在设置成相应的环境变量,当然就可以作为参数传递给任意接口了,这就是接口间参数传递的原理所在;

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值