Postman接口&压力测试

Postman接口与压力测试实例

 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件。它提供功能强大的 Web API & HTTP 请求调试。

1、环境变量和全局变量设置

环境变量可以使用在以下地方:

  • URL
  • URL params
  • Header values
  • form-data/url-encoded values
  • Raw body content
  • Helper fields

先设置好变量名及数值后,接下来就可以调用环境变量名,例如:

key对应的values,填写{ {address}},注意需要用双花括号引用。

全局变量设置方法跟环境变量一样,点击"Globals" 后就会出现添加环境变量类似的页面,进行变量和值的设置。

全局变量设置应用于整个(Collection)中的请求。

GET 和POST 的区别:

  • GET 使用URL 或Cookie 传参,而POST将数据放在Body 中。
  • GET的URL 在长度上会有限制,而POST没有。
  • POST比GET相对安全,因为在地址栏不可见。
  • 一般POST请求用来获取数据,POST请求用来发送数据。

2、Get请求:

参考开发提供的接口设计文档,提供传参数据录入。

3、post请求:

如常见基本认证的登录用的较多,用户名和密码也可以通过设置的环境变量获取。Postman支持不同的认证机制如: Basic、Digest、OAuth等),支持收到响应语法高亮(HTML\JSON\XML等)。

下面举一个添加发布会接口例子开展:

选择form-data方式传参发送。

一、Body:

1. form-data
  就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。当上传的字段是文件时,会有Content-Type来说明文件类型;content-disposition,用来说明字段的一些信息;由于有boundary隔离,所以multipart/form-data既可以上传文件,也可以上传键值对,它采用了键值对的方式,所以可以上传多个文件。
2.x-www-form-urlencoded
  就是application/x-www-from-urlencoded,会将表单内的数据转换为键值对
3.raw
  可以上传任意格式的文本, 可以上传text、 json、 xml、 html等
 4.binary
   相当于Content-Type:application/octet-stream 只可以上传二进制数据,通常用来上传文件,由于没有键值,所以, 一次只能上传一个文件。

 二、Pre-requestScript 的使用

 对于环境变量和全局变量的使用,除了上面所讲的方法外,也可以用Pre-requestScript 方法。

以login接口为例,在"Pre-requestScript"中设置环境变量 "username", "password",在Body 中选取"form-data" 格式,输入所需的key-value, value即为变量{ {username}}, { {password}}。

三、Tests使用(断言)

所谓断言,主要用于测试返回的数据结果进行匹配判断,匹配成功返回PASS,失败返回FAIL。

下图方法一,直接点击右侧例子函数,会自动生成出现在左侧窗口脚本,只需修改数据即可。

方法二:直接自己写脚本,如下图所示:

复制代码

 常用tests用法如下:

1.检查response body中是否包含某个string
tests["Body matches string"] = responseBody.has("string_you_want_to_search");

注意:"Body matches string" 需唯一。

2.检测JSON中的某个值是否等于预期的值
var data = JSON.parse(responseBody);
tests["Your test name"] = data.value === 100;

JSON.parse()方法,把json字符串转化为对象。parse()会进行json格式的检查是一个安全的函数。 

如:检查json中某个数组元素的个数(这里检测programs的长度)
var data = JSON.parse(responseBody);
tests["program's lenght"] = data.programs.length === 5;

3.检查response body是否与某个string相等
4.转换XML body为JSON对象
var jsonObject = xml2Json(responseBody);

tests["Body is correct"] = responseBody === "response_body_string";

5.测试response Headers中的某个元素是否存在(如:Content-Type)
tests["Content-Type is present"] = postman.getResponseHeader("Content-Type"); 
//getResponseHeader()方法会返回header的值,如果该值存在

或者: 

tests["Content-Type is present"] = responseHeaders.hasOwnProperty("Content-Type");
上面的方法,不区分大小写。下面的方法,要区分大小写。

6.验证Status code的值

tests["Status code is 200"] = responseCode.code === 200;

7.验证Response time是否小于某个值
tests["Response time is less than 200ms"] = responseTime < 200;

8.name是否包含某个值
tests["Status code name has string"] = responseCode.name.has("Created");

9.POST 请求的状态响应码是否是某个值
tests["Successful POST request"] = responseCode.code === 201 || responseCode.code === 202;

10.很小的JSON数据验证器

var schema = {

"items": {

"type": "boolean"

}

};

var data1 = [true, false];

var data2 = [true, 123];

console.log(tv4.error);

tests["Valid Data1"] = tv4.validate(data1, schema);

tests["Valid Data2"] = tv4.validate(data2, schema);

复制代码

4、传参场景(比如测试登录接口需要不的账号,密码)

在接口测试过程中,有的时候需要构建多组同类型数据测试(正常数据,异常数据),当然没必要写多条测试用例,可使用CSV格式传参
举个例子,在测试用户登录接口的时候,需要用户输入相应的手机号和密码
那么,需要构建的测试数据有:手机号&密码正确,手机号正确&密码错误,手机号错误&密码正确,手机号为空&密码不为空,手机号正确&密码为空,手机&密码均为空。
如post请求:/api/login?phone={ {phone}}&password={ {password}}
a、可本地创建一个txt文档,并编辑数据,数据的头部必须参数名称保持一致,也就是phone和password,数据如下:

b、然后选择批量运行,即collection runner,操作如下:

数据预览图,如下:

c、最后点击运行就OK,可以在collection runner->Run Results查看运行结果。

5、压力测试

压力测试只能以文件夹的方式执行多个接口,不能单独执行。

设置并发10次。执行后结果:

 以上是postman基本操作总结。具体详细可参考官方样例:Postman test script examples | Postman Docs

 

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取   

### 如何使用Postman进行API接口压力测试 #### 准备阶段 为了有效地执行API压力测试,在开始之前需确保已安装并配置好Postman应用程序。此外,建议先熟悉目标API的功能及其正常操作条件[^2]。 #### 创建试集合 在Postman中创建一个新的Collection用于保存所有的请求项。对于每一个要试的API端点,添加相应的Request,并设置必要的参数、头信息以及认证方式等。此过程有助于组织化管理和重复利用试案例[^1]。 #### 配置环境变量 定义一组适用于整个collection或特定requests的环境变量。这些变量可用于存储动态数据(如URL路径、查询字符串),使得脚本更加灵活通用,也便于后续调整和维护。 #### 编写预处理与后处理脚本 利用Pre-request Scripts和Tests标签页编写JavaScript代码片段,前者可在每次发送request前执行初始化逻辑;后者则用来解析response body, 提取所需的数据作为断言依据或是传递给下一个依赖的任务。 #### 设置并发数及迭代次数 进入Runner界面指定想要模拟的同时在线用户的数量&mdash;&mdash;即并发连接数目,还有每轮次内应发出多少个连续请求&mdash;&mdash;也就是循环计数器。这两个参数直接影响着最终得到的结果集范围和精度。 #### 执行并监控进度 启动runner之后,可以通过实时更新的状态栏观察当前正在进行中的各项指标变化情况,比如平均响应时间、成功率百分比等等。一旦完成全部预定的操作序列,则会自动生成一份详尽报告供进一步审查分析之用。 ```javascript // 示例:简单的前置脚本获取随机ID pm.variables.set(&quot;randomId&quot;, Math.floor(Math.random() * 90000) + 10000); // 示例:基本的成功状态码验证 pm.test(&quot;Status code is 200 OK&quot;, function () { pm.response.to.have.status(200); }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值