JMeter BeanShell簡單使用

背景

使用JMeter進行接口測試,有時候需要編寫一些BeanShell腳本語言,或者利用BeanShell調用自己的工具類,來完成jmeter基本功能中無法實現的功能,下面將對BeanShell Sampler及其相關使用作一個簡要的介紹。

什么是BeanShell

  • BeanShell是一種完全符合Java語法規范的腳本語言,并且又擁有自己的一些語法和方法;
  • BeanShell是一種松散類型的腳本語言(這點和JS類似);
  • BeanShell是用Java寫成的,一個小型的、免費的、可以下載的、嵌入式的Java源代碼解釋器,具有對象腳本語言特性,非常精簡的解釋器jar文件大小為175k。
  • BeanShell執行標準Java語句和表達式,另外包括一些腳本命令和語法。

JMeter有哪些BeanShell

  • 定時器:  BeanShell Timer
  • 前置處理器:BeanShell PreProcessor
  • 采樣器:  BeanShell Sampler
  • 后置處理器:BeanShell PostProcessor
  • 斷言:   BeanShell斷言
  • 監聽器:  BeanShell Listener

BeanShell的用法

在此介紹下BeanShell PreProcessor的用法,其它的BeanShell可以類推。在此我們使用beahshell調用自己寫的工具類,工具類實現了簡單的加減功能。

1、在IDE寫好代碼,然后把該類打成jar包;

2、把jar包放到JMeter目錄/%JMETER_HOME%/lib/ext下

3、打開JMeter,添加一個Http Sampler(調用登錄接口),在Sampler下添加一個BeanShell PreProcessor

4、在BeanShell PreProcessor中導入我們的jar包,調用里面的加減方法,把結果保存在JMeter變量中,下面兩個方法是BeanShell中我們最常用到的:

  • vars.get(String paramStr):獲得變量值
  • vars.put(String key,String value):,將數據存到jmeter變量中
import com.pingan.ff.account.user.utils.*;

//加密
System.out.println("*****加密*****");
String password = "123123";
String encode = SecurityUtils.getKey(password);//調用工具類中的方法進行加密
System.out.println("Set my encode");
vars.put("encode",encode);//把值保存到jmeter變量encode中
String getEncode=vars.get("encode");
System.out.println("Get my encode: " + getEncode);

5、把加密后的密碼存到jmeter變量中,然后在http sampler中就可以通過${encode}進行使用了:

6、執行腳本

Bean Shell常用內置變量

JMeter在它的BeanShell中內置了變量,用戶可以通過這些變量與JMeter進行交互,其中主要的變量及其使用方法如下:

  • log:寫入信息到jmeber.log文件,使用方法:
log.info(“This is log info!”);
log.warn("This is a warn info!")
  • ctx:該變量引用了當前線程的上下文,使用方法可參考:org.apache.jmeter.threads.JMeterContext。

  • vars - (JMeterVariables):操作JMeter變量,這個變量實際引用了JMeter線程中的局部變量容器(本質上是Map),它是測試用例與BeanShell交互的橋梁,常用方法:

    • a) vars.get(String key):從jmeter中獲得變量值
    • b) vars.put(String key,String value):數據存到jmeter變量中
    • 更多方法可參考:org.apache.jmeter.threads.JMeterVariables
  • props - (JMeterProperties - class java.util.Properties):操作jmeter屬性,該變量引用了JMeter的配置信息,可以獲取Jmeter的屬性,它的使用方法與vars類似,但是只能put進去String類型的值,而不能是一個對象。對應于java.util.Properties。

    • a) props.get("START.HMS");  注:START.HMS為屬性名,在文件jmeter.properties中定義
    • b) props.put("PROP1","1234");
  • prev - (SampleResult):獲取前面的sample返回的信息,常用方法:

    • a) getResponseDataAsString():獲取響應信息
    • b) getResponseCode() :獲取響應code
    • 更多方法可參考:org.apache.jmeter.samplers.SampleResult
  • sampler - (Sampler):gives access to the current sampler

BeanShell常用的幾種場景和方法

一、操作變量:通過使用Bean shell內置對象vars可以對變量進行存取操作

a) vars.get("name"):從jmeter中獲得變量值

b) vars.put("key","value"):數據存到jmeter變量中

二、操作屬性:通過使用Bean shell內置對象props 可以對屬性進行存取操作

a) props.get("START.HMS");  注:START.HMS為屬性名,在文件jmeter.properties中定義

b) props.put("PROP1","1234");

三、自定義函數:

在BeanShell中,我們可以使用java語言自定義函數來處理特定的邏輯,結合BeanShell的內置對象進行變量的存取,方便我們進行測試提高腳本的靈活性。

示例:

1、在Test Plan中添加一個變量:hello = kitty

2、Debug sampler-1和Debug sampler-2什么都不處理,用來查詢對比beahshell處理前后的結果

3、BeanShell Sampler中的腳本如下:


4、運行結果:

Debug sampler-1中顯示:hello=kitty
BeanShell sampler中 返回結果為:success
Debug sampler-1中顯示:hello=world,jmeter=111111

四、引用外部java文件:

有沒有覺得上面(三)中自定義函數這樣的方式太麻煩并且也不美觀?而且如果我們已經有現成的java源文件或者class文件時,我們有沒有什么辦法直接在jemter中引用?這就是這部分要介紹的內容,直接上示例:

1、假如我有一個java 源文件,名為:Myclass.java,代碼如下:

package test;

public class Myclass {
    public int add(int a, int b) {
        return a + b;
    }
}

2、Bean Shell使用代碼如下:

在bean shel中通過source("代碼路徑")方法引入java,然后調用方法和java一樣,new一個class,再調用里面的add 方法。
  


3、運行結果:


五、引用外部class文件:

現在知道如何引用外部文件,有時候如果我們只有class文件怎么辦呢?其實在jmeter中也可以直接引用class文件,示例如下:

1、直接把上例中的java文件編譯成class文件,如何編譯請自行百度。

2、Bean Shell使用代碼如下:

用addClassPath("D:\")方法引入 class文件,在用import導入包及類,然后就可以像java一樣調用了


3、運行結果:


六、引用外部Jar包:

上面四、五介紹了如何引用外部java和class文件,如果文件比較多時我們可以把它們打成一個jar包然后在jemter中調用,具體如何使用可以看我上一篇有介紹:Jmeter之Bean shell使用(一)。

在這里想補充一點的是jmeter中引入jar的方法:

1、上一篇中已使用過的:把jar包放到jmeter目錄\apache-jmeter-2.13\lib\ext下

2、在Test Plan的右側面板最下方直接添加需要引用的jar包,如下圖:


七、其它用法:

1、在Test Plan中定義如下三個變量:


2、Bean Shell可腳本如下:

a、bean shell可以接受傳入參數,如下圖:{u1}{u2} ${u3}

b、參數可以通過bsh.args[]按順序提取

c、bean shell提供了一個內置變量Parameters,來保存參數的集合
  

  

3、運行結果:


下圖中1輸入的這兩句設置:

ResponseCode = 500;
ResponseMessage = "This is a test";

下圖中2輸入的這兩句設置:

log.info(Parameters);

log.info(Label);

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容