testng对执行失败的用例,再次执行

发表于:2018-7-03 16:57

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:纯白色和白色    来源:博客园

#
TestNG
分享:
  前段时间在网络上看到通过重写TestNG的接口,可以再次执行失败的测试用例,于是学习了,我之前的做法是当自己的脚本中碰到异常,就自动调用方法本身来达到再次执行用例的目的,这个过程中有设定重试的次数
  对于TestNG,首先重写接口IRetryAnalyzer,重写该接口中的retry方法,自定义需要重试的次数maxReTryNum,如果一个用例失败,自动进入retry方法,在此方法中判断已经重试的次数是否小于等于maxReTryNum,如果是,则返回true,则自动再次执行失败的用例,如果是失败的用例再次执行还是失败,那么还是自动调用retry方法,直到到重试次数大于设定的maxReTryNum了,则返回false,那么系统就是判定该方法失败了
  public class OverrideIReTry implements IRetryAnalyzer {
  public static Logger logger=Logger.getLogger(OverrideIReTry.class);
  public int initReTryNum=1;
  public int maxReTryNum=3;
  @Override
  public boolean retry(ITestResult iTestResult) {
  if(initReTryNum<=maxReTryNum){
  String message="方法<"+iTestResult.getName()+">执行失败,重试第"+initReTryNum+"次";
  logger.info(message);
  Reporter.setCurrentTestResult(iTestResult);
  Reporter.log(message);
  initReTryNum++;
  return true;
  }
  return false;
  }
  }
  当我们重写了TestNG的IRetryAnalyzer 接口,那么就需要让系统调用我们重写的接口,需要让TestNG调用,还需要对TestNG.xml中的注解接口进行重写。先判断TestNG.xml中是否有重试分析器,如果没有,则调用我们自己重写类
  public class OverrideIAnnotationTransformer implements IAnnotationTransformer{
  @Override
  public void transform(ITestAnnotation iTestAnnotation, Class aClass, Constructor constructor, Method method) {
  IRetryAnalyzer iRetryAnalyzer= iTestAnnotation.getRetryAnalyzer();
  if(iRetryAnalyzer==null){
  iTestAnnotation.setRetryAnalyzer(OverrideIReTry.class);
  }
  }
  }

  我们可以定义了2个方法test1和test2,代码如下,其中test1方法执行是正确,test2执行一定是会报异常的,那么预期的结果是,test2方法失败后,会被再次执行3次
  public class ReTryTest {
  @Test
  public void test1(){
  System.out.println(1/1);
  }
  @Test
  public void test2(){
  System.out.println(1/0);
  }
  }

  此时,我们就可以在TestNG.xml中直接声明监听重试的函数了,并且调用test1和test2来验证重写IRetryAnalyzer是否会对失败的用例重新执行
  <?xml version="1.0" encoding="UTF-8"?>
  <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
  <suite name="casual">
  <listeners>
  <listener class-name="reTry.OverrideIAnnotationTransformer"></listener>
  </listeners>
  <test name="test">
  <classes>
  <class name="reTry.ReTryTest">
  <methods>
  <include name="test1"/>
  <include name="test2"/>
  </methods>
  </class>
  </classes>
  </test>
  </suite>

  直接编译后,我们可以看到log中是显示这个的,说明了我们的重写是可以正确的
  [INFO ] main 2015-08-29 09:55:13,030                  reTry.OverrideIReTry     - 方法<test2>执行失败,重试第1次
  [INFO ] main 2015-08-29 09:55:13,031                  reTry.OverrideIReTry     - 方法<test2>执行失败,重试第2次
  [INFO ] main 2015-08-29 09:55:13,032                  reTry.OverrideIReTry     - 方法<test2>执行失败,重试第3次

上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号