『动善时』JMeter基础 — 31、JMeter中BeanShell断言详解
JMeter中的BeanShell断言,可以使用BeanShell脚本来执行断言检查,可以用于更复杂的个性化需求,使用更灵活,功能更强大,但是要能够熟练使用BeanShell语。
1、BeanShell简介
Beanshell是一种类似JAVA的脚本语言,通过BeanShell可以对请求数据、响应数据或环境变量进行更加灵活的处理和判断。还可以直接调用外部的JAR包,例如:可以直接引入现成的第三方JSON解析包来使用。
在JMeter的多种组件中都有BeanShell的身影,如下:
- 定时器:
BeanShell Timer
- 前置处理器:
BeanShell PreProcessor
- 采样器:
BeanShell Sampler
- 后置处理器:
BeanShell PostProcessor
- 断言:
BeanShell Assert
- 监听器:
BeanShell Listener
在JMeter运行的流程控制中,BeanShell出现的位置,如下图所示:
2、Beanshell的内置变量和方法
Beanshell有一些默认的内置变量和方法,用户可以通过这些变量与JMeter进行交互,
例如:
prInt
:非GUI模式下打印信息(输出信息到stdout
,标准输出控制台)。log
:输出信息到日志(文件)log.debu("调试信息")
log.info("响应状态码" + ResponseCode)
log.warn("警告信息")
log.error("出错信息")
ResponseCode
:响应状态码(String类型)。ResponseHeaders
:响应头(String类型)。prev
:获取当前请求结果prew.getResponseDataAsString()
:获取响应体数据(String类型)。prew.getResponseCode()
:获取状态码(同ResponseCode,String类型)。
vars
:操作JMeter变量String var1 = vars.get("变量名")
:获取变量的值(假设为String类型)。vars.put("变量名", 变量值)
:设置变量值。
props
:操作JMeter属性props.get(String,String)
可以获取JMeter中已经生成的属性。props.put(String,String)
可以创建和更新JMeter属性。
ctx
:获取当前线程上下文数据(可获取所有信息)ctx.getVariables("变量名")
:获取变量值(同vars.get()
)。ctx.setVariables("变量名", "变量值")
:设置变量(同vars.put()
)。ctx.getProperties("属性名")
:获取属性值(同props.get()
)。ctx.setProperties("属性名","属性值")
:设置属性(同props.put()
)。ctx.getPreviousResult()
:获取当前请求结果同(prev
)。ctx.getCurrentSampler()
:获取当前采样器。ctx.getPreviousSampler()
:获取前一采样器。ctx.getThreadNum()
:获取线程数。ctx.getThreadGroup()
:获取线程组。ctx. getThread()
:获取当前线程。ctx.getEngine()
:获取引擎。ctx.isSamplingStarted()
:判断采样器是否启动。ctx.isRecording()
:判断是否开启录制。ctx.getSamplerContext()
:获取采样器山下文数据。
提示:ctx详细API可参考:JMeter上下文
3、BeanShell断言界面详解
添加BeanShell断言组件操作:选中“取样器”右键 —> 添加 —> 断言 —> BeanShell断言
。
界面如下图所示:
BeanShell断言组件的详细说明:
- 名称:BeanShell断言组件的自定义名称,见名知意最好。
- 注释:即添加一些备注信息,对该BeanShell断言组件的简短说明,以便后期回顾时查看。
Reset bsh.Interpreter before each call
:每个BeanShell测试元素都有自己的解释器副本(对于每个线程)。如果重复调用测试元素,例如在循环内,除非选择在每次调用之前重置bsh.Interpreter
选项,否则解释器将保留在调用之间。一些长时间运行的测试可能会导致解释器使用大量内存。
由于BeanShell的bsh.Interpreter
存在内存泄露,常规方法无法支持长时间的压力测试。JMeter官网推荐,在使用BeanShell进行长时间测试时,打开选项Reset bsh.Interpreterbefore each call
,则在每次调用BeanShell程序前,都把解释器重置,以释放解释器之前占用的内存。参数 (-> String Parameters和String[]bsh.args)
:输入String参数。String []bsh.args
是主类main函数的形式参数,是一个String 对象数组,可以用来获取命令行用户输入进去的参数。- 脚本文件:脚本文件(可以填入脚本文件路径),可以点击后边的浏览选择脚本文件。
Script (see below for variables that are defined)
:编写脚本,参照下文定义的变量(使脚本文件参照定义的变量来运行)
4、BeanShell断言的使用
BeanShell断言中可以通过ResponseCode
、ResponseHeaders
及pre.getResponseDataAsString()
来分别获得String格式的响应状态码、响应头、响应体数据。结合if
判断,通过变量Failure=false
或Failure=true
来设置断言是否通过。当设置Failure=true
时,还可以设置FailureMessage
来设置失败原因。
我们以一个登陆接口,来演示BeanShell断言组件的应用。
(1)测试计划内包含的元件
添加元件操作步骤:
- 创建测试计划。
- 创建线程组:
选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
。 - 在线程组里面,添加取样器“HTTP请求”组件:
选中“线程组”右键 —> 添加 —> 取样器 —> HTTP请求
。 - 在取样器下,添加断言“BeanShell断言”组件:
选中“取样器”右键 —> 添加 —> 断言 —> BeanShell断言
。 - 在取样器下,添加监听器“断言结果”组件:
选中“取样器”右键 —> 添加 —> 监听器 —> 断言结果
。 - 在线程组里面,添加监听器“察看结果树”组件:查看结果,
选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树
。
最终测试计划中的元件如下:
点击运行按钮,会提示你先保存该脚本,脚本保存完成后会直接自动运行该脚本。
(2)登陆接口请求界面内容
标准的Post请求,填写请求的基本信息和参数即可。
编写内容如下:
(3)BeanShell断言界面内容
我把只要把自己编写的BeanShell代码,复制到Script (see below for variables that are defined)
下的输入框即可。
如果需要进行模拟压力测试的时候,可以勾选上Reset bsh.Interpreter before each call
选项。我们这里不用。
编辑好的界面,如下图所示:
说明:
1)状态码断言代码:
//状态码断言
log.info("状态码:" + ResponseCode);
if(ResponseCode.equals("200")){
Failure=false; // 表示断言成功
}
else{
Failure=true; // 表示断言失败
FailureMessage="响应状态码非200"; // 自定义的失败信息
}
注:字符串只能使用双引号,字符串相等要使用
" ".equals(" ")
表达式。
2)响应体包含特定内容断言代码:
//获取响应数据
String response = prev.getResponseDataAsString();
log.info("响应体:" + response);
//响应数据包含
if(response.contains("登录成功")){
Failure=false; // 表示断言成功
}
else{
Failure=true; // 表示断言失败
FailureMessage="响应数据不包含登录成功";
}
(4)查看运行结果
我们在察看结果树组件中,观察脚本运行之后的结果。
如果断言正确,和正常发送请求一样,如下图:
如果断言失败,则会出现断言失败的提示,如下图所示:
(5)断言结果组件说明
也添加断言结果监听器,通过断言结果组件来判断断言是否通过。
如下图所示:
说明:
- 已通过的断言仅显示取样器名称。
- 未通过的,除了显示取样器的名称,还显示错误原因。
5、补充知识点
(1)JSON响应体字段提取及断言
将String类型的响应体转为JSON对象并操作需要额外的JAR包,可以使用org.json.jar
或gson.jar
。
以json.jar
为例,下载后将其放入JMeter/lib
目录下,重启JMeter,添加BeanShell断言代码,如下:
//JSON响应断言
import org.json.*; //导入org.json包
String response = prev.getResponseDataAsString(); //获取响应数据
JSONObject responseJson = new JSONObject(response); //转为JSON对象
String message = responseJson.getString("message");
log.info("响应message字段:" + message);
if(message.equals("成功")){
Failure=false;
}
else{
Failure=true;
FailureMessage="响应message字段非成功";
}
JSONObject对象除了getString()
方法外,还支持:
getBoolean("字段名")
:获取布尔类型字段值。getInt("字段名")
:获取整型字段值。getLong("字段名")
:获取长整型字段值。getDouble("字段名")
:获取双精型字段值。getJSONObject("字段名")
:获取嵌套Object类型字段值,JSONObject类型。getJSONArray("字段名")
:获取嵌套Array类型,JSONArray类型。
(2)响应头解析
响应头原本为String类型,可以通过分割遍历组装成Map类型来提取响应头中的项
Copyimport java.util.HashMap;
import java.util.Map;
//将字符串用换行符 截取为adc数组
String [] headersList = ResponseHeaders.split("\n");
Map headersMap = new HashMap(); //创建HashMap来从新组装headers
for(int i=1;i<headersList.length;i++){
String [] itemList=headersList[i].split(": "); // 将每一条Headerr项按冒号分割
headersMap.put((itemList[0]), itemList[1]); // 分键值放入HashMap
}
String contentType = headersMap.get("Content-Type"); // 提取相应项
log.info("响应Content-Type:" + contentType)
『动善时』JMeter基础 — 31、JMeter中BeanShell断言详解的更多相关文章
- 『与善仁』Appium基础 — 12、Appium的安装详解
目录 (一)Appium server安装 方式一:(桌面方式:推荐) 1.Appium Desktop下载 2.Appium Desktop安装 3.Appium Desktop使用 方式二:(No ...
- 『动善时』JMeter基础 — 32、JMeter察看结果树组件详解
目录 1.察看结果树介绍 2.察看结果树界面详解 3.察看结果树的其他功能 (1)将数据写入文件中 (2)Search功能 (3)Scroll automatically选项 4.总结 1.察看结果树 ...
- 『动善时』JMeter基础 — 6、使用JMeter发送一个最基础的请求
目录 步骤1:创建一个测试计划 步骤2:创建线程组 步骤3:创建取样器 步骤4:创建监听器 步骤5:完善信息 步骤6:保存测试计划 步骤7:查看结果 总结:JMeter测试计划要素 当我们第一次打开J ...
- 『动善时』JMeter基础 — 8、JMeter主要元件介绍
目录 1.测试计划(Test Plan) 2.线程组 3.取样器(sampler) 4.逻辑控制器(Logic Controller) 5.配置元件(Config Element) 6.定时器(Tim ...
- 『动善时』JMeter基础 — 20、JMeter配置元件【HTTP Cookie管理器】详细介绍
目录 1.HTTP Cookie管理器介绍 2.HTTP Cookie管理器界面详解 3.JMeter中对Cookie的管理 (1)Cookie的存储 (2)Cookie的管理策略 4.补充:Cook ...
- 『动善时』JMeter基础 — 40、JMeter中ForEach控制器详解
目录 1.什么是逻辑控制器 2.ForEach控制器介绍 3.ForEach控制器的使用 (1)测试计划内包含的元件 (2)获取学院列表请求内容 (3)JSON提取器内容 (4)ForEach控制器内 ...
- 『动善时』JMeter基础 — 44、JMeter对数据库的更新操作
目录 1.执行一条insert语句 2.insert语句实现参数化 3.一次执行多条insert语句 4.使用Beanshell生成加密数据示例 (1)测试计划内包含的元件 (2)JDBC连接配置组件 ...
- 『动善时』JMeter基础 — 7、jmeter.properties文件常用配置
目录 1.默认语言设置 2.配置默认编码格式 3.GUI图标放大比例设置 4.功能区工具栏图标大小设置 5.视图区目录树图标大小设置 6.内容区编辑字体设置 7.添加JMeter元素快捷键设置 8.捕 ...
- 『动善时』JMeter基础 — 12、JMeter取样器详解:sampler
目录 1.取样器介绍 2.JMeter自带的取样器 3."HTTP请求"为例介绍一下取样器 (1)HTTP Request: (2)Web服务器: (3)HTTP请求: (4)同请 ...
随机推荐
- Score UVA - 1585
There is an objective test result such as "OOXXOXXOOO". An 'O' means a correct answer of ...
- Day11_50_SortedMap集合
SortedMap集合 二叉查找树 和 二叉*衡树 二叉查找树是一种有序的树,所有的左孩子的value值都是小于叶子结点的value值的,所有右孩子的value值都是大于叶子结点的.这样做的好处在于: ...
- 二向箔web安全学院 --新手入门
二向箔安全学院 click here 新手入门|梦境穿越 1.要建立一个这样的观念|理解:计算机之所以是计算机,是它具有重复进行某种指令的特征,因而我们写的代码 or 脚本,本质上就是让计算机代替我们 ...
- C/C++ 对代码节的动态加解密
加壳的原理就是加密或者压缩程序中的已有资源,然后当程序执行后外壳将模拟PE加载器对EXE中的区块进行动态装入,下面我们来自己实现一个简单的区块加解密程序,来让大家学习了解一下壳的基本运作原理. 本次使 ...
- 线程操作与进程挂起(Windows核心编程)
0x01 线程挂起与切换 对于挂起进程,挂起线程则比较简单,利用 ResumeThread 与 SuspendThread 即可,当线挂起时线程用户状态下的一切操作都会暂停 #include < ...
- Maven关于web.xml中Servlet和Servlet映射的问题
在配置Servlet时,有两个地方需要配置. 一个是<servlet>,另一个是<servlet-Mapping>,这两个一个是配置Servlet,一个是配置其映射信息. &l ...
- ThinkPHP5.1 输出到模板HTML格式被强行转成了字符
出现问题 控制器传给视图一个input标签,在视图页面显示出来就是 <input type='text'></input>,显示出来的是一个文本,而不是一个可以输入的文本框 解 ...
- Linux yum 报错:One of the configured repositories failed (Unknown), and yum doesn't have.
1. 请先确定你是无法联网还是配置问题. ping www.baidu.com 如果是正常ping那可以看这个帖子完成配置 https://blog.csdn.net/weicuidi/articl ...
- ConcurrentHashMap源码解读一
最近在学习并发map的源码,如果由错误欢迎指出.这仅供我自己学习记录使用. 首先就先来说一下几个全局变量 private static final int MAXIMUM_CAPACITY = 1 & ...
- 【译】.NET 的新的动态检测分析
随着 Visual Studio 16.9 的发布,Visual Studio 中的检测分析变得更好用了.本文介绍我们新的动态分析工具.这个工具显示了函数被调用的确切次数,并且比我们以前的静态检测工具 ...