1.什么是BeanShell断言?
BeanShell断言可以使用beanshell脚本来执行断言检查,可以用于更复杂的个性化需求,使用更灵活,功能更强大,但是要能够熟练使用beanshell脚本。
在这里除了可以使用beanshell的内置变量外,主要通过Failure和FailureMessage来设置断言结果。
Failure = false;-----表示断言成功,
FailureMessage = "……"; ----自定义的成功信息
Failure = true;-----表示断言失败,
FailureMessage = "……";-----自定义的失败信息。
org.json.jar下载地址
链接: https://pan.baidu.com/s/1bIwY5N81JVx_Z_aM0UP76A 提取码: 6jcz
BeanShell断言界面如下:

Name:断言的名字(可以用一个比较容易理解和分辨的名称)
Comments:注释(对这个断言进行一个解释,备注)
Reset bsh.interpreter before each call:在每次调用Bean Shell之前重置bsh.interpreter类(bsh.interpreter是Bean Shell脚本语言的一种类,也可以理解为一种解析器)
Parameters(String Parameters and String []bsh.args):String参数(String []bsh.args是主类main函数的形式参数,是一个String 对象数组,可以用来获取命令行用户输入进去的参数)
Script file:脚本文件(可以填入脚本文件路径)
Script(see below for variables that are defined):参照下文定义的变量(使脚本文件参照定义的变量来运行)
2.示例
添加断言-BeanShell断言
添加监听器-断言结果
import org.json.*;
//获取上一个请求的返回值
String response = prev.getResponseDataAsString();
//将返回值转换为json
JSONObject responseJson = new JSONObject(response);
//获取响应中的responseMessage
String message = responseJson.getString("message");
log.info("message的值:" + message);
//获得内置变量$recnum的值
String recnum = vars.get("recnum");
if (recnum.equals("310000026") || recnum.equals("310000028")) {
if (message.equals("同一学员培训时段已存在")) {
Failure = false;
} else {
Failure = true;//失败
FailureMessage = "message:" + message;//失败原因
}
} else {
if ("".equals(message)) {
Failure = false;
} else {
Failure = true;//失败
FailureMessage = "message:" + message;//失败原因
}
}
log.info("recnum:" + recnum+"*Failure"+Failure);
断言结果
3.常用内置变量
JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下:
log:用来记录日志文件,写入到jmeber.log文件,使用方法:log.info(“This is log info!”);
ctx(JmeterContext)通过它来访问context,使用方法可参考:org.apache.jmeter.threads.JMeterContext。
vars - (JMeterVariables):操作jmeter变量,提供读取/写入访问变量的方法。这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),它是测试用例与BeanShell交互的桥梁,常用方法:
a) vars.get(String key):从jmeter中获得变量值
b) vars.put(String key,String value):数据存到jmeter变量中
c) vars.putObject("OBJ1",new Object());
更多方法可参考:org.apache.jmeter.threads.JMeterVariables
props - (JMeterProperties - class Java.util.Properties):操作jmeter属性,该变量引用了JMeter的配置信息,可以获取Jmeter的属性,它的使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。对应于java.util.Properties。
a) props.get("START.HMS"); 注:START.HMS为属性名,在文件jmeter.properties中定义
b) props.put("PROP1","1234");
prev - (SampleResult):获取前面的sample采样的结果,常用方法:
a) getResponseDataAsString():获取响应信息
b) getResponseCode() :获取响应code
更多方法可参考:org.apache.jmeter.samplers.SampleResult