赞
踩
在JMeter中开发自定义函数是一个常见的需求,允许我们扩展JMeter的功能以适应特定的测试需求。自定义函数可以用来处理数据,生成输出,或者执行特定的运算。通过JMeter函数二次开发可以帮我们解决实际测试过程中造数难的问题
用过JMeter的同学对JMeter内置的函数助手不陌生,使用函数助手可以帮我们非常高效生成一些数据满足我们的接口测试的要求。比如我们想要生成随机的手机号码,可以使用RandomString函数,具体做法:设置手机号码前缀区段(比如189、138、177)这些,然后再使用RandomString函数帮我们生成后8位的随机数,然后拼接成手机号码:
但是有时候测试需求中的手机号码区段并不是固定的,如果想要手机号码区段也能够满足随机的要求(并且符合运营商开放的区段),又或者是生成合法的随机身份证号码,这类需求该如何实现呢?JMeter的内置函数满足不了,此时我们可以对JMeter函数进行二次开发。
自定义函数必须继承于JMeter的AbstractFunction类
并需要重写该类的4个方法:
execute,函数执行逻辑,必需,自定义函数的核心逻辑,并返回经过处理后的内容
getReferenceKey,函数名称,必需,返回一个字符串,表示在JMeter中使用自定义函数的函数名,一般以双下划线开头,如__IDNumber
setParameters,设置函数接收参数值,如果自定义函数有参数,用于接收调用时传递过来的参数,注意使用时,字符串参数不要加双引号
getArgumentDesc,函数参数描述,如果自定义函数有参数,用于返回函数参数说明
1、创建Java Maven项目
选择从maven-archetype-quickstart模板创建
在pom.xml中添加依赖ApacheJMeter_java、ApacheJMeter_core,注意与使用的JMeter版本保持一致
<!--引入JMeter依赖-->
<dependency>
<groupId>org.apache.jmeter</groupId>
<artifactId>ApacheJMeter_java</artifactId>
<version>5.4.3</version>
</dependency>
<dependency>
<groupId>org.apache.jmeter</groupId>
<artifactId>ApacheJMeter_core</artifactId>
<version>5.4.3</version>
</dependency>
2、自定义函数类继承AbstractFunction
创建functions子包,在已有包中,添加一个名为functions子包
添加自定义函数, 在functions子包下,添加自定义函数类,并继承AbstractFunction类,并实现该类的4个抽象方法:
在execute方法中添加插件逻辑
在getReferenceKey方法中返回自定义名称函数
如果函数有参数,在setParameters方法获取传递过来的参数
如果函数有参数,在getArgumentDesc中描述接收的参数
public class IDNumber extends AbstractFunction { //参数 private String area; /** * 函数执行逻辑,自定义函数的核心逻辑,并返回经过处理后的内容 * * @param sampleResult * @param sampler * @return * @throws InvalidVariableException */ public String execute(SampleResult sampleResult, Sampler sampler) { //调用身份证生成逻辑,使用了第三方的业务逻辑 String idNumber = IdNumberGenerateUtil.generate(area); return idNumber; } /** * 设置函数接收参数值,接收JMeter界面用户传递过来的参数 * * @param parameters * @throws InvalidVariableException */ public void setParameters(Collection<CompoundVariable> parameters) throws InvalidVariableException { //检查参数个数 checkParameterCount(parameters, 0, 1); //获取参数 Object[] params = parameters.toArray(); //获取区域 if (params.length > 0) { CompoundVariable cvArea = (CompoundVariable) params[0]; this.area = cvArea.execute(); } } /** * 函数名称,JMeter界面函数的名称 * * @return */ public String getReferenceKey() { return "__IDNumber"; } /** * 函数参数描述,JMeter界面显示的参数说明 * * @return */ public List<String> getArgumentDesc() { List<String> desc = new ArrayList<String>(); desc.add("城市名"); return desc; } }
3、将代码打包成jar文件
方式一:项目没有第三方依赖,直接使用右侧Maven菜单的Lifecyle->package打包,直接使用jar包
方式二:项目有第三方依赖,需要按照如下步骤操作:
在pom.xml文件的build->plugins配置节下添加如下内容
<build> <plugins> <!--将依赖打包到jar包--> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-assembly-plugin</artifactId> <version>2.5.5</version> <configuration> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> </descriptorRefs> </configuration> </plugin> <plugin> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.1</version> <configuration> <source>1.8</source> <target>1.8</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build>
使用右侧Maven菜单的Plugins->assembly->assemble:assembly打包,会生成一个带-jar-with-dependencies后缀的jar包,直接使用此xxxx–jar-with-dependencies.jar包
将上一步的xxx.jar文件拷贝到JMeter安装目录的lib/ext目录中
重启JMeter,打开函数助手即可使用自定义的函数:
行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入群: 759968159,里面有各种测试开发资料和技术可以一起交流哦。
最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取 【保证100%免费】
我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。