Jmeter - BeanShell常用内置变量及脚本开发

什么是BeanShell?

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

BeanShell内置变量

BeanShell 脚本中不用定义,可以直接使用的变量,常用的内置变量和方法如下:

  • Log:写日志到控制台,如 log.info(*****)

  • vars: 操作Jmeter变量
    1、vars.get(“goodsid”); 从jemter中获取 ${goodid} 变量
    2、vars.put(“goodsid”, 20); 将20保存在 ${goodid} 变量

  • prev:获取前面 smpler返回的信息
    1、getResponseDataAsString(); 获取响应信息
    2、getResponseCode(); 获取相应code码

  • props:操作jmeter属性,使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。
     a) props.get(“START.HMS”); 
     注:START.HMS为属性名,在文件jmeter.properties中定义
     b) props.put(“PROP1”,“1234”);
     *props可用于线程组之间参数传递,即全局变量。
     props.put(“var_name”,“var_value”);存 props.get(“var_name”);取

下面我们按照上方的内置变量,来实际操作一下,我们配置如下代码,运行脚本

// 打印接口响应数据
log.info("用户列表的响应数据为" + prev.getResponseDataAsString());

// 打印响应状态码
log.info("结果响应状态码为" + prev.getResponseCode());

JMeter日志概览
JMeter与Java程序一样,会记录事件日志,日志文件保存在bin目录中,名称为jmeter.log。当然,我们也可以在面板中直接察看日志,点击右上角黄色标志物可以打开日志面板,再次点击收起。
Jmeter - BeanShell常用内置变量及脚本开发_第1张图片
另外,JMeter可以很方便地设置日志输出级别:
Jmeter - BeanShell常用内置变量及脚本开发_第2张图片
可见,通过JMeter日志中看到输出的数据,说明我们的脚本调试成功了。Jmeter - BeanShell常用内置变量及脚本开发_第3张图片
BeanSheel 实战,脚本开发
需求:

  1. 调用获取商品sku的接口
  2. 拿到商品sku之后,我们判断商品库存值是否大于500,如果大于500,则调用下单接口,购买5个商品

我们来编写如下脚本


// 打印接口响应数据
log.info("商品sku库存接口的响应数据为" + prev.getResponseDataAsString());

// 获取商品库存值
String stock = vars.get("stock");

// 因为获取到的库存值是 string 类型,我们将它转换成 Int
int iStork = Integer.parseInt(stock);


// 判断库存值是否大于500,大于500,则购买10件商品
if (iStork > 500){
	
	vars.put("buynum", "10");
	}else{
	// 否则购买5件
	vars.put("buynum", "5");	
		}

下面我们把脚本放到BeanShell后置处理器中,我们可以看到库存大于500,下单的商品数量为10,脚本调试成功了~Jmeter - BeanShell常用内置变量及脚本开发_第4张图片

你可能感兴趣的:(Jmeter性能测试,jmeter,java,servlet)