目录
课程大纲
昨日回顾
今日目标
- 能够使用postman组织测试用例
- 能够使用postman对测试结果进行断言(响应状态码和json格式响应数据)
- 能够使用postman解决多接口的依赖
Postman高级用法1
一、用例管理
作用:规范法管理接口上的大量测试用例
实现步骤:
- 1. 创建集合---项目(如IHRM、tpshop)
- 2. 创建文件夹---模块(如:登录、员工管理)
- 3. 创建请求---测试用例(如:登录成功)
操作演示
1. 创建集合---项目
2. 创建文件夹---模块
3. 创建请求---测试用例
二、Postman断言
1、断言前置基础
(1)断言:通过代码自动判断实际运行的结果是否与测试用例中的预期结果一致
(2)断言结果:
- 结果一致:测试通过pass
- 结果不一致:测试不通过fail
(3)复习:UnitTest常用断言方式有哪些?
(4)Postman的断言
- 使用JavaScript语言编写的,写在Postman的【Tests】标签中
- 【Tests】中的脚本在发送请求之后执行,它会把断言的结果(PASS/FAIL)最终在【TestResults】标签中
- Postman的常用断言
- 断言响应状态码是否为200(Status code is 200)
- 断言响应体JSON数据校验(Response body:JSON value check)
- 断言响应体是否包含指定字符串(Response body: Contains string)
- 断言响应体是否等于指定字符串(Response body:Is equal to a string)
- 断言响应头是否包含指定的头信息(Response headers: Content-Type header check)
操作示例
2、Postman断言
2.1 断言响应状态码(重点)
样例代码:
pm.test("Status code is 200", function () {
pm.response.to.have.status(200);
});
说明: pm.test是postman内置对象pm对外提供的一种名称为test的方法,他的功能是使用pm.test来编写测试脚 本时,即使方法内部处理内容出现错误也不会影响后续自动化脚本的运行。
案例:
1.请求IHRM项目的登录接口,请求数据({"mobile":"13800000002","password":"123456"})
2.登录接口地址URL:http://ihrm-test.itheima.net/api/sys/login
3.请设置断言自动判定服务器响应状态码为200
2.2 断言JSON数据(重点)
示例代码:
pm.test("Your test name", function () {
var jsonData = pm.response.json();
pm.expect(jsonData.value).to.eql(100);
});
说明:var是用来声明javascript的变量,上面的代码等价于下面的代码。
pm.test("Your test name", function () {
pm.expect(pm.response.json().value).to.eql(100);
});
案例:
1.请求IHRM项目的登录接口,请求数据({"mobile":"13800000002","password":"123456"})
2.登录接口地址URL:http://ihrm-test.itheima.net/api/sys/login
3.请设置断言自动判定服务器响应体数据中success=true,code=10000,message=操作成功!
排错说明:
- (1)检查断言代码片段是否选错了
- (2)检查断言代码是否设置错了 预期结果或者是判断实际结果的字段选择错误
- (3)先点击发送,基于响应中的body数据做初步预判
- (4)检查请求相关参数(请求方式、请求头、请求体)
2.3 断言包含指定的字符串内容(知道)
样例代码:
pm.test("Body matches string", function () {
pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});
案例:
1.请求IHRM项目的登录接口,请求数据({"mobile":"13800000002","password":"123456"})
2.登录接口地址URL:http://ihrm-test.itheima.net/api/sys/login
3.请设置断言自动判定服务器响应体数据中包含【操作成功】
2.4 断言等于指定的字符串(知道)
样例代码:
pm.test("Body is correct", function () {
pm.response.to.have.body("response_body_string");
});
案例:
1.请求IHRM项目的登录接口,请求数据({"mobile":"13800000002","password":"123456"})
2.登录接口地址URL:http://ihrm-test.itheima.net/api/sys/login
3.请设置断言自动判定服务器响应体数据等于【操作成功】
思考:怎么完整的匹配一个JSON返回数据呢? 说明:直接单引号包裹起来即可// 服务器响应体数据中等于【操作成功】精确查找 pm.test("服务器响应体数据中等于【操作成功】精确查找", function () { pm.response.to.have.body( '{"success":true,"code":10000,"message":"操作成 功!","data":"9ad2a988-e618-47ec-9498-1efe9535c88e"}'); });
2.5 断言响应头标签(了解)
示例代码:
pm.test("Content-Type is present", function () {
pm.response.to.have.header("Content-Type");
});
案例:
1.请求IHRM项目的登录接口,请求数据({"mobile":"13800000002","password":"123456"})
2.登录接口地址URL:http://ihrm-test.itheima.net/api/sys/login
3.请设置断言自动判定服务器响应头中包含Content-Type和Content-Length
3、断言综合练习
练习: |
1.请求IHRM项目的登录接口,请求数据({"mobile":"13800000002","password":""}) 2.登录接口地址URL:http://ihrm-test.itheima.net/api/sys/login 3.请设置断言自动判定服务器: (a)响应状态码为200 (b)响应体数据中success=false,code=20001,message=用户名或密码错误,data=null (c)响应体数据中包含【用户名或密码错误】 |
答案: |
// 3.请设置断言自动判定服务器: pm.response.to.have.status(200); }); // (b)响应体数据中success=false,code=20001,message=用户名或密码错误,data=null pm.test("Your test name", function () { var jsonData = pm.response.json(); pm.expect(jsonData.success).to.eql(false); }); pm.test("Your test name", function () { var jsonData = pm.response.json(); pm.expect(jsonData.code).to.eql(20001); }); pm.test("Your test name", function () { pm.expect(jsonData.message).to.eql("用户名或密码错误"); }); // (c)响应体数据中包含【用户名或密码错误】 pm.test("Body matches string", function () { pm.expect(pm.response.text()).to.include("用户名或密码错误"); }); // (d)响应体数据等于【false】 pm.test("Body is correct", function () { pm.response.to.have.body(false); }); // (e)响应头中包含Content-Type pm.test("Content-Type is present", function () { pm.response.to.have.header("Content-Type"); }); |
三、环境变量与全局变量
1、概念
全局变量:作用范围是针对postman下面所有测试集均生效
环境变量:
- 只对选择了对应环境的测试集生效(如:选择了测试环境的测试集IHRM0720)
- 开发环境、测试环境、生产/线上环境
- 一套环境中变量不能重复、但是可以定义多个不重复的变量
2、设置变量
全局变量 手动设置
代码设置:
环境变量(手动设置 )
3、获取变量
全局变量与环境变量
- 在请求参数中获取:{{变量名}}
- URL
请求头
请求体
通过代码来获取
pm.environment.get("variable_key");
pm.globals.get("variable_key");
// 获取环境变量的值 mobile2和password2
var mobile = pm.environment.get("mobile2");
var password = pm.environment.get("password2");
console.log("测试环境中的mobile是:" + mobile) console.log("测试环境中的password是:" + password)
四、请求前置脚本(了解)
介绍:在Pre-request Script页签类编写,在请求发送之前被执行
使用场景
- 在请求url中需要使用随机数或时间戳
- 需要对敏感数据进行加密
使用案例
// 生成随机数 // 通过全局变量保存随机数 pm.globals.set("g_random", r); |
五、Postman关联(重点)
1、 Postman基础介绍
- Postman关联:后一个接口的请求需要依赖前一个接口的响应数据,一般通过全局变量或者环境 变量来进行参数在接口之间的传递。
- 技术实现
2、 通过全局变量进行接口关联
案例1: 2.获取天气接口返回结果中的城市名称 3.请求百度搜索接口:http://www.baidu.com/s?wd={{城市名称}},城市名称即为天气接口获取并保存 到全局变量中的数据。 |