JMeter之BeanShell使用

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 

  1. Jmeter日志默认存放在%JMeter_HOME%\bin\JMeter.log, 脚本中使用log.info("日志")打印需要的日志信息 
    JMeter里面点击右上角可打开日志窗口 
     

 
 

  1. 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信息不会被显示。 

  2. 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);  

运行,查看结果 
 

 

posted @ 2017-11-28 11:59  春田花花同学会  阅读(248)  评论(0编辑  收藏  举报