版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/MenofGod/article/details/72846649
今天给大家分享一下testng执行用例失败自动重跑问题的解决办法,为什么要写这篇博客?有人会说了,网上找一车一车的,干嘛自己搁这儿写这个。。。
没错,网上是有很多,只是我感觉按照网上的说法去做不一定一次点亮,可能跟我们每个人的理解不一样,也可能是网上说的也不一定都准确,这个大家都能理解,所以呢,老套路:我想用我自己的方式,站在大家也有被此问题困惑的角度写出解决办法,我认为这个是最重要的。好了,废话少说,正儿八经的呈上:
一、首先新建Java类实现IRetryAnalyzer接口,代码如下(主要配置自动重跑次数maxRetryCount):
public class OverrideIReTry implements IRetryAnalyzer {
public static Logger logger=Logger.getLogger(OverrideIReTry.class);
public int retryCount=0;
private static int maxRetryCount ;
static {
//外围文件配置最大运行次数,失败后重跑maxRetryCount+1次
maxRetryCount = 2;//也就是失败后重跑3次
logger.info("maxRunCount=" + (maxRetryCount));
}
@Override public boolean retry(ITestResult iTestResult){
if(retryCount <= maxRetryCount){String message = "running retry for '" + iTestResult.getName() + "' on class " +
this.getClass().getName() + " Retrying " + retryCount + " times";
logger.info(message);
Reporter.setCurrentTestResult(iTestResult);
Reporter.log("RunCount=" + (retryCount + 1));
retryCount++;
return true;
} return false;
}
}
二、新建Java类实现IAnnotationTransformer接口,代码如下:
package TezitongAll;
import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import org.testng.IAnnotationTransformer;
import org.testng.IRetryAnalyzer;
import org.testng.annotations.ITestAnnotation;
public class RetryListener implements IAnnotationTransformer {
@Override
public void transform(ITestAnnotation annotation, @SuppressWarnings("rawtypes") Class testClass,@SuppressWarnings("rawtypes") Constructor testConstructor, Method testMethod) {
IRetryAnalyzer retry = annotation.getRetryAnalyzer();
if (retry == null) {
annotation.setRetryAnalyzer(OverrideIReTry.class);
}
}
}
三、我们还有重写onFinish方法,我这里呢同样新建了一个类,代码如下:
package TezitongAll;
import java.util.Iterator;
import org.testng.ITestContext;
import org.testng.ITestNGMethod;
import org.testng.ITestResult;
import org.testng.TestListenerAdapter;
import org.testng.log4testng.Logger;
public class TestngListener extends TestListenerAdapter {
private static Logger logger = Logger.getLogger(TestngListener.class);
@Override
public void onTestFailure(ITestResult tr) {
super.onTestFailure(tr);
logger.info(tr.getName() + " Failure");
}
@Override
public void onTestSkipped(ITestResult tr) {
super.onTestSkipped(tr);
logger.info(tr.getName() + " Skipped");
}
@Override
public void onTestSuccess(ITestResult tr) {
super.onTestSuccess(tr);
logger.info(tr.getName() + " Success");
}
@Override
public void onTestStart(ITestResult tr) {
super.onTestStart(tr);
logger.info(tr.getName() + " Start");
}
@Override
public void onFinish(ITestContext testContext) {
super.onFinish(testContext);
Iterator<ITestResult> listOfFailedTests = testContext.getFailedTests().getAllResults().iterator();
while (listOfFailedTests.hasNext()) {
ITestResult failedTest = (ITestResult) listOfFailedTests.next();
ITestNGMethod method = failedTest.getMethod();
if (testContext.getFailedTests().getResults(method).size() > 1) {
listOfFailedTests.remove();
}
else {
if (testContext.getPassedTests().getResults(method).size() > 0) {
listOfFailedTests.remove();
}
}
}
}
}
四、之后,我们在testng.xml中添加监听,代码如下:
<listeners>
<listener class-name="TezitongAll.TestngListener"></listener> //需要改成自己目录的路径和名称
<listener class-name="TezitongAll.RetryListener"></listener> //需要改成自己目录的路径和名称
</listeners>
//以下为你要运行的case在哪个类下边就配置相应的路径和name
<test name="usersinfo">
<classes>
<class name="TezitongAll.TezitongAll" />
</classes>
</test>
五、以上完成之后,执行我们的testng.xml(记住:每次都要执行testng.xml才能监听到你测case是否失败了,失败才会重跑)如下:
六、查看运行结果(***是我为了看到底有没有重跑,如果有重跑了几次而加上的标记,执行onTestFailure是报错截图中的提示),如下:
七、OK,到此完事。