Jmeter Thread Group中如果存在HTTP request执行失败,就对整个Thread Group重新执行,限定最大执行次数N次
由于在对WEB系统进行自动化测试的过程中,经常会由于握手连接断开等原因导致HTTP请求发送失败,如果重新执行一次,会是成功的。在每天的自动化冒烟测试过程中,生成在测试报告存在误报,严重浪费了测试人员确认的时间,因此希望在HTTP请求失败的情况下,重新执行,设置一个重新执行的最大次数,如果尝试了多次都是失败的才认为是真的失败了。
一开始,我只是对单个HTTP request通过While Controller做了失败后重新执行这样的处理,但是要让一个thread group里面所有的HTTP request都这样处理该怎么办呢?由于对每个HTTP request都添加一段那样的代码不太现实,最后,我是这样处理的,将一个thread group里面所有的脚本都放在一个While Controller里面,如果有任意一个HTTP request失败了,就重复执行整个thread group,而且最后一次执行无论成功与否,其前面的几次执行都强行设置成是成功的,这样如果前N-1次执行失败了,第N次执行成功了,出来的测试报告不会有这个HTTP request失败的信息,测试人员就不需要花时间去重新确认了。
1 初始化变量
1 2 3 4 | vars.putObject( "INCREMENT" , 0); vars.putObject( "ANYSAMPLEFAIL" , false ); vars.putObject( "ISCONTINUE" , true ); vars.putObject( "MAXLOOP" , 3); |
2 控制循环
1 | ${__BeanShell((Boolean)vars.getObject( "ISCONTINUE" ))} |
3 对HTTP sample的结果sampleresult进行判断,如果有任何一个失败了,就将标志位ANYSAMPLEFAIL设置为true,以便据此判断整个thread group是否需要重新执行
备注:此BeanShell Assertion将作用于While Controller内每一个HTTP Sampler
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | import org.apache.jmeter.util.JMeterUtils; import org.apache.jmeter.samplers.SampleResult; import org.apache.jmeter.assertions.AssertionResult; SampleResult prev_result=ctx.getPreviousResult(); Integer increment = (Integer)vars.getObject( "INCREMENT" ); Integer maxloop = (Integer)vars.getObject( "MAXLOOP" ); if (prev_result != null && !prev_result.isSuccessful()) { vars.putObject( "ANYSAMPLEFAIL" , true ); if (increment.intValue() < (maxloop.intValue() - 1)) { prev_result.setSuccessful( true ); } } |
4 对循环次数进行计数,对是否继续重复执行进行判断,对是否存在任何一个samper失败的标志位ANYSAMPLEFAIL进行重置
备注:此BeanShell Samper只在每次的While Controller的最后执行一次
1 2 3 4 5 6 7 8 9 | Integer increment = (Integer)vars.getObject( "INCREMENT" ); increment++; Boolean requestResult = (Boolean)vars.getObject( "ANYSAMPLEFAIL" ); Integer maxloop = (Integer)vars.getObject( "MAXLOOP" ); boolean iscontinue = (increment < maxloop) && requestResult.booleanValue() ; vars.putObject( "ISCONTINUE" , iscontinue); vars.putObject( "ANYSAMPLEFAIL" , false ); vars.putObject( "INCREMENT" , increment ); |
这样处理之后,如果最大循环三次,三次都失败了,前两次也不会被标记为失败的,请看结果树:
在上图中,前两次失败的HTTP request虽然其下的断言标记为失败的,但是HTTP request并没有标记为失败的。
如果希望前两次失败的HTTP request连其下的断言都标记为成功的,那么需要这样处理:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | import org.apache.jmeter.util.JMeterUtils; import org.apache.jmeter.samplers.SampleResult; import org.apache.jmeter.assertions.AssertionResult; SampleResult prev_result=ctx.getPreviousResult(); if (prev_result != null && !prev_result.isSuccessful()) { AssertionResult [] results=prev_result.getAssertionResults(); int size = results.length; for ( int i=0; i< size; i++) { AssertionResult result_item = results[i]; if (result_item != null ) { result_item.setFailure( false ); } } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!