Java TestNG注解的运行顺序

TestNG可以通过注解的方式来控制方法的运行顺序,在代码中经常会通过注解的方式来实现初始化操作和清理操作,比如数据库的连接和关闭,即使在测试方法中抛出异常,但是after注解的方法依旧会执行。常用的注解有:

1  @BeforeSuite(在测试集之前运行) → @AfterSuite(在测试集之后运行)

2  @BeforeClass(在测试类之前运行) → @AfterClass(在测试类之后运行)

3  @BeforeTest (在开始执行测试方法前运行)→ @AfterTest(在执行测试方法后运行)

4  @BeforeMethod (在每个测试方法前运行)→ @AfterMethod(在每个测试方法后运行)

但是几种注解一起使用时,经常搞不清楚运行的先后顺序,先把结论抛出来:

1 @BeforeSuite  > @BeforeTest > @BeforeClass > @BeforeMethod

2  @AfterMethod > @AfterClass > @AfterTest > @AfterSuite

3  可以看出越先运行的before注解所对应的after注解就越后运行。

下面通过一段代码来验证一下运行顺序

public class MainClass {

@BeforeSuite

    public void beforeSuite(){

System.out.println("beforeSuite");

    }

@AfterSuite

    public void afterSuite(){

System.out.println("afterSuite");

    }

@BeforeClass

    public void beforeClass(){

System.out.println("beforeClass");

    }

@AfterClass

    public void afterClass(){

System.out.println("afterClass");

    }

@BeforeTest

    public void beforeTest1(){

System.out.println("beforeTest");

    }

@AfterTest

    public void afterTest(){

System.out.println("afterTest");

    }

@BeforeMethod

    public void beforeMethod(){

System.out.println("beforeMethod");

    }

@AfterMethod

    public void afterMethod(){

System.out.println("afterMethod");

    }

@Test

    public void test1(){

System.out.println("test1");

    }

@Test

    public  void test2(){

System.out.println("test2");

    }

}

运行代码后,控制台输出


由此可以得出结论

1  @BeforeSuite  > @BeforeTest > @BeforeClass > @BeforeMethod

2  @AfterMethod > @AfterClass > @AfterTest > @AfterSuite

3  可以看出越先运行的before注解所对应的after注解就越后运行。

你可能感兴趣的:(Java TestNG注解的运行顺序)