一、什么是Bean Shell
二、Jmeter有哪些Bean Shell
5
种方式使用BeanShell样例
。样例
触发前,使用BeanShell进行加工处理。样例
触发后,使用BeanShell进行加工处理。断言
处理。监听器
。对象名
存在元素
功能
log
BeanShell Sampler
BeanShell PreProcessor
BeanShell PostProcessor
BeanShell Assertion
BeanShell Listener
日志信息输出
Label
BeanShell Sampler
样例
FileName
BeanShell Sampler
文件名
Parameters
BeanShell Sampler
参数
bsh.args
BeanShell Sampler
BeanShell脚本
SampleResult
BeanShell Sampler
BeanShell Assertion
BeanShell Listener
样例结果
ResponseCode
BeanShell Sampler
BeanShell Assertion
返回的状态码
ResponseMessage
BeanShell Sampler
BeanShell Assertion
返回信息
IsSucess
BeanShell Sampler
是否成功
ctx
BeanShell Sampler
BeanShell PreProcessor
BeanShell PostProcessor
BeanShell Assertion
BeanShell Listener
JMeter的上下文
vars
BeanShell Sampler,BeanShell PreProcessor
BeanShell PostProcessor
BeanShell Assertion
BeanShell Listener
变量操作
props
BeanShell Sampler
BeanShell PreProcessor
BeanShell PostProcessor
BeanShell Assertion
BeanShell Listener
JMeter属性
prev
BeanShell PreProcessor
BeanShell PostProcessor
BeanShell Listener
样例的前置
结果读取
sampler
BeanShell PreProcessor
BeanShell PostProcessor
当前样例
Response
BeanShell Assertion
返回的对象,读-写
Failure
BeanShell Assertion
是否失败
FailureMessage
BeanShell Assertion
失败信息
ResponseData
BeanShell Assertion
返回数据体,字节形式
ResponseHeader
BeanShell Assertion
返回信息头
RequestHeader
BeanShell Assertion
请求信息头
SampleLabel
BeanShell Assertion
样例名称
SampleData
BeanShell Assertion
发送至服务器的数据
SampleEvent
BeanShell Listener
读取当前样例的事件
有了上面的操作对象,可以在测试过程中,对测试的内容,进行更加详细的
加工
。
三、BeanShell的用法
在此介绍下BeanShell PreProcessor的用法,其它的beahshell可以类推。在此我们使用beahshell调用自己写的工具类,工具类实现了密码的加、解密功能:
1、在eclipse写好代码,然后把该类打成jar包(在类上点击右键->Export->jar file)
2、把jar包放到jmeter目录\apache-jmeter-2.13\lib\ext下
3、打开jmeter,添加一个http sampler(调用登录接口),在sampler下添加一个BeanShell PreProcessor
4、在beanshell PreProcessor中导入我们的jar包,调用里面的加、解密码方法,把结果保存在jmeter变量中,下面两个方法是beanshell中我们最常用到的:
vars.get(String paramStr):获得变量值
vars.put(String key,String value):,将数据存到jmeter变量中
5、把加密后的密码存到jmeter变量中,然后在http sampler中就可以通过${encode}进行使用了:
6、执行脚本:
四、Bean Shell常用内置变量
JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下:
log:写入信息到jmeber.log文件,使用方法:log.info(“This is log info!”);
ctx:该变量引用了当前线程的上下文
vars - (JMeterVariables):操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),它是测试用例与BeanShell交互的桥梁,常用方法:
a) vars.get(String key):从jmeter中获得变量值
b) vars.put(String key,String value):数据存到jmeter变量中
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
sampler - (Sampler):gives access to the current sampler
//当前时间
${__timeShift(,,,,)}
//增加一天
${__timeShift(,,P1d,,)}
//增加七天时间格式化
${__timeShift(yyyy-MM-dd,,P7d,,)}
//减少七天时间格式化
${__timeShift(yyyy-MM-dd,,-P20d,,)}
//当前时间时间格式化
${__timeShift(yyyy-MM-dd,,,,)}
//增加一H
${__timeShift(,,PT1H,,)}
${__timeShift(yyyy-MM-dd HH:mm:ss:SSS,,,,)}
${__timeShift(yyyy-MM-dd HH:mm:ss:SSS,,P1d,,)}
${__timeShift(yyyy-MM-dd HH:mm:ss:SSS,,PT1H,,)}
${__timeShift(yyyy-MM-dd HH:mm:ss:SSS,,PT10m,,)}
${__timeShift(yyyy-MM-dd HH:mm:ss:SSS,,PT20S,,)}
${__timeShift(yyyy-MM-dd HH:mm:ss:SSS,,P1dT1H10m20s,,)}
${__time(YMDHMS,)}
${__time(YYYYMMDHMS,)}
浮点时间戳转换为标准时间
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
//10位的秒级时间戳
long time1 = ${time}; //获取时间戳变量
String result1 = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" ).format( new Date(time1 * 1000 ));
log.info( "10位时间戳(秒)--->Date:" +result1);
//13位的毫秒级时间戳
//double time2 = 1515730332000d;
//String result2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(time2);
//System.out.println("13位数的时间戳(毫秒)--->Date:" + result2);
解析jsonlist
//利用beanshell获取到json响应,而后经过JSONObject 和JSONArray 将数组解析,遍历数组的length以后,提取参数值
//导入json包
import org.json.*;
//获取获取请求的返回值
String response_data = prev.getResponseDataAsString();
//日志打印获取请求的返回值
log.info(response_data);
//将String类型的返回值构形成JSONObject对象
JSONObject data_obj = new JSONObject(response_data);
//获取做为下一个请求post的参数值Province(两种方式)
//String Provincelist_str = data_obj.get("Province").toString();
JSONArray Provincelist_str = data_obj.getJSONArray( "Province" );
//log.info(Provincelist_str);
//获取Province数组的长度
int len = Provincelist_str.length();
String strlen = Integer.toString(len);
vars.put( "MessageNum" ,strlen);
log.info(strlen);
int i = 0 ;
for (;i < len;++i)
{
//获取 data[ i ] 数组对象
JSONObject jsonTemp = (JSONObject)Provincelist_str.getJSONObject(i);
switch (i)
{
case 0 :
//两种提取参数的写法
String NameItems = jsonTemp.getString( "Name" );
// String NameItems = jsonTemp.get("Name").toString();
// 两种打印参数的方法
// vars.put("Name_1", jsonTemp.getString("Name"));
vars.put( "Name_1" , NameItems);
log.info(NameItems);
}
}
手机扫一扫
移动阅读更方便
你可能感兴趣的文章