• 0
  • 0
分享

  Postman不仅是一个强大的 API 开发工具,它还提供了创建自动化测试脚本的能力,这些脚本可以用于检验API请求得到的响应是否符合预期。这些测试脚本被称为 “Tests”,支持使用 JavaScript 编程语言进行编写,并且 Postman 提供了一系列的断言库来帮助你检查包括但不限于状态码、响应内容以及响应时间在内的响应数据。

  创建并运行这些测试脚本的过程分为几个步骤:

  创建新的API请求

  首先,启动 Postman 应用并新建一个 API 请求。在请求设置界面的顶部导航中,找到并点击 "Tests" 标签。此处提供了一个编辑器,允许你输入和编辑 JavaScript代码,用以对接口响应进行验证。

  脚本编写阶段

  Postman 的断言库提供了多种函数来帮助你验证响应数据。例如,利用pm.response.to.have.status()函数可以验证响应状态码是否正确,通过pm.response.to.have.jsonBody()函数可以检测 JSON 格式的响应体。下方的代码展示了一个验证状态码为 200 的基本测试脚本:

 // 验证响应状态码为200pm.test("Status code is 200", function () {    pm.response.to.have.status(200);});

  测试与结果验证

  当测试脚本编写完毕后,点击 "Send" 按钮提交请求。Postman 将自动执行 测试脚本,并在 "Test Results" 面板中展示出测试结果。

  除了上述的状态码验证之外,Postman 的测试脚本还能够应对各式各样的测试需求。以下是一些其他常见的测试脚本示例:

  检查响应体特定字段:

  pm.test("Response body contains specific field", function () {    let jsonData = pm.response.json();    pm.expect(jsonData).to.have.property('field_name');});

  验证响应时间:

  pm.test("Response time is within expected range", function () {    pm.expect(pm.response.responseTime).to.be.below(500);});

  检查特定响应头:

  pm.test("Response includes certain header", function () {    pm.response.to.have.header('header_name');});

  确认响应体字段值:

  pm.test("Expected value in response body field", function () {    let jsonData = pm.response.json();    pm.expect(jsonData.field_name).to.equal('expected_value');});

  验证 JSON 结构:

  pm.test("JSON structure matches expectation", function () {    pm.response.to.have.jsonBody('json_schema');});

  检查数组长度:

  pm.test("Array length in response body meets expectation", function () {    let jsonData = pm.response.json();    pm.expect(jsonData.array_name).to.have.lengthOf(expected_length);});

  这些脚本仅是展示了 Postman 强大测试能力的冰山一角。为了高效地使用这些测试功能,强烈建议阅读官方文档,了解更多的预定义断言函数和测试方法。

  通过这种方式,Postman 能够帮助开发者和测试工程师确保 API 的每个改动都能满足预期的标准,从而提升 API 的质量和稳定性。

  总结

  Postman 的 “Tests” 功能为 API 开发与测试提供了强大支持,从简单的状态码检查到复杂的响应时间和内容验证,无不显现其灵活性和强大的定制能力。通过编写和执行这些测试脚本,开发者与测试工程师能够确保他们的 API 表现符合设计预期,同时提升整体的开发效率。



  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 1.接口自动化测试Web应用的接口自动化测试可以分为两类:模块接口测试和web接口测试1.1 模块接口测试主要测试模块之间的调用与返回,可以将其看做是单元测试的基础,主要强调对一个类方法或函数的调用,并对返回结果的验证,所用到的测试工具与单元自动化测试相同1.2 Web接口测试又分为服务器接口测试和外部接口测试1.2.1 服务器接口测试测试浏览器与服务器的接口1.2.2 外部接口测试指调用的接口由第三方提供,如使用QQ,支付宝,微信账号登录系统等2.什么是接口(API)人类与电脑等信息机器或人类与程序之间的接口称为用户界面(UI接口)电脑等信息机器硬件组件间的接口称为硬件接口电脑等信息机器软件...
            0 0 1265
            分享
          •   法国网站 Numerama 就本月早些时候推出的新款 iPad Pro 采访了苹果公司的三位高级员工。虽然讨论没有透露太多新细节,但提到了未来 iPad 的一个潜在变化。  iPad Pro 2024 太空黑 iPad 背面的苹果徽标在垂直方向上是直立的,但在连接键盘的情况下,设备通常是横向使用的,这就导致苹果徽标会横着出现。在新款 iPad Pro 和 iPad Air 上,苹果已经将前置摄像头移到了较长的右侧边缘,这样当设备横向使用时,摄像头就会出现在顶部中央。  随着横向使用越来越流行,苹果产品设计师莫莉-安德森(Molly Anderson)表示,未来的 iPad 有可能采用横向苹...
            0 0 744
            分享
          • 苹果6月4日的全球开发者大会上,我们看到iOS的改进之处在于增强了对增强现实的支持。一个全新的ARKit正在崭露头角,随着它的出现,一些令人印象深刻的应用程序和功能可以使混合现实不再仅仅是只一个新奇的玩意了,可以会有更多的应用。      我们还没有看到任何真正令人兴奋的AR,但重要的是要记住这个主题对苹果有多重要。首席执行官蒂姆库克一再表示,他认为AR是苹果长期未来最重要的发展之一。去年,他告诉Vogue,“我认为所有任何部门或行业都会受到AR的影响。” 我们现在还只是看到了渐进式的发展,但AR是构建软件背景的一部分,这将...
            0 0 1912
            分享
          • 手动测试做久了,总会想要尝试接触些新技术,UI自动化就是一个非常容易尝试的入门砖。小白也能做,相信自己放手去试吧。一、为什么需要做UI自动化1.想一想,为什么需要做UI自动化可以从解决问题的角度出发,想一下在工作中,哪些工作重复性非常高?最最常见的重复性工作,那就是:功能回归测试啦。现在市面上的大小公司都在推敏捷开发,几乎都是2周/3周发一次版本。即2周/3周跑一次回归测试,而且Android和iOS都需要跑一次,即便分在个人头上的回归内容很少,其实也占据了大家大量时间。当然,并不是说UI自动化只能在回归测试阶段发光发热,在测试的任何阶段都可以尝试跑UI测试脚本,可以根据公司需要调整运行阶段、...
            0 0 2118
            分享
          •   某系统的批量程序和联机程序同时发起交易、操作数据库同一张表时,出现了交易间相互影响导致交易失败。  分析原因为事务A对数据库表操作全表删除时,数据库机制会自动触发产生排他行锁,当行锁数达到“升级到表锁前允许的最大行锁数”时,会自动升级为表锁。但因事务B已对数据库表产生了排他行锁,则事务A自动升级表锁失败。直至事务A消耗掉了数据库“最大锁资源数”,系统会报错“锁资源耗尽”、交易失败。  因此,设计程序时,如涉及多事务操作数据库同一张表,需考虑事务间的关联影响,是否会引发事务冲突。  下文将详细描述和分析该问题。  1 数据库锁  首先介绍一下数据库锁的相关概念。  1.1 行锁、页锁和表锁 ...
            14 14 1730
            分享
      • 51testing软件测试圈微信