Jmeter之Bean shell使用

一、什么是Bean Shell

  • BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法;
  • BeanShell是一种松散类型的脚本语言(这点和JS类似);
  • BeanShell是用Java写成的,一个小型的、免费的、可以下载的、嵌入式的Java源代码解释器,具有对象脚本语言特性,非常精简的解释器jar文件大小为175k。
  • BeanShell执行标准Java语句和表达式,另外包括一些脚本命令和语法。

二、Jmeter有哪些Bean Shell

  • 定时器:  BeanShell Timer
  • 前置处理器:BeanShell PreProcessor
  • 采样器:  BeanShell Sampler
  • 后置处理器:BeanShell PostProcessor
  • 断言:   BeanShell断言
  • 监听器:  BeanShell Listener
三、BeanShell内置对象

其中,每个BeanShell元件都有自己的内置对象,在元件上也有对应说明,当前元件的内置对象有哪些,比如BeanShell Sampler元件的底部有提示该元件有哪些内置对象。

jemter BeanShell执行Java代码 jmeter beanshell if_java

常用的内置对象

log

记录日志,Jmeter使用log4j记录日志,一般使用的比较多的是log.info()、log.error(),打印的日志会记录到bin/jmeter.log文件

props

操作Jmeter属性,即jmeter.properties文件的配置

props.get(“https.use.cached.ssl.context”): 获取对应的属性值

props.put(“https.use.cached.ssl.context”, false): 保存数据到Jmeter属性中,如果属性不存在就创建

vars

是类JMeterVariables的对象,具体内部方法使用,请看 操作Jmeter变量,需要注意Jmeter变量是在线程启动时,拷贝到线程的,类似线程的局部变量,所以一个线程更新了变量,不会影响到另一个线程

vars.get(“name”): 从线程中获得变量值

vars.put(“key”, “value”): 保存数据到线程中,如果变量不存在会创建

ctx

是类JMeterContext的对象,保存线程的上下文,该对象不是线程安全的,建议在单线程时使用,具体内部方法使用,请看

prev

是类SampleResult的对象,保存前一个请求的信息,具体内部方法使用,请看 注意 根据作用域和执行顺序 可以知道,元件有在采样器前执行的,有在采样器后执行的,对于在采样器前执行的,prev表示的是前一个请求的信息,而对于在采样器后执行的,prev表示的当前请求的信息!

data

类型是byte[],即字节数组, 当前请求的响应数据,可以用String str = new String(data, “utf-8”)转成字符串再打印出来

操作变量:通过使用Bean shell内置对象vars可以对变量进行存取操作

a) vars.get(“name”):从jmeter中获得变量值

b) vars.put(“key”,“value”):数据存到jmeter变量中

操作属性:通过使用Bean shell内置对象props 可以对属性进行存取操作

a) props.get(“START.HMS”);  注:START.HMS为属性名,在文件jmeter.properties中定义

b) props.put(“PROP1”,“1234”);

自定义函数:

在BeanShell中,我们可以使用java语言自定义函数来处理特定的逻辑,结合BeanShell的内置对象进行变量的存取,方便我们进行测试提高脚本的灵活性。

示例:

1、在Test Plan中添加一个变量:hello = kitty

jemter BeanShell执行Java代码 jmeter beanshell if_jmeter_02

2、Debug sampler-1和Debug sampler-2什么都不处理,用来查询对比beahshell处理前后的结果

3、BeanShell Sampler中的脚本如下:

jemter BeanShell执行Java代码 jmeter beanshell if_内置对象_03

4、运行结果:

  • Debug sampler-1中显示:hello=kitty
  • BeanShell sampler中 返回结果为:success
  • Debug sampler-1中显示:hello=world,jmeter=111111

jemter BeanShell执行Java代码 jmeter beanshell if_jmeter_04

jemter BeanShell执行Java代码 jmeter beanshell if_jmeter_05

jemter BeanShell执行Java代码 jmeter beanshell if_Shell_06

引用外部java文件:

自定义函数这样的方式太麻烦并且也不美观?而且如果我们已经有现成的java源文件或者class文件时,我们有没有什么办法直接在jemter中引用?这就是这部分要介绍的内容,直接上示例:

1、假如我有一个java 源文件,名为:Myclass.java,代码如下:

package test;

public class Myclass
{
    public int add(int a, int b)
    {
        return a + b;
    }    
}

2、Bean Shell使用代码如下:

在bean shel中通过source(“代码路径”)方法引入java,然后调用方法和java一样,new一个class,再调用里面的add 方法。

jemter BeanShell执行Java代码 jmeter beanshell if_Shell_07

3、运行结果:

jemter BeanShell执行Java代码 jmeter beanshell if_内置对象_08

引用外部class文件:

现在知道如何引用外部文件,有时候如果我们只有class文件怎么办呢?其实在jmeter中也可以直接引用class文件,示例如下:

1、直接把上例中的java文件编译成class文件,如何编译请自行百度。

2、Bean Shell使用代码如下:

用addClassPath(“D:\”)方法引入 class文件,在用import导入包及类,然后就可以像java一样调用了

jemter BeanShell执行Java代码 jmeter beanshell if_jmeter_09

3、运行结果:

jemter BeanShell执行Java代码 jmeter beanshell if_Shell_10

引用外部Jar包:

上面四、五介绍了如何引用外部java和class文件,如果文件比较多时我们可以把它们打成一个jar包然后在jemter中调用。

在这里想补充一点的是jmeter中引入jar的方法:

1、上一篇中已使用过的:把jar包放到jmeter目录\apache-jmeter-5.3\lib\ext下

2、在Test Plan的右侧面板最下方直接添加需要引用的jar包,如下图:

jemter BeanShell执行Java代码 jmeter beanshell if_jmeter_11

七、其它用法:

1、在Test Plan中定义如下三个变量:

jemter BeanShell执行Java代码 jmeter beanshell if_内置对象_12

2、Bean Shell可脚本如下:

a、bean shell可以接受传入参数,如下图:${u1} ${u2} ${u3}

b、参数可以通过bsh.args[]按顺序提取

c、bean shell提供了一个内置变量Parameters,来保存参数的集合

jemter BeanShell执行Java代码 jmeter beanshell if_内置对象_13

3、运行结果:

jemter BeanShell执行Java代码 jmeter beanshell if_jmeter_14

下图中1输入的这两句设置:

ResponseCode = 500;
ResponseMessage = “This is a test”;

下图中2输入的这两句设置:

log.info(Parameters);

log.info(Label);

jemter BeanShell执行Java代码 jmeter beanshell if_java_15