新手区 性能测试 jmeter 的 beanshell 脚本的 2 个常用例子

大话性能 · 2018年09月25日 · 最后由 大话性能 回复于 2018年09月26日 · 2161 次阅读

在利用 jmeter 进行接口测试或者性能测试的时候,我们需要处理一些复杂的请求,此时就需要利用 beanshell 脚本了,BeanShell 是一种完全符合 Java 语法规范的脚本语言,并且又拥有自己的一些语法和方法,所以它和 java 是可以无缝衔接的。beanshell 由于内置了一些特有的变量,没法在一些集成代码工具上去调试。今天就和大家分享下常用的 2 个代码例子,大家可以直接拿来稍微修改下就可以使用。

更多性能测试实战好文章干货分享,请关注微信公众号大话性能

http://dwz.cn/0UWb6GVc

Bean Shell 内置变量大全

首先大家需要掌握 bean shell 本身自带的一些内置变量和一些方法。JMeter 在其 BeanShell 中内置了变量,用户是通过这些变量与 JMeter 进行交互。

1.log 打印日志写入信息到jmeber.log文件

2.SampleResult 获取SampleResult对象能通过这个对象获取想要的信息

3.Response 获取Response对象能通过这个对象获取响应信息

4.Failure 查看接口调使用能否成功假如返回false是成功的true是失败的

5.FailureMessage 失败信息没有设置的时候失败信息是空的能set这个信息

6.ResponseData 获取response body类型是byte[]

7.ResponseCode 返回接口code成功是200

8.ResponseMessage 获取msg成功是OK

9.ResponseHeaders 获取接口服务端返回的头部信息

10.RequestHeaders 获取用户端请求的头部信息

11.SampleLabel 获取接口请求的名称

12.SamplerData 获取请求的url和body

13.ctx 代表上下文信息能直接用

14.vars即JMeterVariables操作jmeter变量这个变量实际引用了JMeter线程中的局部变量容器本质上是Map),常用方法

a) vars.get(String key)从jmeter中获得变量值

b) vars.put(String keyString value)数据存到jmeter变量中

15.prev 获取前面的sample返回的信息常用方法

a) getResponseDataAsString()获取响应信息

b) getResponseCode() 获取响应code

在写代码的时候,可以直接用上面的变量和方法,参考如下例子。

例子 1

使用 jmeter 的 bean shell preprocessor,调用自己写的工具类,实现请求的处理。

步骤如下:

1、 用 eclipse 把自己写的 java 代码打包成 jar。

2、 把自定义的 JAR 包放入到 jmeter 的/lib/ext 目录下。

3、 重启 jmeter,开始写 beanshell 脚本。

具体代码:

import net.sf.json.JSONObject;
import ht.test.PluginTest.*;


         //请求体,mac做了参数化

       String body1 = "{\"ID\":123456,\"RPCMethod\":\"BootInitiation\",\"PROTVersion\":\"1.0.0\",\"MAC\":\"${MAC}\"}";


        int bodylenth1 = body1.length();
        byte[] lenBytePrefix1 = utils.getBytesOfBig(bodylenth1);
        //System.out.println(utils.bytesToHexString(lenBytePrefix2));

        //System.out.println(utils.bytesToHexString(body2.getBytes()));
        String postdata2 = utils.bytesToHexString(lenBytePrefix1) +
                       utils.bytesToHexString(body1.getBytes());

        String postdata3 = postdata2.replaceAll(" ", "");
        //System.out.println("binary data is :" + postdata3);

        vars.put("postrequest",postdata3);
        //System.out.println(vars.get("postrequest"));

注意:在用 system.out.println 调试完成后,最终需要注射掉,否则在真正压测的时候会影响压测客户端的性能。

例子 2

使用 beanshell 的 assertion 断言,完成一些响应结果判断的的操作。

一个比较完整的代码框架如下,大家依葫芦画瓢就行了。

import org.apache.jmeter.assertions; 
import org.apache.jmeter.samplers.SampleResult; 
import org.apache.jmeter.assertions.AssertionResult; 
import org.json.*;



String response_data = prev.getResponseDataAsString();//获取接口返回的response数据 

JSONObject data_obj = new JSONObject(response_data);//转换成json 

//判断code是否等于0 如果等于0 再取里面的字段 

String code = data_obj.get(code); 

if(code.equals(0)) 

{ 

String user_name = data_obj.get(data).get(user).get(userName).toString(); 

//这里的my_name 是用户自定义的变量或者之前的接口返回获取的 

    if(user_name.equals(${my_name})){ 

    Failure = false; //设置成false 表示接口跑成功,在结果树中sample是绿色的 

//做后续动作 

     ……. 

    } 

    else{ 

      //做其他动作 

    } 

} 

else 

{ 

Failure = true;//直接判断失败,表示接口跑失败,在结果树中sample是红色的 

prev.setStopThread(true);//如果断言失败,后面的接口不需要再跑,直接暂停 

}

技巧

假如我们希望线程之间共享一个变量,可以利用 BeanShell 来完成。

JMeter 中线程间共享变量可以通过定义属性值来完成,JMeter 启动时会读取一些属性文件,比如 jmeter.properties、user.properties,这些属性值是可以修改的,通过 BeanShell 可以对其进行更改。通过 props.put() 来修改属性,props.get() 来获取属性。

大家可持续关注大话性能公众号,不断学习测试实战技能和高薪岗位内推。

共收到 2 条回复 时间 点赞

好记性不如烂笔头,beanshell 中常用的 2 个例子,相信你也会用到

快来微信公众号大话性能学习更多好东西

wink_yang Jmeter 之 Bean shell 使用 中提及了此贴 05月08日 15:31
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册