您好,登錄后才能下訂單哦!
本篇文章為大家展示了使用jmeter如何實現函數自定義,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
1、打開IntelliJ IDEA,新建一個Maven項目
2、導入Jmeter的依賴包
在idea中導入jmeter下的ApacheJMeter_core.jar和ApacheJMeter_functions.jar依賴包
3、添加java自定義函數
要實現擴展JMeter function,主要有兩點:
實現function的類的package聲明必須包含".functions"需要繼承org.apache.jmeter.functions.AbstractFunction,并且實現相應的方法。
擴展AbstractFunction類
package org.apache.jmeter.functions;import java.util.Collection;import java.util.LinkedList;import java.util.List;import org.apache.jmeter.engine.util.CompoundVariable;import org.apache.jmeter.samplers.SampleResult;import org.apache.jmeter.samplers.Sampler;import org.apache.jmeter.util.JMeterUtils;public class MyFunction extends AbstractFunction {//自定義function的描述 private static final List<String> desc = new LinkedList<>(); //function名稱 private static final String KEY = "__MyFunction"; static { desc.add("systemnum"); desc.add("sizenum"); } private CompoundVariable systemnum; private CompoundVariable sizenum;// 函數的邏輯執行主體 /** {@inheritDoc} */ @Override public String execute(SampleResult previousResult, Sampler currentSampler) throws InvalidVariableException { long num = Long.valueOf(systemnum.execute()); int size = Integer.valueOf(sizenum.execute()); String str = Long.toHexString(num);; while(str.length()<size){ str = "0" + str; } return str; }// 用來接收和處理GUI界面的參數的傳值 /** {@inheritDoc} */ @Override public void setParameters(Collection<CompoundVariable> parameters) throws InvalidVariableException { checkParameterCount(parameters, 2); Object[] values = parameters.toArray(); systemnum = (CompoundVariable) values[0]; sizenum = (CompoundVariable) values[1]; }// 用來定義函數的名稱,把自定義的內容顯示在函數對話框中 /** {@inheritDoc} */ @Override public String getReferenceKey() { return KEY; }// 用來設置GUI界面的函數對話框,把自己定義的參數給顯示在jmeter的GUI界面上 /** {@inheritDoc} */ @Override public List<String> getArgumentDesc() { return desc; }}
4、將自定義函數編譯成.class文件*
由于Maven默認用的是JDK1.5去編譯,所以使用JDK1.8版本進行編譯的時候報錯了。
在pom.xml中添加以下代碼,然后進行編譯(Build->Build project),編譯成功
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.5.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build>
5、將.class文件添加到ApacheJMeter_functions.jar中
使用WinRAR打開ApacheJMeter_functions.jar,進入\org\apache\jmeter\functions目錄下
點擊【添加】,選擇編譯好的.class文件
6、
重新啟動jmeter
打開函數助手
自定義函數添加成功
上述內容就是使用jmeter如何實現函數自定義,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。