API接口测试-postman自动断言及关联用法

在批量执行大量接口请求时,往往需要自动化断言来实现精准的数据请求把控,来监测请求过程中产生的异常,本文将讲述postman在实际使用过程中常用的一些自动化断言方法以及基础关联用法。

***自动化断言***


断言:获取一个环境变量(Get an environment variable)

pm.environment.get("variable_key");

//返回值用一个变量接收  如var value = pm.environment.get("variable_key");

//环境变量:在特定环境下生效的变量(生产、测试、开发...)

断言:获取一个全局变量(Get a global variable)

pm.globals.get("variable_key");

//返回值用一个变量接收  如var value = pm.globals.get("variable_key");

//全局变量:在postman全局生效的变量,全局唯一。

断言:获取一个变量(Get a variable)

pm.variables.get("variable_key");

//界面获取法:{{变量名}}

//代码获取:需用变量接收

断言:获取一个集合变量(Get a collection variable)

pm.collectionVariables.get("variable_key");

断言:设置一个环境变量(Set an environment variable)

pm.environment.set("variable_key", "variable_value");

//variable_key:设置的环境变量名,必须带双引号
//variable_value:设置的环境变量值,必须带双引号

断言:设置一个全局变量(Set a global variable)

pm.globals.set("variable_key", "variable_value");

//variable_key:设置的全局变量名,必须带双引号
//variable_value:设置的全局变量值,必须带双引号

断言:清除一个环境变量(Clear an environment variable)

pm.environment.unset("variable_key");

断言:清除一个全局变量(Clear a global variable)

pm.globals.unset("variable_key");

断言:清除一个集合变量(Clear a collection variable)

pm.collectionVariables.unset("variable_key");

断言:发送一个请求(Send a request)

pm.sendRequest("https://postman-echo.com/get", function (err, response) {
    console.log(response.json());
});

断言:响应状态码是200(Status code:Code is 200)

pm.test("Status code is 200", function () {
    pm.response.to.have.status(200);
});

// 常用,Status code is 200是名称,可以自己随便起,status(200)是断言的状态码内容

断言:响应体中是否包含字符串(Response body:Contains string)

pm.test("Body matches string", function () {
    pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});

// 常用,Body matches string的位置可以自己定义名称,string_you_want_to_search位置替换成想要判断的字符串

断言:JSON的值检查(Response body:JSON value check)

pm.test("Your test name", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.value).to.eql(100);
});

//最常用

//Var jsonData:使用JavaScript语法定义一个变量,jsonData是变量名

//pm.response.json()是将响应的结果转化为了json格式

//Your test name可以修改成任意名称

//Value替换为json的键  eql后面的100替换为json的值

断言:响应体是否等于一个字符串(Response body:Is equal to a string)

pm.test("Body is correct", function () {
    pm.response.to.have.body("response_body_string");
});

// 比较实用,应用场景不是很广泛,因为判断是完全相等才可以,Body is correct可以替换成任意名称,response_body_string替换为想要判断的文本内容

//替换成JSON时不需要加双引号

断言:校验响应头(Response headers:Content-Type header check)

pm.test("Content-Type is present", function () {
    pm.response.to.have.header("Content-Type");
});

//使用频率不高

//Content-Type is present为提示信息可以改成任意名称

//主要用于断言响应头中是否包含某个值,Content-Type可替换为想断言的响应头

//可以同时断言key和value如:
pm.test("Content-Type is present", function () {
    pm.response.to.have.header("Content-Type","application/json");
});

断言:响应时间小于200ms(Response time is less than 200ms)

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

断言:状态码post请求成功(Status code:Successful POST request)

pm.test("Successful POST request", function () {
    pm.expect(pm.response.code).to.be.oneOf([201, 202]);
});

断言:状态码中是否包含字符串(Code name has string)

pm.test("Status code name has string", function () {
    pm.response.to.have.status("Created");
});

断言:将XML转换为JSON对象(Response body:Convert XML body to a JSON Object)

var jsonObject = xml2Json(responseBody);

断言:判断响应状态码在不在其中(Status code:Successful POST request)

pm.test("Successful POST request", function () {
    pm.expect(pm.response.code).to.be.oneOf([201, 202,200]);
});

//oneOf后的括号中可书写多种情况

***预请求脚本参数携带传递案例*** 


案例:将前置脚本获取的时间戳传递给HTTP/HTTPS请求 

Pre-request Script:
// 获取时间戳
var timestamp = new Date().getTime()

//将时间戳设置到全局变量
pm.globals.set("glb_timestamp",timestamp)


Params:
设置KEY:t
设置VALUE:{{glb_timestamp}}


Request:
"http://域名?t={{glb_timestamp}}"
//完成传递,校验方法:View-Show Postman Console(控制台)

***跨请求关联案例*** 


案例:通过天气API获取的城市信息作为数据传递给百度搜索API使用

天气API:
//天气接口响应信息:GET请求
"URL:http://www.weather.com.cn/data/sk/101010100.html"
{
    "weatherinfo": {
        "city": "北京",
        "cityid": "101010100",
        "temp": "27.9",
        "WD": "南风",
        "WS": "小于3级",
        "SD": "28%",
        "AP": "1002hPa",
        "njd": "暂无实况",
        "WSE": "<3",
        "time": "17:55",
        "sm": "2.1",
        "isRadar": "1",
        "Radar": "JC_RADAR_AZ9010_JB"
    }
}

Tests:
//从响应结果中获取城市的名字
var jsonData = pm.response.json()
var city = jsonData.weatherinfo.city

//将城市名写入到全局变量
pm.globals.set("glb_city",city)

百度API:
GET请求URL:"http://www.baidu.com/s?wd={{glb_city}}"
//通过全局变量完成关联和数据传递

关注我,不迷路

******我的本文相关专栏******

软件测试专栏(单击此处进入)


 ******我的其它作品专栏******

PC常见故障汇总专栏(点击进入)

EXCEL综合场景应用详解(点击此处进入)

全国计算机等级考试-二级python基础(点击此处进入)

你可能感兴趣的:(软件测试,&,开发,postman,测试工具,断言,关联,自动化)