JMeter(5) JMeter之BeanShell使用

作者: ss酱 | 来源:发表于2016-09-01 18:47 被阅读2236次

    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里面点击右上角可打开日志窗口

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

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

    运行,查看结果


    参考链接

    Jmeter接口文档:
    https://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html
    Java数据类型:
    http://webcache.googleusercontent.com/search?q=cache:SgdVfka7SZIJ:www.runoob.com/java/java-basic-datatypes.html+&cd=1&hl=zh-CN&ct=clnk&gl=ph

    相关文章

      网友评论

        本文标题:JMeter(5) JMeter之BeanShell使用

        本文链接:https://www.haomeiwen.com/subject/vysvsttx.html