JMeter之BeanShell使用

发表于:2017-12-15 11:47

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:牵牛花的春天    来源:博客园

  BeanShell介绍
  BeanShell是用Java写成的,一个小型的、免费的、可以下载的、嵌入式的Java源代码解释器,具有对象脚本语言特性。本篇只记录一下基本的使用。有以下五个组件:
  · Beanshell Sampler
  · Beanshell PreProcessor
  · Beanshell PostProcessor
  · Beanshell Assertion
  · __Beanshell Function
  常用变量
  1、vars:实际引用jmeter线程的局部变量,连通jmeter和beanshell
    vars.get(String key) //获取变量值
    vars.put(String key, String value)//存储value到变量key
  2、log: 写入信息到日志中,log.info("")
  3、prev: 获取前一个sample的响应
    getResponseDataAsString()
    getResponseCode()
  4、props: class java.util.Properties
  变量属性赋值给变量props.put("some_variable",vars.get("some_variable"))
  Jmeter Log
  Jmeter日志默认存放在%JMeter_HOME%\bin\JMeter.log, 脚本中使用log.info("日志")打印需要的日志信息
  JMeter里面点击右上角可打开日志窗口
  Jmeter使用Log4j日志组件输出日志,%JMETER_HOME%\bin\jmeter.properties\log_level.jmeter用于控制Jmeter日志记录级别。可以设置以下日志级别:FATAL_ERROR, ERROR, WARN, INFO,DEBUG,其中FATAL_ERROR打印日志最少,DEBUG级别日志最详细。
  log_level.jmeter=INFO //INFO级别,只有等于及高于这个级别的才打印日志,如果配置为INFO只显示INFO, WARN, ERROR的log信息,而DEBUG信息不会被显示。
  jmeter可以为不同的模块设置不同的日志级别,如下:
  Beanshell PreProcessor
  预先处理,生成一段随机字符串并赋值给变量,同个线程组内通过${变量名}读取
import java.util.Random;
String random_len(int length) {
chars = "ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz";
int string_length = 8;
randomstring ="";
for (int i=0; i<string_length; i++) {
Random randomGenerator = new Random();
int randomInt = randomGenerator.nextInt(chars.length());
randomstring += chars.substring(randomInt,randomInt+1);
}
return randomstring;
}
log.info(random_len(8));
log.info(random_len(16));
vars.put("random_8", random_len(8));
vars.put("random_16", random_len(16));
  Beanshell Assertion
  断言结果字段是Failure=true/false; 运行结果需要打印出的信息写在FailureMessage = "XXXX";
  eg1. 断言uid=预期的值
if(!"${uid}".equals("774170"))
{
Failure=true;
FailureMessage = "error, check";
}
else
{
FailureMessage = "ok!";
}
  实例: 断言返回的数据类型
  先把用到的jar包org.json放在jmeter/lib文件下,并在测试计划中导入
  思路
function(standardData,respData){
standardJson =getJson();
respJson = getJson(respData);
循环N次{
if(standardJson.getType == respJson.getType); //逐个判断json的字段类型是否符合标准
}
Beanshell代码
import org.json.JSONArray;
import org.json.JSONObject;
import java.util.Iterator;
import java.util.Map;
/**
* Created by Susie on 2016/8/25.
*/
public static String equalsJson(JSONObject standardJson, JSONObject responseJson) {//输入两个json,判断第一个里面的所有字段在第二个中的类型是否相同
String err_message = "";
Iterator it = standardJson.keys(); // 储存所有要验证的Key
while (it.hasNext()) {
String key = (String) it.next();
String thisKetType = standardJson.get(key).getClass().getName(); //获取当前Key的标准type
log.info("standard Key = " + key + ", Value = " + standardJson.get(key) + ", Type = " + thisKetType);
if(responseJson.isNull(key)){ //判断response中有无当前Key
log1 = "------ExistError: " + key + " Not found.";
log.info("!!Failed: " + log1);
err_message = (err_message + "\n" + log1);
}
else{  //response中找到Key了,再判断type
String respKetType = responseJson.get(key).getClass().getName(); //获取响应的字段类型
if(respKetType.equals(thisKetType)){
log.info("Passed.");
if(thisKetType.equals("org.json.JSONObject")){ //object类型的字段继续往内层判断
err_message += equalsJson(standardJson.getJSONObject(key), responseJson.getJSONObject(key)); //!!进入递归时,保存当前错误信息
}
} else {
String log1 = "------TypeError : " + key + " is " + respKetType + " (should be " + thisKetType + ")";
log.info("!!Failed: " + log1);
err_message = (err_message + "\n" + log1);
}
}
}
return err_message;
}
public static Boolean respTypeAssertion(String standardData) { //输入标准响应,转为json并调用比较函数,得到断言结果
String resData = prev.getResponseDataAsString(); //获取前一个请求的响应
log.info("res: " + resData);
JSONObject standardJson = new JSONObject(standardData);
JSONObject jo = new JSONObject(resData);
JSONObject responseJson = jo.getJSONObject("data");
log.info("------------------------Beanshell assertion7-------------");
String message = equalsJson(standardJson, responseJson);
log.info("------------------------ResultMessage--------------------" + message);
if(message == ""){    //如果错误信息是空,说明断言结果通过
FailureMessage = "Pass!";
return true;
}
else{   //有错误信息打印到断言结果里面
Failure=true;
FailureMessage = "Type Error!" + message;
}
return false;
}
//-----------------------------------------------
String standardData = "{'uid':'123','phone':'13580478329','has_password':true,'location':{'province':true,'city':'\u6c55\u5934\u5e02'},'cpma':null}";
respTypeAssertion(standardData);
  运行,查看结果

上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号