postman入门到精通
- 一、postman下载安装与更换主题
- 二、页面详解
- 三、管理用例
- 四、设置环境变量和全局变量
- 五、发送请求
- 六、接口关联
- 七、postman动态参数
- 八、postman断言
- 九、Postman+newman+jenkins实现自动生成报告并持续集成
一、postman下载安装与更换主题
1、下载与安装
下载地址:https://www.postman.com/downloads/
下载适合自己的版本
下载后图标
2、更换主题(Themes)
打开后页面:
更换主题:选择自己喜欢的明色或者暗色系
二、页面详解
1、顶部工具栏
data:image/s3,"s3://crabby-images/fa995/fa9953de4034235292276743e5bcbc9a5b454902" alt=""
-
搜索
-
同步数据(Sync)
-
【invite】邀请加入团队
-
抓取API请求
-
【Sign In】登录
-
【Runner】运行用例
2、左侧栏
data:image/s3,"s3://crabby-images/09715/09715c43c1d8e22a1596a5809ceb9c9e38e12837" alt=""
- 【New】新建
data:image/s3,"s3://crabby-images/2bd7d/2bd7dec3d4a66055bbcb95410fb66d53a788291b" alt=""
-
【import】导入
-
【Collections】集合:用来管理用例
3、中部栏
3.1 请求部分页签介绍
data:image/s3,"s3://crabby-images/37312/373120d420c7021335d445f70561171a1b5830cc" alt=""
接口来源于聚合数据,点击此处查看
- 请求方式
data:image/s3,"s3://crabby-images/97849/978496b409545be5b3b6bfe16f2803eea773d0ff" alt=""
-
接口地址
-
send: 发送请求
-
Params:get请求传参
注:Bulk Edit 批量编辑
data:image/s3,"s3://crabby-images/8cbb0/8cbb06f861fbc5ab156dabd9b6db135f832e8e70" alt=""
-
Authorization:认证鉴权
-
Headers:请求头
注:如使用post请求方式,请求头(Headers)要加入content-type参数
-
Body:post请求传参
1、none:没有参数
2、form-data:传文件和键值对
注:Content-Type与请求参数的格式之间的关联
当选择某一参数方式后,postman会自动帮我们设置对应的Content-Type,不需要自行设置,而如果是使用jmeter还是需要自行设置Content-Type。
所以,当选择form-data的参数方式后,postman会自动的帮我们设置了Content-Type:multipart/form-data
3、x-www-form-urlencoded :传键值对
当选择x-www-form-urlencoded的参数方式后,postman会自动的帮我们设置了Content-Type:application/x-www-form-urlencoded
4、raw:可以上传任意格式的文本,可以上传text、json、xml等
data:image/s3,"s3://crabby-images/fadcf/fadcf36c6a4a38f6fd9bd483ef91dbedf6c2b0e9" alt=""
当我们选择了text时,postman同样帮我们自动设置了Content-Type:text/plain,可自行查看Headers
data:image/s3,"s3://crabby-images/70068/7006877145c777df510592dabe1babad645ebf5b" alt=""
当我们选择了JSON时,postman同样帮我们自动设置了Content-Type:application/json,可自行查看Headers
当我们选择了XML时,postman同样帮我们自动设置了Content-Type:text/xml,可自行查看Headers
5、binary:只可以上传二进制数据,通常用来上传文件,一次只能上传一个文件
6、GraphQL:发送GraphQL查询
- Scripts
Pre-request :预请求脚本
Post-response:请求后置脚本/请求后的脚本处理/断言
data:image/s3,"s3://crabby-images/7151e/7151e0b00698fe4e461c64e9c8d6d21310284eaf" alt=""
- Setting:设置
- Cookies:Postman的cookie的管理器
3.2 响应部分页签介绍
data:image/s3,"s3://crabby-images/6f73d/6f73d9d0ad90a801bd498867330d16f1fdcd76f5" alt=""
Body:响应的数据(Pretty:json格式,Raw:文本格式,Preview:网页格式)
Cookies:缓存
Headers:响应头
Test Results:断言的结果
Status:200返回码
OK:返回信息
Time:响应时间 588ms(毫秒)
Size:2.7KB
三、管理用例
四、设置环境变量和全局变量
全局变量:就是在所有接口请求里面都可以访问的变量
环境变量:就是全局变量。(开发环境,测试环境,线上环境)
1、添加环境变量
例如:
开发环境:ip:略
测试环境:ip:略
生产环境:ip:http://apis.juhe.cn/fapig/football/query
data:image/s3,"s3://crabby-images/a802d/a802dcc72329327584fc7f8b675f8aa6fe12ebc3" alt=""
引用方式为:{{变量名}}
在运行时:选择相应的环境变量
2、添加全局变量
步骤同环境变量,不再赘述
五、发送请求
1、发送一个get请求
接口文档:
data:image/s3,"s3://crabby-images/48af4/48af4e6d0e5955fc092d01487bce0ac6e492e1ad" alt=""
根据接口文档,我们可以看到,请求方式为get或post,这里使用get方法,填写url并把参数填写到Params中,点击Send后成功发送请求
data:image/s3,"s3://crabby-images/52680/5268021183df9ccdf25e88ce215f1ebc86ee719e" alt=""
2、发送一个post请求
接口文档:
data:image/s3,"s3://crabby-images/f42dc/f42dc8398dc65e49a0a1fe5eef68a50201e80393" alt=""
六、接口关联
场景:下一个接口的参数是使用的上一个接口的返回值
接口示例:用的是聚合数据的接口,可自行申请
脚本输入位置
1、JSON提取器(响应body中提取)
javascript
//javascript脚本,var定义变量
// 将响应body里的内容解析为一个json对象(字典),存到变量res中
var res=pm.response.json() ;
//提取响应body中的date值存到全局变量date中
pm.globals.set("date", res.result.matchs[0].date);
执行后,可以看到全局变量中存上了变量date和它的值
获取全局变量:{{变量名}},如其它接口把date作为入参只需要:{{date}}
接口示例:
2、正则表达式提取器(响应body中提取)
javascript
var dateone = pm.response.text().match(new RegExp('"date":"(.*?)"'));
console.log(dateone[1]);
pm.globals.set("dateone", dateone[1]);
执行后,也可以看到全局变量中存上了变量dateone和它的值
3、从响应头中去提取
响应头示例:
javascript
// 获取响应头中参数Etag的值
var Etag=pm.response.headers.get("Etag")
// 在控制台输出
console.log(Etag)
控制台可以看到,成功获取Etag的值
4、从响应Cookie中去提取
响应Cookie示例
javascript
//响应Cookie中提取
var aliyungf_tc=pm.cookies.get("aliyungf_tc")
// 在控制台输出
console.log(aliyungf_tc)
控制台可以看到,成功获取aliyungf_tc的值
七、postman动态参数
接口测试中常常会出现接口的参数不能写死,必须使用随机数来实现。
1、内置动态参数
javascript
{{$timestamp}} 时间戳
{{$randomInt}} 随机的0-1000的整数
{{$guid}} 随机的很长的字符串
2、自定义动态参数
javascript
//自定义的时间戳
var times = Date.now();
pm.globals.set("times",times);
//让接口请求停留3秒(3秒灌水机制),time.sleep(3)
const sleep = (milliseconds) => {
const start = Date.now();
while (Date.now() <= start + milliseconds) {}
};
sleep(3000);
八、postman断言
八种断言方式
1、断言返回码为200 用于状态断言
pm.test("Status code is 200", function () {
pm.response.to.have.status(200);
});
示例:
2、断言返回的结果中包含一个指定的字符串 用于业务断言
pm.test("Body matches string", function () {
pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});
data:image/s3,"s3://crabby-images/152f2/152f22a1d76aeb416be2152f6d4af3daba66d6b9" alt=""
data:image/s3,"s3://crabby-images/a0afa/a0afab96f97c6fed13fd82e37e7535c610fe5c74" alt=""
3、检查返回结果的json字符串的值 用于业务断言
pm.test("Your test name", function () {
var jsonData = pm.response.json();
pm.expect(jsonData.value).to.eql(100);
});
data:image/s3,"s3://crabby-images/04f4b/04f4b350a9209f6fd9565daaeeadca0ee6f85d8d" alt=""
data:image/s3,"s3://crabby-images/32ddb/32ddb1a00ff2a1700877eff45f4b9f922605eefc" alt=""
4、断言返回的结果等于一个字符串 用于业务断言
pm.test("Body is correct", function () {
pm.response.to.have.body("response_body_string");
});
5、断言响应头中包含有指定的响应头
pm.test("Content-Type is present", function () {
pm.response.to.have.header("Content-Type");
});
data:image/s3,"s3://crabby-images/c035b/c035b3b76aa8489b585248c8a5fe966a98c0c4d0" alt=""
data:image/s3,"s3://crabby-images/ef67b/ef67b4e2c5fffa3f0ff85647fa7f9ddd9862ea7f" alt=""
6、断言请求接口的时间小于200ms 用于性能断言
pm.test("Response time is less than 200ms", function () {
pm.expect(pm.response.responseTime).to.be.below(200);
});
data:image/s3,"s3://crabby-images/7a4fe/7a4fe95ff613b0abb95b8cd1ca8c8e23f6fb50f0" alt=""
7、断言一个post请求的返回的状态码是否在指定的范围中
pm.test("Successful POST request", function () {
pm.expect(pm.response.code).to.be.oneOf([201, 202]);
});
data:image/s3,"s3://crabby-images/a6a49/a6a492d2dccdebad482331b4fe9fe8271b856d19" alt=""
8、断言返回的状态码信息中包含指定的字符串
pm.test("Status code name has string", function () {
pm.response.to.have.status("Created");
});
data:image/s3,"s3://crabby-images/47c10/47c10e67400fbef2b295f69bff666a032560538d" alt=""
每个接口写2个断言,一个状态断言一个业务断言
特别注意:
1.postman内置的动态参数无法做断言。所以必须使用自定义的动态参数。
2.在tests里面不能使用{{}}的方法取全局变量,必须使用以下方式:
pm.globals.get("times1")
globals['times1']
globals.times1
精确断言:
先写预置脚本,保存全局变量
参数中使用全局变量
断言中使用全局变量
全局断言 :状态断言放到全局断言中,用例里只写业务断言即可
九、Postman+newman+jenkins实现自动生成报告并持续集成
未完待续。。。