美文网首页
Postman使用学习

Postman使用学习

作者: 海的那一边 | 来源:发表于2021-10-26 16:01 被阅读0次

使用变量

通过将值存储在变量中,可以在整个集合、环境和请求中引用它,如果需要更新该值,只需在一个地方更改它。
Postman 支持以下变量范围:
Global
Collection
Environment
Data
Local


image.png

如果在两个不同的作用域中声明了同名变量,则使用作用域最窄的变量中存储的值——例如,如果有一个Globa变量和一个Local变量都命名为username,则在请求时将使用Local变量运行。

  • 全局变量允许您访问集合、请求、测试脚本和环境之间的数据。全局变量在整个工作区中都可用。
    由于全局变量会造成混淆,因此您应该只谨慎使用它们——例如,快速测试某些东西或当您的项目处于非常早期的原型设计阶段时。*
  • 集合变量在集合中的整个请求中都可用,并且与环境无关,因此不要根据所选环境进行更改。
    如果您仅使用单个环境,则集合变量是合适的,例如用于身份验证 / URL 详细信息。*
  • 环境变量允许您针对不同环境定制处理,例如本地开发与测试或生产。一次只能激活一个环境。
    如果您只有一个环境,使用集合变量会更有效率,但是环境允许您指定基于角色的访问级别。
  • 局部变量是临时的,只能在您的请求脚本中访问。局部变量值仅限于单个请求或集合运行,并且在运行完成后不再可用。
    如果您需要一个值来覆盖所有其他变量范围,但不希望该值在执行结束后持续存在,则局部变量是合适的。
    数据变量来自外部 CSV 和 JSON 文件,用于定义在通过 Newman 或 Collection Runner 运行集合时可以使用的数据集。

在脚本中定义变量:

pm.globals.set("variable_key", "variable_value");
pm.collectionVariables.set("variable_key", "variable_value");
pm.environment.set("variable_key", "variable_value");
pm.variables.set("variable_key", "variable_value");

在脚本中使用变量:

//access a variable at any scope including local
pm.variables.get("variable_key");
//access a global variable
pm.globals.get("variable_key");
//access a collection variable
pm.collectionVariables.get("variable_key");
//access an environment variable
pm.environment.get("variable_key");

访问变量:
{{username}}
如果变量未解析,Postman 会将其突出显示为红色。

使用动态变量
动态变量的例子如下:

{{$guid}} :一个 v4 风格的guid
{{$timestamp}}: 当前时间戳(以秒为单位的 Unix 时间戳)
{{$randomInt}}: 0 到 1000 之间的随机整数
const stringWithVars = pm.variables.replaceIn("Hi, my name is {{$randomInt}}");

共享和持久化数据
创建或编辑变量时,您可以输入初始值和当前值。在 UI 中创建新变量时,如果将当前值留空,它将自动填充初始值。如果您指定一个当前值,它将仅对您的实例是本地的——Persist选项允许您将当前值推送到共享数据,更新初始值以匹配当前值。

编写脚本

您可以添加 JavaScript 代码以在流中的 2 个事件期间执行:

  1. 在将请求发送到服务器之前,作为预请求脚本选项卡下的预请求脚本。
  2. 收到响应后,作为测试选项卡下的测试脚本。

脚本执行顺序:
在 Postman 中,单个请求的脚本执行顺序如下所示:

  • 与请求关联的预请求脚本将在请求发送之前执行
  • 与请求关联的测试脚本将在请求发送后执行

单个请求的工作流程

对于集合中的每个请求,脚本将按以下顺序执行:

  • 与集合关联的预请求脚本将在集合中的每个请求之前运行。
  • 与文件夹关联的预请求脚本将在文件夹中的每个请求之前运行。
  • 与集合关联的测试脚本将在集合中的每个请求之后运行。
  • 与文件夹关联的测试脚本将根据文件夹中的请求运行。

收集请求的工作流程

编写预请求脚本

您可以在 Postman 中使用预请求脚本在请求运行之前执行 JavaScript。通过在请求、集合或文件夹的Pre-request Script选项卡中包含代码,您可以执行预处理,例如设置变量值、参数、标头和正文数据。您还可以使用预请求脚本来调试代码,例如通过将输出记录到控制台。

请求前脚本的示例用法如下:

  • 您在集合中有一系列请求并按顺序运行它们,例如使用集合运行器
  • 第二个请求取决于从第一个请求返回的值。
  • 该值需要在您将其传递给第二个请求之前进行处理。
  • 第一个请求将响应字段中的数据值设置为其测试脚本中的变量。
  • 第二个请求检索该值并在其Pre-request Script 中处理它,然后将处理后的值设置为变量(在第二个请求中引用,例如在其参数中)。

脚本工具流:
在此之后运行指定的请求(集合中定义的请求名称,例如“获取客户”):

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'));

编写测试断言:

您可以为每个请求添加所需的任意数量的测试。
您的测试可以包含多个断言作为单个测试的一部分——您可以使用它来将相关断言组合在一起。

pm.test("The response has all properties", () => {
    //parse the response json and test three properties
    const responseJson = pm.response.json();
    pm.expect(responseJson.type).to.eql('vip');
    pm.expect(responseJson.name).to.be.a('string');
    pm.expect(responseJson.id).to.have.lengthOf(1);
});

您可以将测试脚本添加到集合、文件夹或集合中的单个请求。与集合关联的测试脚本将在集合中的每个请求之后运行。与文件夹关联的测试脚本将在文件夹中的每个请求之后运行。这允许您在每次请求后重用常用的测试。

测试响应体

您可以检查响应正文中的特定值:

pm.test("Person is Jane", () => {
  const responseJson = pm.response.json();
  pm.expect(responseJson.name).to.eql("Jane");
  pm.expect(responseJson.age).to.eql(23);
});

测试状态码

您可以测试响应状态代码:

pm.test("Status code is 201", () => {
  pm.response.to.have.status(201);
});

如果您想测试状态代码是否为一组,您可以将它们全部包含在一个数组中并使用oneOf

pm.test("Successful POST request", () => {
  pm.expect(pm.response.code).to.be.oneOf([201,202]);
});

您还可以检查状态代码文本:

pm.test("Status code name has string", () => {
  pm.response.to.have.status("Created");
});

测试响应时间
您可以测试响应时间是否在指定范围内:

pm.test("Response time is less than 200ms", () => {
  pm.expect(pm.response.responseTime).to.be.below(200);
});

使用集合运行器

  • 每个请求之间的间隔延迟(毫秒)。
  • 一个数据文件,用于收集运行。
  • 将响应保存到日志将允许您查看它们,但可能会影响性能。
  • 持久变量意味着运行更新的任何变量在运行之后将保持更改。如果不持久化变量,运行完成后将不会保存更改。请注意,集合运行中的持久变量将仅更新当前值。
  • 如果您的请求使用 cookie,您可以选择在收集运行中禁用它们。
  • 保存 cookie 意味着在运行期间受请求影响的任何值将在它完成后保留。

设置接下来要执行的请求:

postman.setNextRequest("request_name");

循环当前请求:

提供当前运行的名称setNextRequest会导致 Postman 连续运行当前请求。
注意:在连续循环一个请求时,应该包装setNextRequest一些逻辑以确保请求不会无限期地运行,否则收集运行器将需要强制关闭。
您可以使用数据文件传递 Postman 值集以在集合运行中使用。通过在 Collection Runner 中选择 JSON 或 CSV 数据文件,您可以在单次运行中使用多个不同的值测试您的请求。

相关文章

  • 学习计划

    学习postman工具使用 学习burpsuite工具使用 准备明年考软件评测考试

  • POSTMAN

    POSTMAN简介 POSTMAN安装 POSTMAN使用

  • Postman使用学习

    使用变量 通过将值存储在变量中,可以在整个集合、环境和请求中引用它,如果需要更新该值,只需在一个地方更改它。Pos...

  • 使用 Postman 进行接口测试(cookie设置)

    目录:使用 Postman 进行接口测试(入门)使用 Postman 进行接口测试(续) 使用postman模拟接...

  • Postman 使用入门

    Postman Postman Makes API Development Simple. 使用 PostMan ...

  • postman+jenkins 接口压测

    序言 本文章是讲postman+jenkins的实践,前提是已学习了postman和jenkins的使用实践步骤是...

  • Postman body传参数组

    如果你已经熟练使用 postman,则直接阅读,对 postman 使用不熟练可以下翻“Postman使用心得” ...

  • Mastering HTTP侧

    Http调试工具Postman使用 Postman Postman测试接口之JSON结构化数据提交 Postman...

  • Postman读取JSON文件和CSV文件

    在使用postman读取文件前我们先看下使用postman批量执行请求集合 Postman批量执行测试集合 选择要...

  • request工具

    使用教程 点击查看使用教程 安装文件 Postman Postman Interceptor good luck ...

网友评论

      本文标题:Postman使用学习

      本文链接:https://www.haomeiwen.com/subject/iatsaltx.html