1.TestNG注解

TestNG注解管理层级

testng注解是通过aop切面实现的么 testng有哪些注解_测试方法

@BeforeXXX 之前执行

@AfterXXXX 之后执行

套件注解(@XXSutie)、测试注解(@XXTest)、类注解(@XXClass)、方法注解(@XXMethod)

TestNG基本注解

@Test

标记一个类或方法作为测试的一部分。

@BeforeSuite

在测试集开始运行之前执行该方法。

@AfterSuite

在测试集所有内容执行完成之后执行该方法。

@BeforeTest

在属于<test>标签内的类的所有测试方法运行之前运行

@AfterTest

在属于<test>标签内的类的所有测试方法运行之后运行

@BeforeClass

在调用当前类的第一个@Test方法之前运行。

@AfterClass

在当前类中内容执行完成之后执行。

@BeforeMethod

在每个@Test方法之前都会执行。

@AfterMethod

在每个@Test方法之后都会执行。

上述的注解分为Before类别和After类,我们可以在Before类别的注解方法里面做一些初始化动作,如实例化数据库连接、新建数据库连接池、创建线程池、打开文件流等等。

然后,我们可以在After类别的注解方法里面做一些销毁动作,如释放数据库连接、销毁数据库连接池、销毁线程池或者关闭文件流等等。

同一类别的不同注解会在不同的位置被调用,下面我们逐个介绍:上面的说明,很抽象,也很乱,我们以一个例子来说明上面这些注解的用法:

新建TestNGAnnotationTest 和 TestNGAnnotationTest2  (TestNGAnnotationTest2TestNGAnnotationTest内容一致)

public class TestNGAnnotationTest {
    
      @BeforeSuite
      public void beforeSuite() {
      System.out.println(this.getClass().getName() + " beforeSuite");
      }
    
      @AfterSuite
      public void afterSuite() {
      System.out.println(this.getClass().getName() + " afterSuite");
      }  
  
      @BeforeTest
      public void beforeTest() {
      System.out.println(this.getClass().getName() + "beforeTest");
      }
     
  
      @AfterTest
      public void afterTest() {
      System.out.println(this.getClass().getName() + "afterTest");
      }

      @BeforeClass
      public void beforeClass() {
      System.out.println(this.getClass().getName() + "beforeClass");
      }

      @AfterClass
      public void afterClass() {
      System.out.println(this.getClass().getName() + "afterClass");
      }
    
      @BeforeMethod
      public void beofreMethod() {
      System.out.println(this.getClass().getName() + "beforeMethod");
      }

      @AfterMethod
      public void afterMethod() {
      System.out.println(this.getClass().getName() +  "afterMethod");
      }
    
      @Test
      public void test1() {
      System.out.println(this.getClass().getName() + " test1");
      }

      @Test
      public void test2() {
      System.out.println(this.getClass().getName() + "test2");
      }
}
  • 运行testng测试,得到以下结果:

 ………………

我们可以根据自身需求,选择特定的位置去执行一些初始化动作,以及一些销毁动作。假如你需要针对整个测试suite做初始化动作,那么应该选择在被@BeforeSuite注解的方法里面执行。如果需要针对一个<test>里面的所有测试类做初始化动作,那么可以选择在被@BeforeTest注解的方法里面执行。如果需要针对一个特定的测试类做初始化动作,那么应该选择在被@BeforeClass注解的方法里面执行。最后,假如你想在每一个测试方法执行前做初始化动作,那么应该选择@BeforeMethod。销毁的选择与初始化类似,这里不再赘述。

2. @Test 注解

@Test 注解是TestNG的核心注解,被打上该注解的方法,表示为一个测试方法,类比JUnit是一个道理(JUnit也是用了这个注解,在使用TestNG时候注意导包别导错)。

这个注解有多个配置属性,用法为:

@Test(param1 = ..., param2 = ...)
  • 常见取值说明如下:
  • alwaysRun : 如果=true,表示即使该测试方法所依赖的前置测试有失败的情况,也要执行
  • dataProvider : 选定传入参数的构造器。(@DataProvider注解将在后面章节介绍)
  • dataProviderClass : 确定参数构造器的Class类。(参数构造器首先会在当前测试类里面查找,如果参数构造器不在当前测试类定义,那么必须使用该属性来执行它所在的Class类)
  • dependsOnGroups : 确定依赖的前置测试组别。
  • dependsOnMethods : 确定依赖的前置测试方法。
  • description : 测试方法描述信息。(建议为每个测试方法添加有意义的描述信息,这将会在最后的报告中展示出来)
  • enabled : 默认为true,如果指定为false,表示不执行该测试方法。
  • expectedExceptions : 指定期待测试方法抛出的异常,多个异常以逗号(,)隔开。
  • groups : 指定该测试方法所属的组,可以指定多个组,以逗号隔开。组测试的用法将在后面文章单独介绍。
  • invocationCount : 指定测试方法需要被调用的次数。
  • invocationTimeOut: 每一次调用的超时时间,如果invocationCount没有指定,该参数会被忽略。应用场景可以为测试获取数据库连接,超时就认定为失败。单位是毫秒。
  • priority : 指定测试方法的优先级,数值越低,优先级越高,将会优先与其他数值高的测试方法被调用。(注意是针对一个测试类的优先级)
  • timeout : 指定整个测试方法的超时时间。单位是毫秒。

下面我们写一个简单的测试类,说明@Test注解的使用以及属性的配置方式:

3. @Parameters 注解

@Parameters 注解用于为测试方法传递参数, 用法如下所示:

package com.crazypig.testngdemo;
import org.testng.annotations.Parameters;
import org.testng.annotations.Test;

public class AnnotationParametersTest {

     @Parameters(value = {"param1", "param2"})
     @Test
     public void test(String arg1, String arg2) {
	     System.out.println("use @Parameters to fill method arguments : arg 1 = " + arg1 + ", arg2 = " + arg2);
     }
}
  • testng.xml配置
<test name="testAnnotationParameters">
     <parameter name="param1" value="value1"></parameter>
     <parameter name="param2" value="value2"></parameter>
     <classes><class name="com.crazypig.testngdemo.AnnotationParametersTest"/></classes>
</test>

运行结果:

use @Parameters to fill method arguments : arg 1 = value1, arg2 = value2