JMeter json列表多条件断言使用详解(二次开发)

本文详细介绍了JMeter的JsonListElementAssertion插件的下载、使用条件和步骤,以及如何通过该插件进行接口响应的断言验证。插件适用于JMeter3.3版本,需要将jar包放入指定目录并重启JMeter。通过JsonPath表达式,可以断言列表中是否存在满足特定条件的元素,确保接口返回数据的正确性。当JsonListPath为空时,也能进行有效断言。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一、插件下载地址:
百度网盘链接:https://pan.baidu.com/s/10sb74CzUIBR-f7WMPhbnJA
提取码:75f4

二、使用条件
1.JMeter版本为3.3(在JMeter3.3的基础上开发);
2.将jar包放置到目录…\lib\ext下重启JMeter即可;

三、插件使用说明:
1.安装插件,启动JMeter后断言新增了一个菜单项【Json List Element Assertion】,如下图:

在这里插入图片描述
2.断言【Json List Element Assertion】使用示例:
接口响应结果如下图:

在这里插入图片描述

需求:断言返回结果items列表中有一条记录能同时满足gName=个人文件、name=1234567891、size=0三个条件
示例如下:

在这里插入图片描述

说明:通过Json List Path这一项参数定位到整个列表,然后对列表进行遍历,通过Json Path查询结果和预期Json Value值比较进行断言,列表遍历某一项同时满足三组条件,则断言成功,否则断言失败。

注意:三组条件不能全为空。

3.Json List Path为空时使用示例
接口响应结果如下:
{“token”:“pFA84iH5TdU@1”,“stat”:“OK”}
示例如下:

在这里插入图片描述


四、FAQ
Q:使用此插件可能会出现如下报错:
cannot find class:kg/apc/jmeter/JMeterPluginsUtils
A:需要依赖JSON/YAML Plugins这个插件
————————————————
版权声明:本文为优快云博主「Radioman-lhq」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/q13554515812/article/details/86001016

### JMeter 断言概述 在性能测试工具 JMeter 中,断言用于验证服务器返回的结果是否满足特定条件。通过配置不同的断言组件,能够确保应用程序的行为符合预期,在负载条件下也能正常工作[^1]。 ### 常见断言类型及其功能描述 #### 1. 响应断言 (Response Assertion) 这是最常用的断言之一,允许设置个模式匹配器来检验响应数据中的字符串是否存在或不存在。支持正则表达式、包含/不包含等种方式来进行精确或模糊匹配。 - **适用场景**: 验证HTTP响应体内的指定文本片段 - **特点**: 支持种匹配规则,灵活性高 ```xml <elementProp name="Asserion.test_string" elementType="CollectionProp"> <collectionProp> <!-- 定义要查找的内容 --> <stringProp>Expected Text</stringProp> </collectionProp> </elementProp> ``` #### 2. XML 断言 (XML Assertion) 专门针对XML格式的数据进行校验,能解析并检查XML文档结构的有效性和正确性。 - **适用场景**: 对于RESTful API接口返回的XML格式报文做合法性检测 - **特点**: 自动化处理复杂的XML语法分析任务 #### 3. HTML 断言 (HTML Assertion)断言会尝试渲染接收到的HTML页面,并报告任何可能影响用户体验的问题,比如缺少关闭标签或其他不符合标准的情况。 - **适用场景**: 测试Web应用前端代码质量 - **特点**: 提供直观易懂的错误提示信息 #### 4. BeanShell 断言 (BeanShell Assertion) 利用Java编程语言编写自定义逻辑实现复杂业务需求判断;适合那些无法仅靠简单文本比较完成的任务。 - **适用场景**: 实现高度定制化的验证流程 - **特点**: 可扩展性强,几乎可以执行任意类型的运算操作 ```java // 示例:计算两个变量之和并与期望值对比 double sum = Double.parseDouble(vars.get("var1")) + Double.parseDouble(vars.get("var2")); if(sum != expectedValue){ FailureMessage = "Sum does not match!"; isFailed=true; } ``` --- ### 如何创建简单的响应断言实例 假设正在构建一个登录API的功能测试计划,希望确认每次成功调用该服务后都能得到含有单词 `"success"` 的JSON回复,则可按照如下步骤操作: 1. 打开目标采样器(Sampler),点击右侧“添加”按钮; 2. 寻找名为 `Assertion` 的分类项下拉菜单里的 “Response Assertion”,双击打开编辑窗口; 3. 设置属性: - Pattern Matching Rules: Contains(表示只要求部分匹配) - Patterns to Test: success (即待检索的关键字) 这样每当发送请求时,JMeter 就会在后台自动运用上述设定好的规则去核对实际获取到的信息流,一旦发现不符之处便会记录失败日志以便后续排查原因所在.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值