欢迎来到飞鸟慕鱼博客,开始您的技术之旅!
当前位置: 首页知识笔记正文

postman用法,postman怎么用

终极管理员 知识笔记 131阅读

Postman的使用 Postman断言Postman常用断言1、断言响应状态码2、断言包含某个字符串3、断言JSON数据4、Postman断言工作原理 Postman关联Postman自动关联创建环境 3、Postman参数化CSV文件JSON文件1、用例集的导入导出2、环境导出

Postman断言

让Postman工具代替人自动判断预期结果与实际结果是否一致

Postman常用断言 1、断言响应状态码
// 断言响应状态码未200pm.test(Status code is 200, function () {    pm.response.to.have.status(200);});

pm.test(“Status code is 200”, function () { … });: 这一行是一个测试用例的开始。在 Postman 中你可以使用 pm.test 函数来创建测试用例该函数接受两个参数测试用例的描述作为字符串和一个包含测试逻辑的函数。在这里描述是Status code is 200它表明这个测试用例的目的是验证响应的状态码是否为 200。

pm.response.to.have.status(200);: 这一行是测试逻辑的一部分。pm.response 是一个 Postman 全局变量代表了当前请求的响应。pm.response.to.have.status(200) 的意思是要检查当前响应的状态码是否等于 200。如果状态码为 200测试将通过否则测试将失败。

2、断言包含某个字符串
pm.test(Body matches string, function () {    pm.expect(pm.response.text()).to.include(string_you_want_to_search);});

pm.test(“Body matches string”, function () { … });: 这一行开始了一个测试用例。在 Postman 中你可以使用 pm.test 函数来创建测试用例它接受两个参数测试用例的描述作为字符串和一个包含测试逻辑的函数。在这里测试用例的描述是Body matches string表明这个测试用例的目的是验证响应正文中是否包含特定的字符串。

pm.expect(pm.response.text()).to.include(“string_you_want_to_search”);: 这一行是测试逻辑的一部分。它使用了 Postman 的测试断言函数pm.expect 来验证响应正文中是否包含指定的字符串。具体步骤如下

pm.response.text(): 这是一个 Postman 全局函数用于获取当前请求的响应正文Body内容。pm.response 表示当前请求的响应而 .text() 获取响应的文本内容。
.to.include(“string_you_want_to_search”): 这部分代码是一个断言它要求响应正文中包含特定的字符串这个特定字符串应该替换成你要搜索的实际字符串。如果响应正文中包含了这个字符串测试将通过否则测试将失败。

3、断言JSON数据
pm.test(断言 success 的值为true, function () {    var jsonData  pm.response.json(); //响应体数据    pm.expect(jsonData.success).to.eql(true);});pm.test(断言 code 的值为10000, function () {    var jsonData  pm.response.json(); //响应体数据    pm.expect(jsonData.code).to.eql(10000);});pm.test(断言 message 的值为操作成功, function () {    var jsonData  pm.response.json(); //响应体数据    pm.expect(jsonData.message).to.eql(操作成功);});

上述代码是一个在 Postman 中使用的测试脚本它用于验证 HTTP 请求的响应数据。以下是代码的关键要点

pm.test(“Your test name”, function () { … });: 这行开始了一个测试用例其中描述了测试的目的。

var jsonData pm.response.json();: 代码解析响应数据为 JSON 格式并将其存储在名为 jsonData 的变量中以便后续访问和验证。

pm.expect(jsonData.value).to.eql(100);: 这部分代码使用断言函数验证 JSON 数据中的 value 字段是否等于 100。如果验证通过测试成功否则测试失败。

4、Postman断言工作原理

Postman断言的工作原理简述如下

1、发送请求 在Postman中创建API请求发送请求至目标API服务器。
2、接收响应 Postman接收来自API服务器的响应包括响应状态码、响应头和响应正文。
3、定义断言 在Postman中你可以定义断言这是测试脚本中的规则用于验证响应数据的各个方面。断言可以包括验证响应状态码、响应时间、响应头、响应正文等。
4、执行测试脚本 编写测试脚本其中包含一个或多个断言。这些测试脚本使用Postman的JavaScript库执行断言检查响应是否满足断言的条件。
5、分析结果 测试脚本执行后Postman分析每个断言的结果。如果断言条件成立测试继续执行。如果断言失败测试被标记为失败。
6、报告测试结果 Postman会生成测试报告指出哪些测试通过哪些测试失败并提供有关失败的详细信息。这有助于快速发现API中的问题。

Postman关联

当接口与接口之间由依赖关系。

Postman自动关联

假定接口B产生的数据被加快A依赖。
核心代码

var jsonData  pm.response.json();//2、设置全局变量pm.global.set(全局变量名,全局变量值)//3、设置环境变量pm.environment.set(环境变量名,环境变量值)//4、在Postman中提取全局、环境变量
创建环境

全局变量是在整个Postman应用中可用的不受环境的限制可以在不同环境和请求之间共享。它们通常用于存储全局设置、配置信息、共享的数据和跨环境的数据。

环境变量是在特定环境中定义的每个环境可以有自己的一组环境变量。它们在该环境内可见可用于请求、脚本和测试用例但不跨越环境边界共享。环境变量通常用于存储与特定环境相关的数据如不同服务器的URL、API密钥或令牌以及在不同环境中需要自定义的数据。

var jsonData  pm.response.json();// 从 JSON 数据中提取城市信息var city  jsonData.weatherinfo.city;// 将提取的城市信息存储为全局变量以便在其他请求中使用pm.globals.set(global_city, city);



员工查询
3、Postman参数化

仅测试数据不一样提高复用率
同一个接口不同测试点时
数据文件格式
1、CSVPostman读取CSV不能测试bool类型、不能存储复杂类型、不能实现参数测试。
应用场景数据量大数据格式简单。
2、 JSON
应用场景数据量较少数据组织格式复杂。需要进行参数测试

CSV文件

GET JSON文件 1、用例集的导入导出 2、环境导出

newman run
前提为了运行newman你要确保系统中安装的Node.js版本是大于v6的。

命令常用选项

1
newman [optiions]
-h显示命令行帮助包括选项列表和简单的使用案例。

-v显示当前newman的版本。

1
newman run json文件 [options]
-e source用来指定环境变量文件的路径。

-g source用来指定全局变量文件的路径。

-r reporter-name用来指定产生的数据结果的模型如jsonhtml等。
–reporter-html-export指定html报告写出的路径。
1
newman run test.json -e testing.postman_environment.json --reporter-html-export c:\newmanoutput\test_result.json
注在使用–reporter-html-export进行导出测试结果前首先需要使用npm install -g newman-reporter-html安装reporter-html-export否则测试结果无法自动生成到指定的目录中。

当你使用 newman run 命令时你可以指定一些参数以自定义其行为。以下是一些常用参数的中文说明

集合文件: 这是你要运行的 Postman 集合文件。

arduino
Copy code
newman run my_collection.json
环境文件: 你可以指定一个环境文件来在运行时使用。环境允许你设置在请求中使用的变量。

arduino
Copy code
newman run my_collection.json --environment my_environment.json
全局变量文件: 类似于环境变量但这些变量是全局的不特定于某个环境。

arduino
Copy code
newman run my_collection.json --globals my_globals.json
数据文件: 如果你正在使用数据文件来驱动你的请求可以使用 --data 标志指定数据文件。

arduino
Copy code
newman run my_collection.json --data my_data.csv
迭代次数: 若要指定运行集合的迭代次数可以使用 --iteration 标志。

arduino
Copy code
newman run my_collection.json --iteration 3
报告生成器: 你可以指定不同类型的报告生成器比如 HTML 或 JSON。例如要生成一个 HTML 报告:

css
Copy code
newman run my_collection.json --reporters html
报告输出: 使用 --reporter-html-export 选项来指定 HTML 报告的输出文件。

css
Copy code
newman run my_collection.json --reporters html --reporter-html-export report.html
变量: 你可以在运行时使用 -e 标志定义变量。

arduino
Copy code
newman run my_collection.json -e “变量名变量值”

标签:
声明:无特别说明,转载请标明本文来源!