news 2026/5/9 10:35:07

【性能测试】6_JMeter_JMeter断言

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【性能测试】6_JMeter_JMeter断言

文章目录

  • 一、JMeter断言
    • 1.1 断言的概念
    • 1.2 JMeter中常用断言
  • 二、响应断言
    • 2.1 场景
    • 2.2 操作方法
    • 2.3 同一个HTTP请求下包含多个响应断言
    • 2.4 参数详解
      • 2.4.1 Apply to:适用范围
      • 2.4.2 测试字段:要检查的项
      • 2.4.3 模式匹配规则
      • 2.4.4 测试模式
  • 三、JSON断言
    • 3.1 场景
    • 3.2 操作方法
      • 3.2.1 查看json响应
      • 3.2.2 添加json断言
    • 3.3 参数详解
  • 四、断言持续时间
    • 4.1 场景
    • 4.2 操作方法

一、JMeter断言

1.1 断言的概念

  • 断言: 让程序判断预期结果和实际结果是否一致。
  • 提示: JMeter断言是在请求的返回层面增加一层判断机制; 因为请求成功了, 并不代表结果一定正确, 因此需要检测机制提高测
    试准确性。

1.2 JMeter中常用断言

  • 响应断言
  • JSON断言
  • 断言持续时间(Duration Assertion)

二、响应断言

添加方式: 测试计划 --> 线程组–> HTTP请求 --> (右键添加) 断言 --> 响应断言(断言一定是在HTTP请求的子节点下)

2.1 场景

需求:jmeter 请求:https://www.baidu.com,让程序检查 响应数据中是否包含“百度一下, 你就知道“

2.2 操作方法

1、类型:

  • 响应文本:断言 响应体 中包含的字符串。
  • 响应代码:断言 响应状态码。

2、注意事项:

  • 一个响应文本中,可以放置多个 字符串 关键字。
  • 响应状态码,必须放在响应代码中。

2.3 同一个HTTP请求下包含多个响应断言

2.4 参数详解

2.4.1 Apply to:适用范围

  • Main sample and sub-samples: 作用于父节点取样器及对应子节点取样器;
  • Main sample only: 仅作用于父节点取样器;
  • Sub-samples only: 仅作用于子节点取样器;
  • JMeter Variable: 作用于jmeter变量(输入框内可输入jmeter的变量名称);

2.4.2 测试字段:要检查的项

  • 响应文本: 来自服务器的响应文本, 即主体, 不包括任何HTTP头
  • 响应代码: 响应的状态码, 例如: 200
  • 响应信息: 响应的信息, 例如: OK
  • Response Headers: 响应头部
  • Request Headers: 请求头部
  • Request Data: 请求数据
  • URL样本: 响应的URL
  • Document(text): 响应的整个文档
  • 忽略状态: 忽略返回的响应状态码

2.4.3 模式匹配规则

  • 包括: 文本包含指定的正则表达式
  • 匹配: 整个文本匹配指定的正则表达式
  • Equals: 整个返回结果的文本等于指定的字符串(区分大小写)
  • Substring: 返回结果的文本包含指定字符串(区分大小写)
  • 否: 取反
  • 或者: 如果存在多个测试模式, 勾选代表逻辑或(只要有一个模式匹配, 则断言就是OK) , 不勾选代表逻辑与(所有都必
  • 须匹配, 断言才是OK)

注意: Equals和Substring模式是普通字符串, 而不是正则表达式。

2.4.4 测试模式

即填写你指定的结果(可填写多个),按钮【添加】 、 【删除】 是进行指定内容的管理

三、JSON断言

该组件用来对JSON文档进行验证, 验证步骤如下:

  1. 首先解析JSON数据, 如果数据不是JSON, 则验证失败。
  2. 使用Jayway JsonPath 1.2.0中的语法搜索指定的路径。 如果找不到路径, 就会失败。
  3. 如果在文档中找到JSON路径, 并且要求对期望值进行验证, 那么它将执行验证操作。

添加方式: 测试计划 --> 线程组–> HTTP请求 --> (右键添加) 断言 --> JSON断言

3.1 场景

需求:让程序检查响应的JSON数据中, city对应的内容是否为“北京”

URL:https://www.weather.com.cn/data/sk/101010100.html

场景:响应数据可以转换为json数据时,首选json断言。否则为其它断言

3.2 操作方法

3.2.1 查看json响应

{"weatherinfo":{"isRadar":"1","rain":"0","temp":"18","city":"北京","WSE":"1","qy":"1011","njd":"暂无实况","cityid":"101010100","WD":"东南风","SD":"17%","Radar":"JC_RADAR_AZ9010_JB","time":"17:05","WS":"1级"}}

3.2.2 添加json断言

JsonPath语法 :https://github.com/json-path/JsonPath

$.代表整个json响应结果 第一种语法: $.一级键名.二级键名.三级键名 $.weatherinfo.city 第二种语法:$...N级键名(N是几级,前面应该有几个点) $..city 第三种语法:weatherinfo.city

3.3 参数详解

  • Assert JSON Path exists: 用于断言的JSON元素的路径
  • Additionally assert value: 如果您想要用某个值生成断言, 请选择复选框
  • Match as regular expression: 如果需要使用正则表达式, 请选择复选框
  • Expected Value: 期望值, 用于断言的值或用于匹配的正则表达式的值
  • Expect null: 如果希望为空, 请选择复选框
  • Invert assertion (will fail if above conditions met): 反转断言(如果满足以上条件则失败)

四、断言持续时间

断言持续时间:客户端发送请求,到收到服务器的响应时间,要求不超过指定的时间。

添加方式: 测试计划 --> 线程组–> HTTP请求 --> (右键添加) 断言 --> 持续时间断言

4.1 场景

需求:请求: https://www.jd.com ,让程序检查响应时间是否大于500毫秒

4.2 操作方法

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

AI提示惊人的一致性

再写一个xray的管理页面,用户配置IP白名单机制,实现端口转发,前端有点菜,是非常菜,今天以前都没写过vue的任何代码。。。然后对照着deepseek在操作然后在遇到token过期,需要推出到登录页面的时候&#xff0…

作者头像 李华
网站建设 2026/5/2 15:01:47

Whisper语音识别模型剪枝:参数量化与加速推理

Whisper语音识别模型剪枝:参数量化与加速推理 1. 引言 1.1 项目背景与挑战 在构建基于 OpenAI Whisper Large v3 的多语言语音识别 Web 服务过程中,尽管其具备强大的跨语言转录能力(支持99种语言),但其庞大的模型规…

作者头像 李华
网站建设 2026/5/8 0:06:59

Qwen视觉模型CPU利用率低?优化策略提升推理效率实战案例

Qwen视觉模型CPU利用率低?优化策略提升推理效率实战案例 1. 问题背景与技术挑战 在部署基于Qwen/Qwen3-VL-2B-Instruct的多模态视觉理解服务时,尽管模型具备强大的图文理解能力,但在纯CPU环境下常出现推理速度慢、响应延迟高、CPU利用率偏低…

作者头像 李华
网站建设 2026/5/4 13:08:57

DeepSeek-R1-Distill-Qwen-1.5B多模型集成:投票策略优化

DeepSeek-R1-Distill-Qwen-1.5B多模型集成:投票策略优化 1. 引言 1.1 业务场景描述 在当前大模型应用快速落地的背景下,单一模型虽然具备较强的推理能力,但在复杂任务如数学推导、代码生成和逻辑判断中仍存在输出不稳定、错误累积等问题。…

作者头像 李华
网站建设 2026/5/8 18:20:15

开发者必看:CosyVoice-300M Lite镜像部署与调用完整指南

开发者必看:CosyVoice-300M Lite镜像部署与调用完整指南 1. 引言 1.1 场景背景 在语音合成(Text-to-Speech, TTS)技术快速发展的今天,越来越多的应用场景需要将文本实时转换为自然流畅的语音输出。从智能客服、有声读物到语音助…

作者头像 李华