zoukankan      html  css  js  c++  java
  • Jmeter之BeanShell

    在Jmeter中各种分类组件中都有相应的BeanShell组件,这里简单的说明一下Beanshell的使用。

    一、概念

      BeanShell是一种符合Java语法的脚本语言,也有自己的一些特定语法

    二、内置变量

      Jmeter在它的Beanshell中内置了变量,用户可以通过这些变量与Jmeter进行交互,其中主要的变量及使用方法如下:

    1、log:

      在调试脚本的时候,可以将结果输出到日志,判断结果是否正确。使用log时会将日志信息保存到jmeter.log文件中,也可以打开log viewer实时查看日志信息。

      常用方法为:log.info("");

      注意在使用log.info输出信息的时候,如果变量的值是字符型,一定要在调用变量的时候,加双引号。

    2、vars:

      操作jmeter变量,常用的方法有:

      (1、vars.get("变量名"):从jmeter变量中获取值;

      (2、vars.put("变量名",变量):将beanshell中的变量值,复制给Jmeter变量,在Jmeter的后续使用中可以通过变量名调用。

    3、prev:

      获取前一个取样器的返回值,常用的方法有:

      (1、getResponseDataAsString():获取前一个取样器的响应信息;

      (2、getResponseCode():获取前一个取样器的响应Code;

    4、其他的变量ctx和props(操作属性)

    BeanShell断言:

    用户可以在jmeter- “beanShell断言”中自定义断言。自由灵活的用脚本实现自己的断言  
    beanShell断言接口介绍  
    在beanShell中直接可以调用的变量,无需加前缀。  
    1.log 打印日志 log.info(“在控制台打印日志”);  
    2.SampleResult 获取SampleResult对象,可以通过这个对象获取想要的信息  
    3.Response 获取Response对象,可以通过这个对象获取对应的信息  
    4.Failure 查看接口调用是否成功,如果返回false是成功的,true是失败的  
    5.FailureMessage 失败信息,没有设置的时候失败信息是空的。可以set这个信息  
    6.ResponseData 获取 response body,类型是byte[]  
    7.ResponseCode 返回接口code,成功是200  
    8.ResponseMessage 获取msg,成功是OK  
    9.ResponseHeaders 获取接口服务端返回的头部信息  
    10.RequestHeaders 获取客户端请求的头部信息  
    11.SampleLabel 获取接口请求的名称  
    12.SamplerData 获取请求的url和body  
    13.ctx 代表上下文信息,可以直接使用  
    14.vars 可以直接调用,将获取的数据变成jmeter变量(put),也可以获取用户自定义的变量(get)  
    eg:  
    1.在http sample下添加一个beanShell断言  
    2.编写script  
    import org.apache.jmeter.assertions;  
    import org.apache.jmeter.samplers.SampleResult;  
    import org.apache.jmeter.assertions.AssertionResult;  
    import org.json.*; 
    
    String response_data = prev.getResponseDataAsString();//获取接口返回的response数据  
    JSONObject data_obj = new JSONObject(response_data);//转换成json  
    //判断code是否等于0 如果等于0 再取里面的字段  
    String code = data_obj.get(“code”);  
    if(code.equals(“0”))  
    {  
    String user_name = data_obj.get(“data”).get(“user”).get(“userName”).toString();  
    //这里的my_name 是用户自定义的变量或者之前的接口返回获取的  
    if(user_name.equals(${my_name})){  
    Failure = false; //设置成false 表示接口跑成功,在结果树中sample是绿色的  
    //做后续动作  
    …….  
    }  
    else{  
    //做其他动作  
    }  
    }  
    else  
    {  
    Failure = true;//直接判断失败,表示接口跑失败,在结果树中sample是红色的  
    prev.setStopThread(true);//如果断言失败,后面的接口不需要再跑,直接暂停  
    } 

    三、一些简单的使用

    1、BeanShell响应断言

     

      因为用到了Json.jar(json-20180813.jar),所以需要先将json.jar导入。

    2、BeanShell Sampler

     

     例:

    import org.json.*;
    String response_data=prev.getResponseDataAsString();
    log.info("交易返回:"+response_data);
    JSONObject data_obj = new JSONObject(response_data);
    String code = data_obj.get("respCode").toString();
    log.info("code:"+code);
    if(code.equals("R200")){
        log.info("交易成功");
        FileWriter fstream = new FileWriter("D:\apache-jmeter-3.3\bin\result\idtxn_R200.csv",true);
        BufferedWriter out = new BufferedWriter(fstream);
        out.write(vars.get("idTxn")+"
    ");
        out.close();
        fstream.close();
        Failure = false;//设置成false 表示接口跑成功,在结果树中sample是绿色的 
    }else if(code.equals("R998")){
        log.info("交易失败");
        FileWriter fstream = new FileWriter("D:\apache-jmeter-3.3\bin\result\idtxn_R998.csv",true);
        BufferedWriter out = new BufferedWriter(fstream);
        out.write(vars.get("idTxn")+"
    ");
        out.close();
        fstream.close();
        Failure = true;
    }

     对上面例子进行优化:

    1.对写文件操作,添加公共方法,并使用相对路径,增加代码可移植性

    import org.json.*;
    source("\java\RecordIdTxn.java");//java文件放在bin目录下,可以使用相对路径,增加代码可移植性
    vars.put("resultPath",System.getProperty("user.dir")+"\result");//在bin目录下新建一个result目录,用于存放执行结果记录
    log.info("获取相对路劲:"+"${resultPath}");
    String response_data=prev.getResponseDataAsString();
    log.info("交易返回:"+response_data);
    JSONObject data_obj = new JSONObject(response_data);
    String code = data_obj.get("respCode").toString();
    log.info("code:"+code);
    if(code.equals("R200")){
        log.info("交易成功");
        //FileWriter fstream = new FileWriter("D:\apache-jmeter-3.3\bin\result\idtxn_R200.csv",true);
        //BufferedWriter out = new BufferedWriter(fstream);
        //out.write(vars.get("idTxn")+"
    ");
        //out.close();
        //fstream.close();
        RecordIdTxn("D:\apache-jmeter-3.3\bin\result\idtxn_R200.csv");//如果没有idtxn_R200.csv文件,会自动生成该文件
        Failure = false;//设置成false 表示接口跑成功,在结果树中sample是绿色的 
    }else if(code.equals("R998")){
        log.info("mcs system error...");
        RecordIdTxn("D:\apache-jmeter-3.3\bin\result\idtxn_R998.csv");
        Failure = true;
    }else{
        log.info("其他异常");
        RecordIdTxn("D:\apache-jmeter-3.3\bin\result\idtxn_other.csv");
        Failure=true;
    }
  • 相关阅读:
    有赞个性化推荐能力的演进与实践
    Doge.jpg 的背后是什么,你知道么?
    实操|如何将 Containerd 用作 Kubernetes runtime
    Linux 用键盘操作窗口
    Oracle中join left,join right,inner join,(+) 等
    sql之left join、right join、inner join的区别
    SQL中GROUP BY的用法
    Oracle CASE WHEN 用法介绍
    Oracle数据库面试题
    Oracle笔试题库之问答题篇-总共60道
  • 原文地址:https://www.cnblogs.com/wsy0202/p/11469207.html
Copyright © 2011-2022 走看看