有没有办法检查某个断言是否失败

时间:2013-11-01 09:28:28

标签: jmeter

我有一个带有响应和持续时间断言的HTTP请求采样器。现在,当响应断言失败时,不允许下一个HTTP请求采样器运行。只有当持续时间断言失败时,才允许运行下一个HTTP请求采样器。

我开始使用IF Controller执行此操作并检查${JMeterThread.last_sample_ok}但是,当我只有响应断言时。添加持续时间断言和新要求时,不再适用。

我已经尝试过BeanShell Post Processors在持续时间断言失败时添加某些变量。但是,当持续时间断言失败时,下面的代码总是给我回来和空数组事件。

BeanShell后处理器代码:

import org.apache.jmeter.assertions.AssertionResult;

AssertionResult[] results = prev.getAssertionResults();

if (results.length == 0) {
   vars.put("assertions_have_zero_length", "true"); 
}

//debug post processor shows the above variable.

我还尝试使用BeanShell监听器,这确实给了我两个断言但是在创建(放置)某些变量时它们没有显示在调试后处理器中。

BeanShell侦听器代码:

import org.apache.jmeter.assertions.AssertionResult;

AssertionResult[] results = sampleResult.getAssertionResults();

System.out.println("Current counter value = " + results.length);

if (results.length == 0) {
  vars.put("assertions_have_zero_length", "true"); 
} else {
  vars.put("assertions_have_zero_length", "false"); 
}

//no assertion_have_zero_length variable shown in debug post processor.

我做错了什么,甚至可能是我想要的吗?

提前致谢。

1 个答案:

答案 0 :(得分:6)

我设法让它与BeanShell Listener一起使用。由于execution order,我第一次尝试使用BeanShell后处理器是不可能的。后处理器在断言之前运行。这也是Debug Post Processor没有显示在BeanShell Listener中创建的变量的原因。

所以BeanShell Listener的代码如下:

import org.apache.jmeter.assertions.AssertionResult;

AssertionResult[] results = sampleResult.getAssertionResults();

boolean skipPostAssertionConsumerService = false;

for(int i =0; i<results.length; i++) { 

    AssertionResult result = results[i];

    boolean isResponseAssertion = result.getName().equals("Response Assertion - Is Not Authentication Failed");
    boolean resultHasFailed = result.isFailure() || result.isError();

     if(isResponseAssertion && resultHasFailed) { 
        skipPostAssertionConsumerService = true;
        break;
     } 
}

vars.put("do_post_assertion_consumer_service_url", (!skipPostAssertionConsumerService).toString());

IF Controller我设置了以下条件:

${do_post_assertion_consumer_service_url}