PostMan Test 的脚本scripts编写方法

本文详细介绍了如何在Postman中设置、获取和清除环境变量及全局变量,包括处理字符串化对象,以及如何进行响应测试,如检查响应主体、状态码、时间等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 设置环境变量
  2 pm.environment.set("variable_key", "variable_value");
  3  
  4 将一个嵌套的对象设置为一个环境变量
  5 var array = [1, 2, 3, 4];
  6 pm.environment.set("array", JSON.stringify(array, null, 2));
  7  
  8 var obj = { a: [1, 2, 3, 4], b: { c: 'val' } };
  9 pm.environment.set("obj", JSON.stringify(obj))
 10  
 11 获得一个环境变量
 12 pm.environment.get("variable_key");
 13  
 14 获得一个环境变量(其值是一个字符串化的对象)
 15 // These statements should be wrapped in a try-catch block if the data is coming from an unknown source.
 16 var array = JSON.parse(pm.environment.get("array"));
 17 var obj = JSON.parse(pm.environment.get("obj"));
 18  
 19 清除一个环境变量
 20 pm.environment.unset("variable_key");
 21  
 22 设置一个全局变量
 23 pm.globals.set("variable_key", "variable_value");
 24  
 25 获取一个全局变量
 26 pm.globals.get("variable_key");
 27  
 28 清除一个全局变量
 29 pm.globals.unset("variable_key");
 30  
 31 获取一个变量
 32 该函数在全局变量和活动环境中搜索变量
 33 pm.variables.get("variable_key");
 34  
 35 检查响应主体是否包含字符串
 36 pm.test("Body matches string", function () {
 37     pm.expect(pm.response.text()).to.include("string_you_want_to_search");
 38 });
 39  
 40 检查响应体是否等于字符串
 41 pm.test("Body is correct", function () {
 42     pm.response.to.have.body("response_body_string");
 43 });
 44  
 45 检查JSON值
 46 pm.test("Your test name", function () {
 47     var jsonData = pm.response.json();
 48     pm.expect(jsonData.value).to.eql(100);
 49 });
 50  
 51 Content-Type 存在
 52 pm.test("Content-Type is present", function () {
 53     pm.response.to.have.header("Content-Type");
 54 });
 55  
 56  
 57 返回时间少于200ms
 58 pm.test("Response time is less than 200ms", function () {
 59     pm.expect(pm.response.responseTime).to.be.below(200);
 60 });
 61  
 62 状态码是200
 63 pm.test("Status code is 200", function () {
 64     pm.response.to.have.status(200);
 65 });
 66  
 67 代码名包含一个字符串
 68 pm.test("Status code name has string", function () {
 69     pm.response.to.have.status("Created");
 70 });
 71  
 72 成功的POST请求状态码
 73 pm.test("Successful POST request", function () {
 74     pm.expect(pm.response.code).to.be.oneOf([201,202]);
 75 });
 76  
 77 为JSON数据使用TinyValidator
 78 var schema = {
 79  "items": {
 80  "type": "boolean"
 81  }
 82 };
 83 var data1 = [true, false];
 84 var data2 = [true, 123];
 85  
 86 pm.test('Schema is valid', function() {
 87   pm.expect(tv4.validate(data1, schema)).to.be.true;
 88   pm.expect(tv4.validate(data2, schema)).to.be.true;
 89 });
 90  
 91 解码base64编码数据
 92 var intermediate,
 93     base64Content, // assume this has a base64 encoded value
 94     rawContent = base64Content.slice('data:application/octet-stream;base64,'.length);
 95  
 96 intermediate = CryptoJS.enc.Base64.parse(base64content); // CryptoJS is an inbuilt object, documented here: https://www.npmjs.com/package/crypto-js
 97 pm.test('Contents are valid', function() {
 98   pm.expect(CryptoJS.enc.Utf8.stringify(intermediate)).to.be.true; // a check for non-emptiness
 99 });
100  
101 发送异步请求
102 此函数可作为预请求和测试脚本使用
103 pm.sendRequest("https://postman-echo.com/get", function (err, response) {
104     console.log(response.json());
105 });
106  
107 将XML主体转换为JSON对象
### 如何在 Postman 中导出脚本的具体操作步骤 #### 1. 创建 Collection 或 Folder 为了更好地管理和组织 API 请求,建议先创建一个 **Collection** 来存放所有的请求。如果需要进一步细分,可以在 Collection 下创建 **Folder**[^4]。 ```javascript // 示例:在一个 Collection 下创建 Folder 并添加请求 pm.collectionVariables.set("exampleKey", "exampleValue"); ``` #### 2. 编写 Pre-request Script 和 Test Scripts 在每个请求中,可以编写 **Pre-request Script** 和 **Test Scripts** 来实现自动化功能。这些脚本使用 JavaScript 编写。 - **Pre-request Script**: 在发送请求前执行的操作。 - **Test Scripts**: 在收到响应后验证结果。 #### 3. 准备导出数据 确保所有未保存的更改都已经保存,并检查集合的内容是否完整。这是为了避免导出时遗漏重要信息[^1]。 #### 4. 导出 Collection 要导出包含脚本的 Collection,请按以下步骤操作: 1. 打开 Postman 应用程序。 2. 在左侧导航栏找到你要导出的 **Collection**。 3. 单击该 Collection 右侧的省略号按钮(...),然后选择 **Export**。 4. 在弹出窗口中,可以选择导出整个 Collection 或仅导出部分内容。 5. 点击 **Export** 按钮下载 JSON 文件。 此过程会将 Collection 和其关联的脚本一并导出为 `.json` 文件[^1]。 #### 5. 使用 Newman 运行导出的脚本 Newman 是 Postman 的命令行工具,可用于运行导出的 Collection 脚本。以下是具体步骤: 1. 安装 Newman: ```bash npm install -g newman ``` 2. 使用以下命令运行导出的 Collection: ```bash newman run <your-collection-file>.json -e <environment-file>.json ``` 如果没有环境文件,可以直接运行 Collection: ```bash newman run <your-collection-file>.json ``` 通过这种方式,可以离线运行 Postman 脚本[^3]。 #### 6. 将 Postman 脚本转换为其他格式 如果需要将 Postman 脚本转换为其他测试框架(如 k6)的脚本,可以使用第三方工具 `postman-to-k6`。以下是 Docker 方式的操作方法: 1. 拉取镜像: ```bash docker pull loadimpact/postman-to-k6 ``` 2. 运行容器并将本地文件挂载到容器中: ```bash docker run -it -v "/path/to/your/postman/collection:/postman/" loadimpact/postman-to-k6 /postman/your_collection.json -o /postman/your_k6_script.js ``` 这样就可以生成适用于 k6 测试的脚本文件[^2]。 --- ### 注意事项 - 确保导出的文件格式正确,Postman 支持的主要格式包括 JSON 和 Export Format v2.1[^1]。 - 如果计划使用 Postman API 自动化导入和导出流程,需确保拥有足够的权限访问相关端点。 - 推荐将导出的 Collection 文件纳入版本控制系统(如 Git),便于团队协作和历史追踪[^1]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值