本文已被51测试网收录:https://mp.weixin.qq.com/s/j1OZOiqmYQ5Yc2hFZrTP8g
目录
一、<a href="#1">postman 基础知识 </a>
二、<a href="#2">postman 变量与集合</a>
三、<a href="#3">postman 脚本应用(sandbox)</a>
四、<a href="#4">postman 接口自动化实现</a>
五、<a href="#5">postman 与第三方框架结合</a>
六、<a href="#6">实战演练(合同系统)</a>
<a name ="1" id="1">
一、postman 基础知识
1. postman 版本选择
postman分为chrome插件版和native版本,插件版的有很多功能都受限制:
比如native必须要安装扩展才可以操作cookie,headers设置受限制,
没有native版本的Postman console,非常不方便调试
2.为什么选择postman作为自动化框架
优点: 门槛低,上手快,界面操作简洁方便
优点: 使用js语言编写脚本,语法简单
优点: 自带各种代码模块,按需使用即可
优点: 自动化框架有命令行版本:newman,方便放在服务器上运行,做持续集成
优点: 支持抓包,保存历史记录,多终端,多用户同步测试用例
优点: 支持读取数据文件,json,csv
优点: 如果项目有Swagger生成API文档,JSON文件可以直接导入Postman来生成用例
不支持:通过url搜索用例,通过命令行传参修改环境变量,不能指定执行失败的测试用例
不理想:不能操作文件相关的操作,不能读写数据库,不能使用非HTTP协议
不理想:不方便调试自动化代码。
3. 账号和数据同步
用户免费注册账号后可以获得以下权限:
①同步和备份历史、集合、环境、与指头
②轻松处理来自不同机器的postman实例
![](https://img.haomeiwen.com/i5720189/c56e310c87279a41.png)
4. 发送请求
强调点:需要发送上传文件的请求,在body中选择选择form-data ,选择File选项后即可选择文件
![](https://img.haomeiwen.com/i5720189/613b411fede81a07.png)
强调点:设置请求头和管理请求头
![](https://img.haomeiwen.com/i5720189/dbec2f2f046de99d.png)
5. 代理抓包
由于postman不是类似fiddle这种专门用于抓包的软件,所以需要手动打开代理设置
①点击右上角的拦截图标,打开【Capture requests】,设置Port和Target
![](https://img.haomeiwen.com/i5720189/6e97ba9a538f9f78.png)
②打开浏览器的代理设置,设置相同端口
![](https://img.haomeiwen.com/i5720189/8add7f4089847a20.png)
手机端设置方法:https://learning.getpostman.com/docs/postman/sending_api_requests/capturing_http_requests
6. postman 控制台
打开左下角打开【postman console】控制台,方便查看接口调试的打印信息
![](https://img.haomeiwen.com/i5720189/03eb3493f33b4212.png)
<a name ="2" id="2">
二、postman 变量与集合
1. 变量
为什么要使用变量,如果某个参数值只需要在某个独立接口的使用一次,那么我们可以不使用变量,但是如果变量需要在多个位置重复使用,或者发生接口传递(即前一个接口的返回值用于下一个接口的请求参数),那么借助变量,postman就可以实现业务逻辑与测试数据分离,帮助我们建立健壮的测试用例。
2. 变量作用域:
全局变量(Global):主要用于需要在多个位置重复使用的几乎不改变的数据
环境变量(environment):主要用于接口传递的参数
局部变量(local):集合/文件/接口中 某个js脚本中的变量
数据变量(data):主要用于并发测试(json/csv文件)
同变量名的情况下,优先级范围:局部变量> 环境变量> 全局变量
3 . 设置变量:
① 在postman的ui上进行定义
![](https://img.haomeiwen.com/i5720189/fa27fe924d0bc2be.png)
![](https://img.haomeiwen.com/i5720189/6a151ce5d63e6321.png)
② 使用脚本定义 pm.environment.set("new_name", "zhougang");
![](https://img.haomeiwen.com/i5720189/8f71dc3f744e1426.png)
4. 使用变量:
① Builder中的使用:{{varname}}
![](https://img.haomeiwen.com/i5720189/62f26e5e4a204784.png)
② js 脚本中的使用:pm.environment.get("variable_key");
5. 集合
为什么要使用集合?
①组织业务逻辑:分类和存储接口
②方便一键运行:在runner中选择要运行的collection或者里面的文件夹进行运行
③方便导入导出:导出和导入json文件,如使用newman在命令行执行(集合和变量的导出是分开的)
③方便分享:分享至自己团队的共享目录下
![](https://img.haomeiwen.com/i5720189/0f0b9569099ca1ea.png)
![](https://img.haomeiwen.com/i5720189/c45ac23c871f11d3.png)
<a name ="3" id="3">
三、postman 脚本应用(sandbox)
postman支持js语言,它允许用户向请求和集合添加动态行为。通过使用js脚本,可以构建包含动态参数的请求,在请求之间传递数据。用户可以在下面两个事件流中添加js代码。
①在请求发送前,在“pre-request script”选项卡下输入脚本,主要用于设置测试需要的测试参数
②在请求发送后,在“test”选项卡下输入脚本,主要用于做断言
![](https://img.haomeiwen.com/i5720189/c682314f71fd6ae3.png)
![](https://img.haomeiwen.com/i5720189/0e686685f3e6b8c7.png)
③右边会有自带各种代码模块,按需使用即可,常用示例如下:
/** test示例 */
var jsonData = pm.response.json();
pm.test("操作是否成功", function () {
pm.expect(jsonData.code).to.eql(1);
});
pm.test("接口返回时间是否超过2s", function () {
pm.expect(pm.response.responseTime).to.be.below(2000);
});
tests["名称是否正确"] = jsonData.data.name === pm.environment.get("customer_contract_name");
tests["管理人是否正确"] = jsonData.data.manage_user === pm.environment.get("admin_user_name");
tests["组织是否正确"] = jsonData.data.manage_org_name === pm.environment.get("org_name");
pm.environment.set("variable_key", "variable_value");
//使用变量{{variable_key}}
如果这里没有你需要的,可以查看帮助文档
https://learning.getpostman.com/docs/postman/scripts/postman_sandbox_api_reference/
![](https://img.haomeiwen.com/i5720189/480863c294f6fcf4.png)
![](https://img.haomeiwen.com/i5720189/dc15041f960e9a14.png)
用户可以将与请求和测试脚本添加到一个集合,一个文件,一个请求中
优先级:请求>文件>集合
<a name ="4" id="4">
四、postman 接口自动化实现
1. 使用postman自带的 runner工具
①在runner中选择要运行的collection或者里面的文件夹进行运行
②enviroment:选择用例跑的环境变量集合
③iterations:接口迭代次数(接口自动化 默认使用1就行,1以上一般拿来做并发测试)
④delay:每个接口发起请求的的间隔时间(建议200ms)
⑤data:数据文件,可以是json格式的,也可以是csv格式的(一般用于并发测试)
⑤keep variable values: 重点!!!必须要勾上,环境变量将会更新
⑥start run:运行结果集,并查看结果页,可导出
![](https://img.haomeiwen.com/i5720189/be1776a2b65d93a7.png)
执行顺序设定(此代码只在runner和Newman中生效):
postman.setNextRequest('接口名称');// 设定下一请求执行路径
运行结果页:
![](https://img.haomeiwen.com/i5720189/2ddd6dc75f3cc143.png)
2. 使用postman插件:Newman
官方说明文档:https://www.npmjs.com/package/newman(https://www.npmjs.com/package/newman
①首先需要安装node.js环境(同时安装了npm)
下载地址:http://nodejs.cn/download/
![](https://img.haomeiwen.com/i5720189/dffbcab502afde1c.png)
②使用命令行安装 Newman
npm install -g newman
安装导出html报告的包: npm install -g newman-reporter-html
③Newman运行命令脚本,一般只需要指定运行集合、运行环境、间隔时间,数据文件,指定输出报告的模板和位置
原始脚本: newman run xxx.json
添加下述定制化参数:
指定运行环境变量集合: --environment xxx.environment.json
指定输出环境变量集合: --export-environment xxx.environment.json
指定输出报告形式:-r cli,html
指定输出报告文件: --reporter-html-export xxx.htm
指定接口间隔时间: --delay-request 100
进入脚本所在文件目录,运行脚本(保存成脚本文件,直接运行即可)
newman run cms_init.postman_collection.json --environment cms-test.environment.json --export-environment cms-test.environment.json -r cli,html --reporter-html-export ./reports/cms_init_html_output.htm --delay-request 120
运行结果(命令行):
![](https://img.haomeiwen.com/i5720189/64cc926067523a01.png)
运行结果(html格式):
![](https://img.haomeiwen.com/i5720189/3131bd65206ae962.png)
<a name ="5" id="5">
六、postman 与第三方框架结合(维护)
1. 与Git结合 (版本控制)
①将集合的脚本文件导出到目录下
②然后使用相关git命令推送到远程仓库即可
备注:多人协作可同时使用postman的分支管理,更好的维护接口代码
![](https://img.haomeiwen.com/i5720189/789530ce7052e218.png)
2. 与jenkins结合 (持续集成)
当我们将代码推送到git上后,可以使用jenkins直接构建任务即可,省去了脚本打包放到对应服务器再启用对应环境脚本的麻烦。
参考链接:https://www.jianshu.com/p/18863c609019
参考链接:https://blog.csdn.net/qq_16510189/article/details/79074809
①下载jenkins的war包,使用java -jar jenkins.war --httpPort=8080启动, 按照配置jenkins完成
②在Jenkins中安装对应的插件,Git、NodeJS 插件
③新建job,配置相关内容
git配置
![](https://img.haomeiwen.com/i5720189/9dd835149a4538c2.png)
定时器配置
![](https://img.haomeiwen.com/i5720189/d26ef02ceb8d84d3.png)
构建环境配置
![](https://img.haomeiwen.com/i5720189/daed703dcbef51d8.png)
构建脚本
![](https://img.haomeiwen.com/i5720189/5f35a8f8f77e5019.png)
③选择构建,查看控制台
![](https://img.haomeiwen.com/i5720189/6a375602365ab3b8.png)
3. 与钉钉机器人结合
![](https://img.haomeiwen.com/i5720189/18e6776be03c4ec0.png)
![](https://img.haomeiwen.com/i5720189/d756c3d031561ea4.png)
![](https://img.haomeiwen.com/i5720189/ce119914c9be149f.png)
![](https://img.haomeiwen.com/i5720189/449345c26781654c.png)
![](https://img.haomeiwen.com/i5720189/c8b24a70b2c54837.png)
<a name ="6" id="6">
六、实战演练
以合同管理系统为例(演示)
网友评论