不会接口测试?用Postman轻松入门——请求结果断言方法

2375 篇文章 33 订阅
1891 篇文章 13 订阅

上篇给大家讲解了用Postman做接口测试,请求结果断言方法常用的断言模板,这篇,我们一起来熟悉下不常用的断言模板有哪些?

不常用断言模板

Status code:Code is 200 断言返回状态码为200

pm.test("Status code is 200", function () {
  //从postman返回中判断它是否有200这个状态码
  pm.response.to.have.status(200);
});

其中的含义很好理解,pm表示postman,在test方法中设置用例的名称Status code is 200。使用时,根据预期的状态码修改function中的200即可。

不会接口测试?用Postman轻松入门(八下)——请求结果断言方法

通常情况下,希望获取到的返回状态码都是200。

Response Body: Is equal to a String 断言返回体内容与指定字符串相等

pm.test("Body is correct", function () {
  //断言返回体内容为指定字符串
    pm.response.to.have.body("response_body_string");
});

与Response Body: Contains string 类似,不同的是,Response Body: Is equal to a String需要设置的预期结果是完整的请求体内容,较少使用。

并且要注意如果是json格式的返回结果,最好选择Text格式显示返回体再行复制。

同时由于json格式的字符串通常带有双引号,所以还需要对字符串中的双引号进行转义,或者将to.hava.body()方法代码的双引号改为单引号使用。

如果出现unicode编码,也要注意对\进行转义。

以特斯汀自动化平台头像上传接口
http://www.testingedu.com.cn/mypro/api/user/setavatar为例:

pm.test("断言返回结果是预期值", function () {
    pm.response.to.have.body('{"code": 1000, "msg": "\\u606d\\u559c\\u60a8\\u4fee\\u6539\\u6210\\u529f", "img": "media/avatar/12.png"}');
});

使用起来过于麻烦,一般不推荐使用该断言模板。

不会接口测试?用Postman轻松入门(八下)——请求结果断言方法

Response Headers:Content-Type header check 断言返回头中有指定头域

pm.test("Content-Type is present", function () {
  //判断postman的返回体中包含Content-Type头域
    pm.response.to.have.header("Content-Type");
});

使用非常简单,在脚本中修改想要验证的头域名。

例如头域字段中包含
Access-Control-Allow-Origin,就可以对它进行校验

pm.test("头域中出现Access-Control-Allow-Origin", function () {
    pm.response.to.have.header("Access-Control-Allow-Origin");
});

不会接口测试?用Postman轻松入门(八下)——请求结果断言方法

Response time is less than 200ms 断言响应时间小于200毫秒

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

用于验证请求发出后得到响应的时间小于指定毫秒数。

例如:

pm.test("诗词接口响应时间小于100毫秒", function () {
    pm.expect(pm.response.responseTime).to.be.below(100);
});

不会接口测试?用Postman轻松入门(八下)——请求结果断言方法

Response Body:Convert XML body to a JSON Object 转换xml格式内容为json对象
这个脚本模板并不算是断言,其作用是将xml格式的返回结果转化为json,在转为json之后可以配合Json value check方法来进行使用。

例如:

//将xml格式字符串转为json格式
var jsonObject = xml2Json(responseBody);
//将json对象转为纯字符串在console控制台输出
console.log(JSON.stringify(jsonObject))

//对转换得到的json对象进行解析断言
pm.test("断言xml的return中包含msg为success", function () {
    pm.expect(jsonObject['S:Envelope']['S:Body']['ns2:authResponse']['return']).to.include('"msg":"success"');
});

不会接口测试?用Postman轻松入门(八下)——请求结果断言方法

Use Tiny Validator for JSON data 使用tv4对JSON格式数据进行格式校验

这个方法通过编写json内容的指定格式结构,来对json返回结果的格式进行验证。

//制定json格式结构为其中的元素为布尔值(即true 或者 false)
var schema = {
    "items": {
        "type": "boolean"
    }
};
//构造两组测试数据,data1满足元素为布尔值的条件,data2不满足
var data1 = [true, false];
var data2 = [true, 123];
//断言data1和data2是否符合模板结构,由于data2不满足,例子将得到断言失败的结果
pm.test('Schema is valid', function () {
    pm.expect(tv4.validate(data1, schema)).to.be.true;
    pm.expect(tv4.validate(data2, schema)).to.be.true;
});

schema的语法格式可以参考:http://json-schema.org/ ,但是意义不大,并不常用。

以诗词接口为例,可以对返回结果进行格式验证:

//编写要求的格式结构
var schema = {
    //properties设置json中出现的字段与其限定结构
    "properties": {
        //表示出现code字段,值为整型
        "code": {"type":"integer"},
        //表示出现message字段,值为字符串
        "message":{"type":"string"},
        //表示出现result字段,值为json
        "result":{"type":"object"}
    }
};
//获取返回结果json对象
var jsonData = pm.response.json();
//验证返回结果符合模板结构
pm.test('符合模板结构', function () {
        pm.expect(tv4.validate(jsonData,schema)).to.be.true;
});

在这里插入图片描述

最后: 可以在公众号:伤心的辣条 ! 自行领取一份216页软件测试工程师面试宝典文档资料【免费的】。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

我推荐一个【Python自动化测试交流群:746506216】,大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,助你快速进阶Python自动化测试/测试开发,走向高薪之路。

喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一 键三连哦!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值