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


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

    不常用断言模板

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

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

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

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

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

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

    与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为例:

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

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

     

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

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

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

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

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

     

     

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

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

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

    例如:

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

     

     

    Response Body:Convert XML body to a JSON Object 转换xml格式内容为json对象

    这个脚本模板并不算是断言,其作用是将xml格式的返回结果转化为json,在转为json之后可以配合Json value check方法来进行使用。

    例如:

    1. //将xml格式字符串转为json格式
    2. var jsonObject = xml2Json(responseBody);
    3. //将json对象转为纯字符串在console控制台输出
    4. console.log(JSON.stringify(jsonObject))
    5. //对转换得到的json对象进行解析断言
    6. pm.test("断言xml的return中包含msg为success", function () {
    7. pm.expect(jsonObject['S:Envelope']['S:Body']['ns2:authResponse']['return']).to.include('"msg":"success"');
    8. });

     

     

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

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

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

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

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

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

     

  • 相关阅读:
    峰会•沙龙•招聘 | 记零数科技多线并进的一天
    Zookeeper应用场景和底层设计
    【推荐系统】wide&deep模型、NeuralCF模型 笔记
    JavaFX Scene Builder Miscellaneous 控件详解
    钉钉自动打卡
    企业级低代码开发效率变革赋能业务增长
    使用 redis 减少 秒杀库存 超卖思路
    SpringBoot实现多数据源(一)【普通版切换】
    eslint常用配置
    算法分析与设计CH25:回溯算法Back-Tracking——N皇后问题
  • 原文地址:https://blog.csdn.net/weixin_68548441/article/details/125619555