news 2026/6/15 15:33:21

【接口测试】3_Postman _Postman断言

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【接口测试】3_Postman _Postman断言

文章目录

  • 一、Postman 断言简介
  • 二、解决Postman没有tests
  • 三、Postman 常用断言
    • 3.1 断言响应状态码(重点)
    • 3.2 判断返回响应体
      • 3.2.1 断言包含某字符串
      • 3.3.3 断言等于某个字符串
    • 3.3 断言JSON数据(重点)
    • 3.4 断言响应头
  • 四、Postman 断言工作原理
  • 五、小结

一、Postman 断言简介

Postman断言: 让Postman工具代替人工自动判断预期结果和实际结果是否一致。

用法:

  • postman 断言借助 JavaScript语言编写代码,写在 ‘Tests’ 的标签页里。
  • Tests中的脚本在发送请求之后执行,会把断言的结果(PASS/FAIL)最终在’Test Results’标签页中展示。

二、解决Postman没有tests

  • 在 Scripts下的Post-response里,Post-response即为tests功能。
  • 官网说明:https://learning.postman.com/docs/tests-and-scripts/write-scripts/test-scripts/

三、Postman 常用断言

3.1 断言响应状态码(重点)

Status code: Code is 200

  1. 在 Tests 标签中,选中 Status Code:code is 200, 生成对应代码
  2. 适当调整 test() 方法参数1,和 匿名函数中的 预期结果。
  3. 点击 send 按钮,发送请求,执行断言代码。
  4. 查看断言结果。
// 判断响应状态码 是否等于200pm.test("Status code is 200",function(){pm.response.to.have.status(200);});------------------------------------------------------------pm:postman的一个实例(对象)。 实例:类下面的一个对象test():pm实例的一个方法。有两个参数 参数1:断言成功后,给出的文字提示。可以任意修改。(不参与断言,只是给个文字提示)"Status code is 200"参数2:匿名函数。function(){pm.response.to.have.status(200);}pm.response.to.have.status(200);// 意思:postman 的响应结果中应该包含状态码 200200——>预期结果!

3.2 判断返回响应体

3.2.1 断言包含某字符串

Response body: Contains string

// 断言响应体包含指定字符串pm.test("Body matches string",function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");});------------------------------------------------------------------解释 pm:postman的一个实例test():postman实例的方法,有两个参数 参1:断言后显示的文字提示信息,可改。(不参与断言,只是给个文字提示) 参2:匿名函数function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");}其中 pm.expect(pm.response.text()).to.include("string_you_want_to_search");// 意思:pm 期望 响应文本 中,包含 xxxx 字符串。"string_you_want_to_search"——>预期结果。 可以修改

3.3.3 断言等于某个字符串

Response body: Is equal to a string

// 断言 响应体 等于某个字符串(对象)pm.test("Body is correct",function(){pm.response.to.have.body("response_body_string");});-------------------------------------------------------------------解释 pm.response.to.have.body("response_body_string");// 意思是,pm 的 响应中应该有 响应体 xxx"response_body_string"——>预期结果。 可以修改

3.3 断言JSON数据(重点)

Response body: JSON value check

// 断言json的响应结果pm.test("Your test name",function(){varjsonData=pm.response.json();pm.expect(jsonData.value).to.eql(100);});-----------------------------------------------------------------------------------解释 pm:postman的一个实例test():postman的方法。有两个参数。 参1:断言完成后,给用户的提示性文字信息。可以任意修改(不参与断言,只是给个文字提示) 参2:是一个 匿名函数 调用。varjsonData=pm.response.json();var是 js 语言中,定义变量的关键字。 jsonData 是变量名 pm.response.json()表示 postman的 json响应结果 代表:{"success":true,"code":10000,"message":"操作成功!","data":"46b1fcde-e996-4520-b8f6-a2cd2da95350"}pm.expect(jsonData.value).to.eql(100);value 指代 json数据中的“key”(举例:可以取:success 或 code 或 message 或 data)100,应该替换为 key 所对应的value(预期结果,可以修改)

3.4 断言响应头

Response headers: Content-Type header check

// 断言响应头pm.test("Content-Type is present",function(){pm.response.to.have.header("Content-Type");});-------------------------------------------------------------解释 pm.response.to.have.header("Content-Type");pm 的响应头中包含 Content-Type 示例:可以在 header 中,添加 响应头中的 key 对应的 value 判定。用 ,隔分。 断言响应头 pm.test("Content-Type is present",function(){pm.response.to.have.header("Content-Type","application/json;charset=UTF-8");});

四、Postman 断言工作原理

五、小结

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 23:29:50

vb.net宿主程序通过统一接口直接调用,命名空间要一致

命名空间不同是导致这个转换失败的核心原因—— 即使接口的方法签名完全一样,只要接口所在的命名空间、程序集不同,CLR 就会将它们视为两个完全不同的接口类型,因此无法强制转换。核心原理:CLR 识别接口的 “唯一标识”CLR 判断两…

作者头像 李华
网站建设 2026/6/15 9:34:59

C#全面超越JAVA,主要还是跨平台用的人少

C# 相较于 Java 表现出 “更快” 的体感或实测性能,并非绝对结论(二者核心性能层级相近),而是运行时设计、编译策略、平台优化、生态适配等多维度差异共同作用的结果。以下从技术底层拆解关键原因,同时说明场景局限性&…

作者头像 李华
网站建设 2026/6/12 0:39:16

自媒体人实测:3 款「适合一人导演的 AI 工具」测评,这款AI工具让我告别 “一人剧组” 焦虑

作为坚持日更的自媒体人,我曾被 “一人当导演、编剧、剪辑、配音” 的压力逼到崩溃。 拍产品开箱要反复调镜头,做剧情短片得手动对上口型,找个环境音效能耗一下午。 直到试了 3 款热门「适合一人导演的 AI 工具」,才发现即梦 AI 刚…

作者头像 李华
网站建设 2026/6/15 7:50:43

Riskified宣布举办2026年Ascend峰会:以“动态智能”引领电商新时代

从北美到亚太,2026年Ascend峰会将汇聚欺诈与风险管理领域的领袖,共商以创新为导向的电商增长战略 电商AI欺诈与风险管理领域的领军企业Riskified (NYSE:RSKD)宣布,其顶级全球峰会Ascend将于2026年再次以全球系列活动的形式举办。Ascend峰会将…

作者头像 李华
网站建设 2026/6/15 11:23:27

DeepCode: Open Agentic Coding

DeepCode: Open Agentic Coding 现在,深度学习和机器学习技术正在逐级提升,我们在开发代码的方式上也遇到了前所未有的变革。DeepCode的诞生,就是为了应对这一挑战,通过多代理系统推动代码生成的智能化。本文将详细介绍DeepCode的…

作者头像 李华
网站建设 2026/6/15 9:34:38

python-flask-django蛋糕甜品烘焙教程微信小程序设计与实现_6uy1k94r

文章目录系统截图项目技术简介可行性分析主要运用技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!系统截图 python-flask-django_6uy1k94r 蛋糕甜品烘焙教程微信小程序设计与实现 项目技术简介 Pytho…

作者头像 李华