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

  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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容

  • Jmeter Bean shell 最近在学习使用 Jmeter 来进行接口测试,使用 Jmeter 提供的基础方...
    csmijo阅读 2,922评论 0 5
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,579评论 18 139
  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 4,925评论 1 13
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,717评论 6 342
  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 4,953评论 0 6