文章目录

  • 一、JSON断言(JSON Assertion)参数说明
  • 二、准备工作
  • 三、测试计划设计
  • 3.1、Assert JSON Path exists
  • 3.2、Additionally assert value
  • 3.3、Expect null
  • 3.4、Invert assertion (will fail if above conditions met)



一、JSON断言(JSON Assertion)参数说明

可以对 Jmeter 取样器的响应消息以 JSON 方式进行检查

使用场景:当返回为 JSON 时,利用 JSON 断言,我们可以快速检测响应报文返回的特征值,进而判断取样器在业务上是否正确

使用频率:比较高,尤其是返回为 JSON 时,为首先断言器

右键 >>> 添加 >>> 断言 >>> JSON断言(JSON Assertion)

java语言json断言_右键

  • Assert JSON Path exists:用于断言的JSON元素的路径(JSONPath);检测JSONPath是否存在;使用XPATH语法书写
  • Additionally assert value:是否额外验证根据JSONPath提取的值。不勾选,验证JSONPath能否在JSON文档中找到路径;勾选,验证根据JSONPath提取值是否预期
  • Match as regular expression:预期值是否可以使用正则表达式。不勾选,预期值不能使用正则表达式表示;勾选,预期值可以使用正则表达式表示
  • Expected Value:预期值;支持脚本语言写法
  • Expect null:若验证提取的值为null,则勾选此项;验证null值,还是需要勾选“Additionally assert value”,否则验证的是JSONPath能否找到路径;预期值不填表示空字符,与null不等价
  • Invert assertion (will fail if above conditions met):若勾选,表示对断言结果取反

注意:除了 null 外,还有一种特殊的值,就是空数组,预期值不能不填,需要设置为:[]。其中 [] 表示空数组

二、准备工作

慕慕生鲜: http://111.231.103.117/#/login

  • 进入网页后,登录,页面提供了账户和密码
  • 搜索框输入“虾”
  • 右键检查或按F12,打开调试工具,点击搜索

java语言json断言_HTTP_02

三、测试计划设计

3.1、Assert JSON Path exists

(1)、测试计划右键 <<< 添加 <<< 配置原件 <<< 用户定义的变量

java语言json断言_HTTP_03

  • 添加一个变量:IP,值为 111.231.103.117

(2)、测试计划右键 <<< 添加 <<< 测试片段 <<< 测试片段

java语言json断言_java语言json断言_04

  • 名称:HTTP 采样请求

(3)、在网页中,调试中点击网络,找到请求,点击负载,复制参数值

java语言json断言_java语言json断言_05

(4)、HTTP 采样请求右键 <<< 添加 <<< 取样器 <<< HTTP请求

java语言json断言_JSON_06

  • 协议:GET
  • 路径:/product/list
  • 点击从剪切板添加,会自动添加;也可手动添加

(5)、HTTP请求右键 <<< 添加 <<< 后置处理器 <<< JSON提取器

java语言json断言_HTTP_07

  • 勾选 Main sample only

只对主取样器进行提取

  • Name of created variable:var1

参数名为:var1

  • JSON Path expressions:$…list[*].name

$:开始符固定的;..:0到多个级别,单个为根级别;list:返回的响应数据结构,相当于字典,key为list的值;name:list值中名为name键的值

  • Match No. (0 for Random):-1

匹配所有符合正则表达式的值

(6)、HTTP请求右键 <<< 添加 <<< 后置处理器 <<< 调试后置处理程序

java语言json断言_右键_08

  • 参数默认即可

(7)、HTTP请求右键 <<< 添加 <<< 配置元件 <<< HTTP请求默认值

java语言json断言_HTTP_09

  • 协议:http
  • 服务器名称或IP:${IP}

使用变量获取ip

  • 端口:8083
  • 内容编码:utf-8

(8)、在网页中,调试中点击网络,找到请求,点击标头找到请求标头,复制所有请求标头

java语言json断言_jmeter_10

(9)、HTTP请求右键 <<< 添加 <<< 配置元件 <<< HTTP信息头管理器

java语言json断言_HTTP_11

  • 点击从剪切板添加,会将复制的值自动添加进去

如图,可以将信息头中的 ip 使用变量 ${IP} 代替

(10)、测试计划右键 <<< 添加 <<< 线程(用户)<<< 线程组

java语言json断言_右键_12

  • 参数默认即可

(11)、线程组右键 <<< 添加 <<< 逻辑控制器 <<< 模块控制器

java语言json断言_右键_13

  • 选择 HTTP 采样请求

(12)、线程组右键 <<< 添加 <<< 断言 <<< JSON断言

java语言json断言_jmeter_14

java语言json断言_JSON_15

  • Assert JSON Path exists:$.data.total

判断响应数据——Response Body 中是否存在此路径

(13)、线程组右键 <<< 添加 <<< 监听器 <<< 查看结果树

(14)、点击启动,点击查看结果树,查看请求及取样器信息

java语言json断言_jmeter_16

如图,HTTP请求成功,HTTP请求的响应数据下的Response Body中存在 $.data.total 此路径,所以断言成功,请求也是成功的

Assert JSON Path exists:响应数据——Response Body 中是否存在此路径;使用XPATH语法书写

3.2、Additionally assert value

测试计划设计在 3.1 基础上进行修改验证

(1)、修改 JSON断言,勾选 Additionally assert value,Expected Value 输入 2

java语言json断言_HTTP_17

  • Assert JSON Path exists:$.data.total
  • 勾选 Additionally assert value

验证根据JSONPath提取的值,与 Expected Value 输入框配合使用

  • Expected Value:2

验证JSONPath提取的值是否与书写的值一致,与 Additionally assert value 配合使用;与 响应数据——Response Body 中的 total 值比较

(2)、点击清除全部,点击启动,点击查看结果树,查看请求及取样器信息

java语言json断言_JSON_18

如图,HTTP请求成功,HTTP请求的响应数据下的Response Body中存在 $.data.total 此路径,且路径中 total 的值为2 ,所以断言成功,请求也是成功的

(3)、修改 JSON断言,勾选 Additionally assert value,Expected Value 为空

java语言json断言_JSON_19

  • Assert JSON Path exists:$.data.total
  • 勾选 Additionally assert value

勾选 Additionally assert value,但未写 Expected Value 时,验证JSONPath路径提取的值是否为 '',空

(4)、点击清除全部,点击启动,点击查看结果树,查看请求及取样器信息

java语言json断言_java语言json断言_20

如图,HTTP请求失败,HTTP请求的响应数据下的Response Body中存在 $.data.total 此路径,且路径中 total 的值为2 ,而JSON断言中,Expected Value 为空,断言 total 值是否为空

Additionally assert value:勾选后,验证根据JSONPath提取的值,是否与 Expected Value 中书写的值一致

3.3、Expect null

测试计划设计在 3.2 基础上进行修改验证

(1)、修改 JSON断言,勾选 Expect null

java语言json断言_JSON_21

  • Assert JSON Path exists:$.data.total
  • 勾选 Additionally assert value
  • 勾选 Expect null

验证JSONPath提取的值是否是 null,与 Additionally assert value 配合使用;与 响应数据——Response Body 中的 total 值比较

(2)、点击清除全部,点击启动,点击查看结果树,查看请求及取样器信息

java语言json断言_右键_22

如图,HTTP请求失败,HTTP请求的响应数据下的Response Body中存在 $.data.total 此路径,且路径中 total 的值为2 ,而JSON断言中,勾选了 Expect null,断言 total 值是否为 null

Expect null:勾选后,验证根据JSONPath提取的值,是否为 null;使用时,需勾选 Assert JSON Path exists

3.4、Invert assertion (will fail if above conditions met)

测试计划设计在 3.3 基础上进行修改验证

(1)、修改 JSON断言,勾选 Invert assertion (will fail if above conditions met)

java语言json断言_右键_23

  • Assert JSON Path exists:$.data.total
  • 勾选 Additionally assert value
  • 勾选 Expect null
  • 勾选 Invert assertion (will fail if above conditions met)

取反

(2)、点击清除全部,点击启动,点击查看结果树,查看请求及取样器信息

java语言json断言_JSON_18

如图,HTTP请求成功,3.3 中的测试计划是断言失败的,勾选 Invert assertion (will fail if above conditions met) 取反,所以断言成功

Invert assertion (will fail if above conditions met):对断言结果取反