Jmeter使用While控制器

1.前言

对于性能测试场景中,需要用"执行某个事物,直到一个条件停止"的概念时,While控制器控制器无疑是首选,但是在编写脚本时,经常会出现推出循环异常,获取参数异常等问题,下面总结两种常用的写法

2.${flag}直接引用判断

1.在预处理器中定义一个flag

或者在用户定义的变量中定义

复制代码
def flag = true
vars.putObject("flag",flag)
log.error("JSR223 预处理程序 flag: " + flag )

2.创建While控制器

3.使用示例触发退出循环

使用"计数器"来实现每次迭代 num_ber+1

在 num_ber > 9 时,将 flag 置为 false

复制代码
log.info("Elapsed Time1: ms:" + vars.getObject("flag"))
int num_ber = (vars.getObject("test_num")).toInteger()
if (num_ber > 9){
	vars.putObject("flag", false)
	}
	
	
log.info("Elapsed Time1: ms:" + vars.getObject("flag") + " num " + num_ber)

4. 运行示例

在num_ber = 10时,while循环结束

3.使用函数判断条件

这里推荐使用 ${__groovy(,)} 来作为函数载体

首先groovy语法与JSR223 中一致,便于理解和学习

其次在很多资料中显示

  • {__jexl3({C}==10)}
  • {__javaScript({C}==10)}

这两种写法存在兼容性bug,经常导致判断失败或异常报错

使用groovy:

复制代码
${__groovy(vars.getObject("flag1") < 10,)}
${__groovy("vars.get("flag1")" < "10",)}

1.同上,使用预处理器,定义flag

复制代码
int flag1 = 0
vars.putObject("flag1",flag1)
log.error("JSR223 预处理程序 flag1: " + flag1 )

2.设置while

3.设置退出条件

复制代码
log.info("Elapsed Time1: ms:" + vars.getObject("flag1"))
int num = (vars.getObject("test_num")).toInteger()

vars.putObject("flag1",num)
log.info("Elapsed Time1: ms:" + vars.getObject("flag1") + " num " + num)

4.结果展示

在num_ber = 10时,while循环结束

相关推荐
se-tester5 天前
JMeter、Postman 和 SoapUI 在做接口测试上的优势和缺点
测试工具·jmeter·接口测试·postman·soapui
feathered-feathered6 天前
测试实战【用例设计】自己写的项目+功能测试(1)
java·服务器·后端·功能测试·jmeter·单元测试·压力测试
质量保障小乔11 天前
JMeter+Jenkins+AI自动化测试
jmeter
装不满的克莱因瓶13 天前
Java高并发异步请求实战,Jmeter暴力压测下的解决方案
jmeter·线程池·多线程·并发·resttemplate·qps·压测
在坚持一下我可没意见18 天前
ideaPool论坛系统测试报告
java·spring boot·功能测试·selenium·jmeter·mybatis·压力测试
linweidong20 天前
别让老板等:千人并发下的实时大屏极致性能优化实录
jmeter·clickhouse·性能优化·sentinel·doris·物化视图·离线数仓
CesareCheung21 天前
JMeter核心组件使用方法及场景大全
jmeter
我会一直在的22 天前
Jmeter的基础使用
功能测试·jmeter·压力测试
choke23322 天前
软件性能测试实战:从基础概念到 JMeter 全组件使用
jmeter
网络安全-杰克23 天前
Jmeter压力测试工具安装与使用
自动化测试·软件测试·测试工具·jmeter·职场和发展