如何解决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<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,到此完事。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值