上篇给大家讲解了用Postman做接口测试,请求结果断言方法常用的断言模板,这篇,我们一起来熟悉下不常用的断言模板有哪些?
- 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。
- 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"}');
- });
使用起来过于麻烦,一般不推荐使用该断言模板。

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

- 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);
- });
这个脚本模板并不算是断言,其作用是将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"');
- });
这个方法通过编写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;
- });
