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、测试结果展示

相关推荐
大师影视解说1 小时前
基于Web端的AI电影解说自动化生产工具实测:4步完成从文案到成片的全流程
运维·人工智能·自动化·影视解说·电影解说工具·网页版电影解说·ai电影解说
科士威传动2 小时前
微型导轨从精密制造到智能集成的跨越
大数据·运维·科技·机器人·自动化·制造
北京耐用通信4 小时前
从隔离到互联:工业现场中耐达讯自动化CC-Link IE转Modbus RTU实战指南
人工智能·科技·物联网·自动化·信息与通信
cyclejune5 小时前
5 个本地 AI Agent 自动化工作流实战
运维·人工智能·自动化·clawdbot·openclaw
lakernote5 小时前
EasyPostman 重大更新:正式支持插件模式,当前已上线 5 个官方插件
java·测试工具·开源·postman
oi..8 小时前
Flag入门—Flag在返回包中
网络·笔记·测试工具·安全·网络安全
Vic101018 小时前
Wireshark 解密 HTTPS 流量
测试工具·https·wireshark
OidEncoder9 小时前
绝对值编码器在AGV舵轮上的应用与调试(含硬件对接+故障排查+代码实例)
人工智能·物联网·自动化·智慧城市·信息与通信
wzl202612139 小时前
基于规则引擎的新客欢迎语自动化:从0到1搭建智能破冰系统
大数据·运维·自动化
信也科技布道师9 小时前
打破“知识孤岛”:微服务架构下的自动化业务图谱构建
微服务·架构·自动化