postman

『政善治』Postman — 11.Postman断言(二)

2021-03-10  本文已影响0人  繁华似锦Fighting

3、示例

(1)响应码断言

我们以“添加学院测试为例”

1)准备数据

Pre-request Script编辑如下代码,来准备数据

// 随机生成一个3位数字的id
var dep_id = Math.floor(Math.random()*1000);
pm.environment.set("depid" , dep_id); //设置到环境变量中

// 随机生成学院名称dep_name
// 随机生成一个10位的字符串
var data = Math.random().toString(36).slice(-10) ;
var dep_name = data+"学院";
pm.environment.set("dep_name" , dep_name);//设置到环境变量中

// 随机生成院长的名字
var first_name = ["赵","钱","孙","李","刘"];
var last_name = ["子鼠","丑牛","寅虎","牟兔","辰龙","巳蛇"];
var master_name = first_name[Math.floor(Math.random() * (first_name.length))] +last_name[Math.floor(Math.random() * (last_name.length))];
pm.environment.set("master_name" , master_name);//设置到环境变量中

// 随机生成口号
var slogan_str = ["吃饭","睡觉","打豆豆"];
var slogan = slogan_str[Math.floor(Math.random() * (slogan_str.length))];
pm.environment.set("slogan" , slogan);//设置到环境变量中


// 很low的代码,只做练习

2)编辑请求所要提交的数据

3)编写Tests中的断言

使用Tests中的Status code: Code is 200内置代码片段。

// 用来断言接口请求的状态码,针对HTTP协议状态码。
// pm.test 表示Postman进行测试断言
// "Status code is 200" 表示断言的名称或者说明,一般和测试用例同名
// function 表示 执行断言的方法
pm.test("新增学院请求正常放回201", function () {
    pm.response.to.have.status(201);
});

4)查看断言结果

如下图:

提示:

Test Results(1/1):表示一共有1个断言,执行通过了1个断言。

All:表示显示所有断言。

Passed:表示只显示通过的断言。

Skipped:表示只显示跳过的断言。

Failed:表示只显示失败的断言。

当我们断言执行失败时,也会有详细提示,如把上面的状态码改成202。

AssertionError: expected response to have status code 202 but got 201

AssertionError:预期响应的状态码为202,但得到201。

(2)返回值断言(非常频繁)

返回值断言,就是再接口返回的数据(body主体)中的字段进行验证。

以返回值为json格式的数据为例:

这里先标识一下,接口的实际返回结果如下:

{
    "create_success": {
        "count": 1,
        "results": [
            {
                "dep_id": "637",
                "dep_name": "k7iwvtgk2h学院",
                "master_name": "李子鼠",
                "slogan": "睡觉"
            }
        ]
    },
    "already_exist": {
        "count": 0,
        "results": []
    }
}

同上面练习,直接编写Tests中的断言,

使用Tests中的Response body: JSON value check内置代码片段。

// 断言返回值为json格式的数据
// pm.test 表示Postman进行测试断言
// "Your test name" 表示断言的名称或者说明,一般和测试用例同名
// function 表示 执行断言的方法
// jsonData 表示接口返回的所有数据
// pm.expect 表示设置断言的预期
// jsonData.value 表示取具体的某一字段,一级一级点下去就可以(层级关系)
pm.test("断言添加学院数量", function () {
    var jsonData = pm.response.json(); // 获取返回值所有数据
    pm.expect(jsonData.create_success.count).to.eql(1); // 断言返回值中具体字段的值
});

然后执行并查看结果:

说明:

如果结果返回的json数据中有数组,如下:我们要取slogan字段

{
    "create_success": {
        "count": 1,
        "results": [
            {
                "dep_id": "637",
                "dep_name": "k7iwvtgk2h学院",
                "master_name": "李子鼠",
                "slogan": "睡觉"
            }
        ]
    },
    "already_exist": {
        "count": 0,
        "results": []
    }
}

需要如下方式进行选取:

pm.test("断言添加学院的口号", function () {
    // 获取返回值所有数据,赋值给jsonData
    var jsonData = pm.response.json(); 
    // 可以使用console.log在控制台输出内容,进行调试
    // console.log(jsonData.create_success.results[0].slogan)
    // 断言返回值中具体字段的值
    pm.expect(jsonData.create_success.results[0].slogan).to.eql("哈哈哈"); //这里是重点
});

其他代码片段使用方式同理,这里就不一一举例了。其实Tests中编写的就是JavaScript脚本,你也可以编写循环、判断、输出到控制台等代码。

上一篇下一篇

猜你喜欢

热点阅读