问题描述:我想要在jmeter的JSR223后置处理中,获取到取样器的断言是否成功的结果然后做一些自己定制的操作。
我的脚本和JSR223的脚本如下:
log.info("开始............进入后置处理器中=================================")
// 获取前一个采样器的结果
def prev = preveeee // 注意这里直接引用了预定义的变量prev
log.info("开始............")
//log.info(prev)
if (prev != null) {
// 获取断言结果列表
def assertionResults = prev.getAssertionResults()
log.info("2222............")
log.info(String.valueOf(assertionResults.size()))
// 遍历所有的断言结果
for (result in assertionResults) {
//网上说的isSuccess()方法在jmeter5.5版本中不存在isFailure()可用
if (result.isFailure()){
log.info("断言失败: " + result.getFailureMessage())
}
// 可以在此处添加额外的处理逻辑}
}
} else {
log.info("没有可用的前一个采样器结果")
}
结果是:
无论如何我获取到的assertionResults都是空值导致我无法判断取样器的断言结果是否正确。
解决方法:
按照如下方式修改checkAssertions和runPostProcessors的调用顺序后,重新打包替换包后,可以正常实现上面的需求。
D:\apache-jmeter-5.5\src\core\src\main\java\org\apache\jmeter\threads\JMeterThread.java