JMeter 常见函数讲解

当使用JMeter进行性能测试或负载测试时,函数是一个非常有用的工具,可以帮助生成动态的测试数据或处理测试结果。

下面是一些常用的JMeter函数的详细讲解和并列示例:

1、__threadNum:

返回当前线程的编号。可以在测试过程中用于生成唯一的标识符或动态数据。

复制代码
生成唯一的用户名:${__threadNum}-user
动态参数化请求路径:/users/${__threadNum}

2、__time:

返回当前的时间戳(以毫秒为单位)。可以用于在测试中记录时间或生成动态的时间戳。

python 复制代码
计算请求的响应时间:${__time(,responseTime)}
创建具有时间戳的唯一订单号:order-${__time(ddMMyyHHmmss)}

3、__property:

用于获取或设置JMeter属性值。可以在测试计划中设置自定义属性,并在测试中使用。

python 复制代码
获取自定义属性值:${__property(myProperty)}
设置自定义属性值:${__setProperty(myProperty,newValue)}

4、__P:

用于获取或设置用户定义的参数。可以在执行测试时通过命令行参数或JMeter属性设置参数的值。

复制代码
获取用户定义的参数值:${__P(myParam)}
设置用户定义的参数值:${__P(myParam,newValue)}

5、__Random:

生成一个随机数。可以指定生成随机数的范围和变量名称。

python 复制代码
生成随机数并存储到变量:${__Random(1,100,randomNumber)}
在请求参数中使用随机数:${randomNumber}

6、__groovy:

执行Groovy脚本。Groovy是一种强大的脚本语言,可以用于在测试中进行复杂的逻辑操作。

python 复制代码
使用Groovy生成动态数据:${__groovy('Hello ' + vars.get('username'),)}
执行Groovy脚本并存储结果:${__groovy(import java.time.LocalDate; return LocalDate.now().plusDays(1),)}

7、__urlencode:

对字符串进行URL编码。可以用于生成具有特殊字符的URL参数。

复制代码
对参数进行URL编码:{__urlencode({paramValue})}

8、__javaScript:

执行JavaScript脚本。可以用于在测试中进行简单的逻辑操作。

python 复制代码
使用JavaScript生成动态数据:${__javaScript('Hello ' + vars.get('username'))}
执行JavaScript脚本并存储结果:${__javaScript(new Date().toString())}

9、__CSVRead:

从CSV文件中读取数据。可以用于从文件中获取测试数据。

复制代码
从CSV文件中读取数据:${__CSVRead(data.csv,0)}

10、__regex:

使用正则表达式从字符串中提取数据。可以用于处理返回结果或提取关键信息。

复制代码
从响应结果中提取信息:{__regex({response},,$1)}

以上示例演示了如何使用常用的JMeter函数来生成动态数据、处理测试结果或执行逻辑操作。可以根据具体需求调整这些示例或查看JMeter的官方文档了解更多函数的详细信息和用法。

行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入扣群: 320231853,里面有各种软件测试+开发资料和技术可以一起交流学习哦。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
Y1nhl9 分钟前
力扣_链表_python版本
开发语言·python·算法·leetcode·链表·职场和发展
乌兰麦朵13 分钟前
Vue吹的颅内高潮,全靠选择性失明和 .value 的PUA!
前端·vue.js
Code季风14 分钟前
Gin Web 层集成 Viper 配置文件和 Zap 日志文件指南(下)
前端·微服务·架构·go·gin
蓝倾14 分钟前
如何使用API接口实现淘宝商品上下架监控?
前端·后端·api
舂春儿16 分钟前
如何快速统计项目代码行数
前端·后端
毛茸茸16 分钟前
⚡ 从浏览器到编辑器只需1秒,这个React定位工具改变了我的开发方式
前端
Pedantic16 分钟前
我们什么时候应该使用协议继承?——Swift 协议继承的应用与思
前端·后端
Software攻城狮17 分钟前
vite打包的简单配置
前端
Codebee17 分钟前
如何利用OneCode注解驱动,快速训练一个私有的AI代码助手
前端·后端·面试
流星稍逝18 分钟前
用vue3的写法结合uniapp在微信小程序中实现图片压缩、调整分辨率、做缩略图功能
前端·vue.js