一种方法是实现方法调用侦听器。在 after 方法中,您可以设置一个标志,在 before 方法中,您可以检查标志并根据标志的值跳过测试。例如:
package com.qmetry.qaf.example.test;
...
public class StopRunListener implements IInvokedMethodListener {
private static boolean hasFailure=false;
@Override
public void beforeInvocation(IInvokedMethod method, ITestResult testResult) {
String[] groups = testResult.getMethod().getGroups();
if(hasFailure && Arrays.asList(groups).contains("Test2")) {
throw new SkipException("Stop execution due to failure");
}
}
@Override
public void afterInvocation(IInvokedMethod method, ITestResult testResult) {
String[] groups = testResult.getMethod().getGroups();
if(!testResult.isSuccess() && Arrays.asList(groups).contains("Test1")) {
hasFailure=true;
}
}
}
在 XML 配置文件中添加监听器
<listeners>
<listener class-name="com.qmetry.qaf.example.test.StopRunListener" />
</listeners>
<groups>
<run>
<include name="@Test1" />
<include name="@Test2" />
</run>
</groups>
<classes>
<class
name="com.qmetry.qaf.automation.step.client.gherkin.GherkinScenarioFactory" />
</classes>
使用 Gherkin 语法,您不能指定依赖项或其他元数据。您可以使用qaf-2.1.14 提供的BDD2 语法test1
,并将 group的依赖项设置为test2
. 它将确保来自 group 的测试在 grouptest2
之后执行test1
。但如果依赖组中的一项测试失败,它不会跳过测试。您可以使用上面示例中提供的侦听器来实现。
例如:
#meta-data on feature will be assigned to all scenario in feature file
@Test1
Feature: A feature is a collection of scenarios
@Test2
@dependsOnGroups:Test1
Feature: A feature is a collection of scenarios
XML配置将是:
<listeners>
<listener class-name="com.qmetry.qaf.example.test.StopRunListener" />
</listeners>
<groups>
<run>
<include name="Test1" /> <!-- don't add @ in group for BDD or BDD2 -->
<include name="Test2" />
</run>
</groups>
<classes>
<class
name="com.qmetry.qaf.automation.step.client.text.BDDTestFactory2" />
</classes>