上篇给大家讲解了用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即可。
通常情况下,希望获取到的返回状态码都是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"}');
});
使用起来过于麻烦,一般不推荐使用该断言模板。
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");
});
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);
});
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"');
});
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;
});