上篇给大家讲解了用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即可。

nestjs post返回200 postman返回200_单元测试

通常情况下,希望获取到的返回状态码都是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"}');
});

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

nestjs post返回200 postman返回200_jenkins_02

 

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");
});

nestjs post返回200 postman返回200_postman_03

 

 

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);
});

nestjs post返回200 postman返回200_jenkins_04

 

 

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"');
});

nestjs post返回200 postman返回200_nestjs post返回200_05

 

 

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;
});

 

nestjs post返回200 postman返回200_postman_06