如何解决testng执行用例失败自动重跑问题

今天给大家分享一下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 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中添加监听,代码如下:


         //需要改成自己目录的路径和名称
          //需要改成自己目录的路径和名称
 

 //以下为你要运行的case在哪个类下边就配置相应的路径和name

        
            
        
     
五、以上完成之后,执行我们的testng.xml(记住:每次都要执行testng.xml才能监听到你测case是否失败了,失败才会重跑)如下:

如何解决testng执行用例失败自动重跑问题_第1张图片

六、查看运行结果(***是我为了看到底有没有重跑,如果有重跑了几次而加上的标记,执行onTestFailure是报错截图中的提示),如下:

如何解决testng执行用例失败自动重跑问题_第2张图片

七、OK,到此完事。

你可能感兴趣的:(Selenium)