postman 自动化测试

postman 自动化测试

0、写在前面

在有些时候看官方文档 比网上搜索效率要高,

比如网上搜一通还是不知道用法或者没有搜索到你想要的用法的时候。

postman官方文档 : https://learning.postman.com/docs/introduction/overview/

1、变量引用

1.1、如何在请求体中引用变量

打开官方文档 在右上角搜索框搜索variables

点击搜索结果中的 Using variables

在请求体中这样引用变量 { "customer_id" : "{{cust_id}}" }

2、变量设置

2.1、测试需求场景描述:

一款软件提供了1 2 3 三个接口供调用,为了验证接口功能,需要对三个接口测试进行软件功能验证。

而这三个接口需要顺序调用,原因是后面的接口依赖前面接口的响应结果 作为输入。

接口1需要token作为请求头,token为时间戳,响应体是一个url, 这个url作为接口2的请求体。

接口2响应体是一个字符串, 这个字符串作为接口3的请求体。

接口3需要获取接口2的字符串响应体+token 拼接成一个url,这个url便是这个软件接口调用的最后结果,通过这个url即可以刚问到特定的资源。

接口1、2、3都需要token作为请求头。

分析以上测试需求,

1、token是3个接口都需要的请求头,因此需要在每个接口执行前要自动获取到时间戳作为请求头,不然每个接口请求前都需要手工获取时间戳作为请求体

2、接口2执行前需要自动获取到接口1的响应体url作为请求体,因此需要在接口1执行完毕后,把响应体url设置为全局变量,这样接口2的请求体里卖弄就可以直接引用这个变量,实现自动化。

接口3同理,需要接口3执行完毕后,把响应体字符串,设置为全局变量,这样在接口3执行前这个字符串全部变量就已经存在了,可直接供接口3的请求体引用。

3、接口3需要进行一次变量拼接,要求能在接口3执行完毕后,自动化拼接这个url,并且通过日志可视化输出。这样我们就可以直接复制这个拼接的url,直接粘贴到浏览器地址栏进行资源访问。

2.2、postman实战

新建1个collection 名称是test-httpApi,含有接口1、2、3

2.2.1、全局token的处理

接口1、2、3都需要token作为请求头。因此需要在每个接口执行前要自动获取到时间戳作为请求头,不然每个接口请求前都需要手工获取时间戳作为请求体

这个需求通过collection的Pre-request Script 实现。collection的Pre-request Script 会在此collection下的每个接口执行前都会执行,因此满足当前这个需求。

javascript 复制代码
var currentTimeStamp=new Date().getTime();
console.log("currentTimeStamp is :"+currentTimeStamp);
pm.globals.set("Auth-Token",currentTimeStamp);

2.2.2、接口1的处理

首先是引用collection设置的全局变量Auth-Token

第二步是接口1执行完毕后 需要把响应体中的url设置为全局变量。

这个需求通过接口1的test脚本实现,在test脚本中设置url全局变量uploadURL。

javascript 复制代码
var jsondata=JSON.parse(responseBody);
var uploadURL=jsondata.data.location.url;
console.log("uploadURL is :"+uploadURL);
pm.globals.set("uploadURL",uploadURL);

2.2.3、接口2的处理

首先是引用collection设置的全局变量Auth-Token

第二步是引用接口1执行完毕后设置的全局变量uploadURL 作为请求体。

第三步是接口2执行完毕后 需要把响应体中的字符串设置为全局变量。

这个需求通过接口2的test脚本实现,在test脚本中设置字符串全局变量string。

javascript 复制代码
var jsondata=JSON.parse(responseBody);
var string=jsondata.data;
console.log("string is :"+string);
pm.globals.set("string",string)

2.2.4、接口3的处理

首先是引用collection设置的全局变量Auth-Token

第二步是引用接口2执行完毕后设置的全局变量string 作为请求体。

第三步是 获取接口2的字符串响应体+token 拼接成一个url,这个url便是这个软件接口调用的最后结果,通过这个url即可以刚问到特定的资源。

javascript 复制代码
var jsondata=JSON.parse(responseBody);
var string=jsondata.data.string;
var string=pm.globals.get("string");
var token=pm.globals.get("Auth-Token");
var URL="https://192.168.x.x:1000/?token="+token+"&string="+string;
console.log("The final URL is :"+URL);

3、测试结果展示

相关推荐
小白学大数据4 分钟前
Python + 大模型行业资讯自动化摘要流水线完整工程实现方案
开发语言·python·自动化
Super Scraper6 分钟前
如何批量抓取 TikTok 数据而不被封锁?完整指南
爬虫·ai·自动化·抖音·tiktok·ai agent
曦尧1 小时前
GitHub - jwasham/coding-interview-university: 一份完整的计算机科学学习计划,助你成为软件工程师。· GitHub
ai·自动化
天空属于哈夫克32 小时前
打造私域闭环:CRM 如何驱动企微外部客户触达
自动化·企业微信·api
苏州邦恩精密2 小时前
GOM三维扫描在制造中的真实价值:让“修模”从经验动作变成数据动作
人工智能·科技·机器学习·3d·自动化·制造
浮云中的神马-潘帅2 小时前
魔兽世界自动化打地鼠方案
运维·自动化
志栋智能3 小时前
超自动化安全的技术选型与架构设计指南
运维·安全·自动化
ai_coder_ai3 小时前
在自动化脚本中操作excel文件
运维·自动化·excel
LT10157974443 小时前
2026年Web自动化测试工具选型指南:多浏览器兼容解决方案
前端·测试工具·自动化
Chengbei113 小时前
AISec真正拟人化全自动渗透工具!支持浏览器交互全自动化挖掘,SQL注入、XSS、越权等。
sql·安全·web安全·网络安全·自动化·系统安全·xss