Postman JavaScript 参考
Postman 提供了可在请求脚本中使用的 JavaScript API。该pm
对象提供了用于测试你的请求和响应数据的功能,该postman
对象提供了额外的工作流控制。
The pm object
你将使用 执行大部分 Postman JavaScript API 功能pm.*
,它提供对请求和响应数据以及变量的访问。
在脚本中使用变量
你可以使用 API 在 Postman 的每个范围内访问和操作 变量 pm
。
你可以在请求运行时使用 动态变量生成值。
Postman support 多种变量 作用域 。该pm
对象提供了专门访问全局变量、集合变量和环境变量的方法,以及pm.variables
访问不同范围变量和设置局部变量的方法。
- 检查当前范围内是否有 Postman 变量:
pm.variables.has(variableName:String):function → Boolean
- 获取具有指定名称的 Postman 变量的值:
pm.variables.get(variableName:String):function → *
- 设置具有指定名称和值的局部变量:
pm.variables.set(variableName:String, variableValue:*):function
- 使用语法返回脚本中动态变量的解析值
{{$variableName}}
:
pm.variables.replaceIn(variableName:String):function: → *
例如:
const stringWithVars = pm.variables.replaceIn("Hi, my name is {{$randomFirstName}}");
console.log(stringWithVars);
- 返回一个包含所有变量及其值在当前范围内的对象。根据优先顺序,这将包含来自多个范围的变量。
pm.variables.toObject():function → Object
变量作用域决定了当你引用变量时 Postman 赋予它们的优先级,按照优先级递增的顺序:
- 全球的
- 收藏
- 环境
- 数据
- 当地的
具有最接近范围的变量会覆盖任何其他变量。例如,如果你score
在当前集合和活动环境中都有命名的变量,并且你调用pm.variables.get('score')
,Postman 将返回环境变量的当前值。当你使用 设置变量值时pm.variables.set
,该值是本地的,并且只会在当前请求或 collection run 时持续存在。
//collection var 'score' = 1
//environment var 'score' = 2
//first request run
console.log(pm.variables.get('score'));//outputs 2
console.log(pm.collectionVariables.get('score'));//outputs 1
console.log(pm.environment.get('score'));//outputs 2
//second request run
pm.variables.set('score', 3);//local var
console.log(pm.variables.get('score'));//outputs 3
//third request run
console.log(pm.variables.get('score'));//outputs 2
有关详细信息,请参阅 Postman Collection SDK 变量参考。
你还可以使用 pm.environment 、 pm.collectionVariables 和 pm.globals 访问在各个范围内定义的变量。
在脚本中使用环境变量
你的脚本可以使用这些pm.environment
方法来访问和操作活动(当前选择的)环境中的变量。
- 活动环境的名称:
pm.environment.name:String
- 检查环境是否有指定名称的变量:
pm.environment.has(variableName:String):function → Boolean
- 获取活动环境中指定名称的变量:
pm.environment.get(variableName:String):function → *
- 在活动环境中设置具有指定名称和值的变量:
pm.environment.set(variableName:String, variableValue:*):function
- 使用语法返回脚本中动态变量的解析值
{{$variableName}}
:
pm.environment.replaceIn(variableName:String):function → *
例如:
//environment has vars firstName and age
const stringWithVars = pm.environment.replaceIn("Hi, my name is {{firstName}} and I am {{age}}.");
console.log(stringWithVars);
- 在单个对象中的活动环境中返回所有变量及其值:
pm.environment.toObject():function → Object
- 从活动环境中删除变量,按名称指定变量:
pm.environment.unset(variableName:String):function
- 清除活动环境中的所有变量:
pm.environment.clear():function
请注意,你编辑变量的能力取决于你在工作空间中的 访问级别。
在脚本中使用集合变量
你的脚本可以使用这些pm.collectionVariables
方法来访问和操作集合中的变量。
- 检查集合中是否存在指定名称的变量:
pm.collectionVariables.has(variableName:String):function → Boolean
- 返回具有指定名称的集合变量的值:
pm.collectionVariables.get(variableName:String):function → *
- 设置具有指定名称和值的集合变量:
pm.collectionVariables.set(variableName:String, variableValue:*):function
- 使用语法返回脚本中动态变量的解析值
{{$variableName}}
:
pm.collectionVariables.replaceIn(variableName:String):function → *
例如:
//collection has vars firstName and age
const stringWithVars = pm.collectionVariables.replaceIn("Hi, my name is {{firstName}} and I am {{age}}.");
console.log(stringWithVars);
- 返回对象集合中的所有变量及其值:
pm.collectionVariables.toObject():function → Object
- 从集合中移除指定的变量:
pm.collectionVariables.unset(variableName:String):function
- 清除集合中的所有变量:
pm.collectionVariables.clear():function
在脚本中使用全局变量
你的脚本可以使用这些pm.globals
方法在工作空间内的全局范围内访问和操作变量。
- 检查哪里有指定名称的全局变量:
pm.globals.has(variableName:String):function → Boolean
- 返回具有指定名称的全局变量的值:
pm.globals.get(variableName:String):function → *
- 设置具有指定名称和值的全局变量:
pm.globals.set(variableName:String, variableValue:*):function
- 使用语法返回脚本中动态变量的解析值
{{$variableName}}
:
pm.globals.replaceIn(variableName:String):function → String
例如:
//globals include vars firstName and age
const stringWithVars = pm.globals.replaceIn("Hi, my name is {{firstName}} and I am {{age}}.");
console.log(stringWithVars);
- 返回对象中的所有全局变量及其值:
pm.globals.toObject():function → Object
- 删除指定的全局变量:
pm.globals.unset(variableName:String):function
- 清除工作空间中的所有全局变量:
pm.globals.clear():function
请注意,你编辑变量的能力取决于你在工作空间中的 访问级别。
在脚本中使用数据变量
你的脚本可以使用这些方法 在 collection run 期间 pm.iterationData
访问和操作数据文件中的变量。
- 检查当前迭代数据中是否存在指定名称的变量:
pm.iterationData.has(variableName:String):function → boolean
- 从具有指定名称的迭代数据中返回一个变量:
pm.iterationData.get(variableName:String):function → *
- 返回对象中的迭代数据变量:
pm.iterationData.toObject():function → Object
- 将 iterationData 对象转换为 JSON 格式:
pm.iterationData.toJSON():function → *
- 删除指定变量:
pm.iterationData.unset(key:String):function
使用请求和响应数据编写脚本
有多种方法可以访问 Postman 脚本中的请求和响应数据,包括 pm.request 、 pm.response 、 pm.info 和 pm.cookies 。 此外,你可以使用 pm.sendRequest 发送请求。
使用请求数据编写脚本
该pm.request
对象为运行脚本的请求提供对数据的访问。对于预请求脚本,这是即将运行的请求,对于测试脚本,这是已经运行的请求。
你可以使用pm.request
对象预请求脚本在运行之前更改请求配置的各个部分。
该pm.request
对象提供以下属性和方法:
请求网址:
当前请求的 header 列表 :
pm.request.headers:HeaderList
HTTP 请求方式:
请求正文 中的数据。这个对象是不可变的,不能从脚本中修改:
pm.request.body:RequestBody
- 为当前请求添加具有指定名称和值的 header:
pm.request.headers.add(header:Header):function
例如:
pm.request.headers.add({
key: "client-id",
value: "abcdef"
});
- 删除指定名称的请求头:
pm.request.headers.remove(headerName:String):function
- 插入指定的 header 名称和值(如果 header 不存在,否则已经存在的 header 将更新为新值):
pm.request.headers.upsert({key: headerName:String, value: headerValue:String}):function)
有关详细信息,请参阅 Postman Collection SDK 请求参考。
使用响应数据编写脚本
该对象提供对添加到Tests 的pm.response
脚本中当前请求的响应中返回的数据的访问。
该pm.response
对象提供以下属性和方法:
响应状态码:
状态文本字符串:
pm.response.status:String
- 响应 header 列表:
pm.response.headers:HeaderList
- 接收响应所花费的时间(以毫秒为单位):
pm.response.responseTime:Number
- 收到的响应大小:
pm.response.responseSize:Number
- 响应文本:
pm.response.text():Function → String
- 响应 JSON,你可以使用它深入了解收到的属性:
pm.response.json():Function → Object
有关详细信息,请参阅 Postman Collection SDK 响应参考。
使用请求信息编写脚本
该pm.info
对象提供与请求和脚本本身相关的数据,包括名称、请求 ID 和迭代计数。
该pm.info
对象提供以下属性和方法:
该事件将是
prerequest
或test
取决于脚本在请求中的执行位置:当前迭代 的值:
计划运行的迭代总数:
pm.info.iterationCount:Number
- 运行请求的保存名称:
pm.info.requestName:String
- 标识正在运行的请求的唯一 GUID:
使用请求 cookie 编写脚本
该pm.cookies
对象提供对与请求关联的 cookie 列表的访问。
该pm.cookies
对象提供以下属性和方法:
- 检查请求的域是否存在特定的 cookie(由名称指定):
pm.cookies.has(cookieName:String):Function → Boolean
- 获取指定 cookie 的值:
pm.cookies.get(cookieName:String):Function → String
- 获取对象中所有 cookie 及其值的副本。返回为请求域和路径定义的任何 cookie:
pm.cookies.toObject():Function → Object
有关详细信息,请参阅 Postman Collection SDK Cookie 列表参考。
你还可以使用pm.cookies.jar
指定域来访问请求 cookie。
要使用这些方法启用编程访问pm.cookies.jar
,请先将 cookie URL 添加到 allowlist 。
- 访问 cookie jar 对象:
pm.cookies.jar():Function → Object
例如:
const jar = pm.cookies.jar();
//cookie methods...
- 使用名称和值设置 cookie:
jar.set(URL:String, cookie name:String, cookie value:String, callback(error, cookie)):Function → Object
- 使用 PostmanCookie 或兼容对象设置 cookie :
jar.set(URL:String, { name:String, value:String, httpOnly:Bool }, callback(error, cookie)):Function → Object
例如:
const jar = pm.cookies.jar();
jar.set("httpbin.org", "session-id", "abc123", (error, cookie) => {
if (error) {
console.error(`An error occurred: ${error}`);
} else {
console.log(`Cookie saved: ${cookie}`);
}
});
- 从 cookie jar 中获取 cookie:
jar.get(URL:String, cookieName:String, callback (error, value)):Function → Object
- 从 cookie 罐中取出所有 cookie。cookie 在回调函数中可用:
jar.getAll(URL:String, callback (error, cookies)):Function
- 删除 cookie:
jar.unset(URL:String, token:String, callback(error)):Function → Object
- 清除 cookie 罐中的所有 cookie:
jar.clear(URL:String, callback (error)):Function → Object
有关详细信息,请参阅 Postman Collection SDK Cookie 参考。
从脚本发送请求
你可以使用该方法从预请求或测试pm.sendRequest
脚本异步发送请求。如果你同时执行计算或发送多个请求,而无需等待每个请求完成,这允许你在后台执行逻辑。你可以通过添加回调函数来避免阻塞问题,以便你的代码可以在 Postman 收到响应时做出响应。然后,你可以对响应数据执行所需的任何其他处理。
你可以向该pm.sendRequest
方法传递一个 URL 字符串,或者可以提供一个完整的 JSON 格式的请求配置,包括 header、方法、正文 等 。
// Example with a plain string URL
pm.sendRequest('https://postman-echo.com/get', (error, response) => {
if (error) {
console.log(error);
} else {
console.log(response);
}
});
// Example with a full-fledged request
const postRequest = {
url: 'https://postman-echo.com/post',
method: 'POST',
header: {
'Content-Type': 'application/json',
'X-Foo': 'bar'
},
body: {
mode: 'raw',
raw: JSON.stringify({ key: 'this is json' })
}
};
pm.sendRequest(postRequest, (error, response) => {
console.log(error ? error : response.json());
});
// Example containing a test
pm.sendRequest('https://postman-echo.com/get', (error, response) => {
if (error) {
console.log(error);
}
pm.test('response should be okay to process', () => {
pm.expect(error).to.equal(null);
pm.expect(response).to.have.property('code', 200);
pm.expect(response).to.have.property('status', 'OK');
});
});
脚本工作流程
当你使用 collection runner 或 Newman 时,该postman
对象提供setNextRequest
构建请求工作流的方法。
请注意,当你使用 Send运行请求时,这
setNextRequest
没有任何效果;它仅在你运行集合时有效。
当你运行一个集合(使用集合运行器或 Newman)时,Postman 将以默认顺序或你在设置运行时指定的顺序运行你的请求。但是,你可以使用postman.setNextRequest
指定下一个要运行的请求来覆盖此执行顺序。
- 在此之后运行指定的请求(集合中定义的请求名称,例如“Get customers”):
postman.setNextRequest(requestName:String):Function
- 在此之后运行指定的请求(由 返回的请求 ID
pm.info.requestId
):
postman.setNextRequest(requestId:String):Function
例如:
//script in another request calls:
//pm.environment.set('next', pm.info.requestId)
postman.setNextRequest(pm.environment.get('next'));
编写 Postman 可视化脚本
用于pm.visualizer.set
指定模板以 在 Postman Visualizer 中显示响应数据 。
pm.visualizer.set(layout:String, data:Object, options:Object):Function
layout
必需的- Handlebars HTML 模板字符串
data
选修的- 绑定到模板的 JSON 对象,你可以在模板字符串中访问它
options
选修的- 选项 对象
Handlebars.compile()
- 选项 对象
用法示例:
var template = `<p>{{res.info}}</p>`;
pm.visualizer.set(template, {
res: pm.response.json()
});
将响应数据构建到 Postman 可视化中
用于pm.getData
检索 Postman Visualizer 模板字符串中的响应数据。
pm.getData(callback):Function
回调函数接受两个参数:
error
- 任何错误详情
data
- 传递给模板 的数据
pm.visualizer.set
- 传递给模板 的数据
用法示例:
pm.getData(function (error, data) {
var value = data.res.info;
});
编写测试断言
pm.test(testName:String, specFunction:Function):Function
你可以使用在预请求或测试pm.test
脚本中编写测试规范。测试包括名称和断言——Postman 将输出测试结果作为响应的一部分。
该pm.test
方法返回pm
对象,使调用可链接。以下示例测试检查响应是否有效以继续。
pm.test("response should be okay to process", function () {
pm.response.to.not.be.error;
pm.response.to.have.jsonBody('');
pm.response.to.not.have.jsonBody('error');
});
可以将可选的done
回调传递给pm.test
, 以测试异步函数。
pm.test('async test', function (done) {
setTimeout(() => {
pm.expect(pm.response.code).to.equal(200);
done();
}, 1500);
});
- 获取从代码中特定位置执行的测试总数:
pm.test.index():Function → Number
该方法允许你使用 ChaiJS expect BDD pm.expect
语法在响应数据上编写断言。
pm.expect(assertion:*):Function → Assertion
你还可以使用pm.response.to.have.*
和pm.response.to.be.*
来构建你的断言。
有关更多断言,请参阅 测试示例。
使用外部库
require(moduleName:String):function → *
该require
方法允许你使用沙箱内置库模块。下面列出了可用库的列表以及相应文档的链接。
- jv
- 阿托布
- btoa
- 柴
- 欢呼声
- 加密 JS
- csv-解析/lib/同步
- lodash (内置
_
对象 v3.10.1 默认存在于沙箱中。用于require
加载最新版本。) - 片刻
- Postman 收集
- 电视 4
- uuid
- xml2js
以下 NodeJS 模块也可在沙箱中使用:
要使用库,调用方法require
,将模块名称作为参数传递,并将方法的返回对象分配给变量。
下一步
你可以使用 Postman 实用程序 以多种方式使用测试将 Postman 构建到你的开发项目中。