• 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、公众号自定义菜单跳转到小程序http请求方式:POST(请使用https协议)接口:https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN;自定义菜单格式如下:2、开放标签跳转小程序:1. 引入JS文件在需要调用JS接口的页面引入如下JS文件:http://...
            0 0 742
            分享
          • 禁足的特殊时期,常规的面试手法:不管是面试官与求职者一对一的单挑,还是群殴式的无领导小组讨论,都无法施展了。取而代之的是:电话面试和视频面试。从人身安全的角度来说,无可厚非,你好我也好,大家好才是真的好。但是问题来了:习惯当面PK的求职者,有点不会玩了,可敌人不会因为你是新兵蛋子而不打你……谨以这篇攻略文,送给诸位疫情之下的求职者,希望添点助力,帮你逆风飞扬,闪亮职场。泰然处之,从容淡定第一条基本原则:不要慌!不同于现场面试,电话面试有点像开卷考试。你慌什么?咱占据有利地形啊!面试官又看不见你!提前备好简历,以防叙述时与简历有偏差,讲的时候更有条理,也避免了遗漏。另外,准备好工具资料备查,甚至...
            1 0 2102
            分享
          •   简历是你进入面试的敲门砖,也是留给意向公司的第一印象,所以这个很重要,必须在这上面做足了文章,一份优秀的面试简历是整个面试成败的重中之重,我们会详细分析如何准备简历才能保证简历不被刷掉。  简历通常有这几部分构成:  · 基本资料  · 专业技能  · 工作经历  · 项目经历  · 教育背景  今天我们主要聊一聊软件测试简历的编写以及注意事项,我稍后会放一个简历模板给大家看一下:  一、准备简历模板  万事开头难,简历的编写如果从头开始需要浪费很多时间,其实最快速也最聪明的办法就是先找一份还不错的简历模板,之后我们只需要填写信息即可。  简历模板的...
            0 0 1072
            分享
          • 概述对于post请求 有几种方式。 Content-Type 实体头部用于指示资源的MIME类型 media type 。content-type是http请求头的字段。作为请求头时(post或者put),客户端告诉服务器实际发送的数据类型。对于不同的content-type 发送的数据不太一样,对于服务器端,需要如何获取数据,以及正确解析的方法也是不一样的。下面列出常用的几种 Content-Typeapplication/jsonapplication/x-www-form-urlencodedmultipart/form-datatext/plaintext/xmltext/html1....
            0 0 1509
            分享
          •   做好缺陷(bug)的管理与跟踪的关键点,是要明确做这件事的目标:缺陷管理的目标是,通过工具辅助,详细记录和准确分类,便于进行数据统计和分析,从而帮助团队分析原因、进一步帮助团队持续改进和提升,而不是追责。  以下是具体的详细说明:  一、我们为什么需要进行缺陷管理与跟踪?  软件缺陷(bug)带来的影响可以包括以下几个方面:  1.用户体验受损:软件缺陷可能导致程序崩溃、功能失效、界面不友好等问题,影响用户使用体验。  2.生产效率降低:软件缺陷可能导致开发团队需要花费额外的时间和精力来修复问题,从而影响项目进度和生产效率。  3.成本增加:软件缺陷可能导致软件开发公司需要承担额外的成本来...
            0 0 825
            分享
      • 51testing软件测试圈微信