TestNG - 基本注解 - AfterSuite



@AfterSuite 注解的方法将在文件夹或 TestNG 套件中定义的所有测试用例执行完成后运行。

以下是 @AfterSuite 注解支持的属性列表

属性 描述

alwaysRun

对于 before 方法(beforeSuite、beforeTest、beforeTestClass 和 beforeTestMethod,但不包括 beforeGroups):如果设置为 true,则无论此配置方法属于哪个组,都将运行。

对于 after 方法(afterSuite、afterClass、...):如果设置为 true,则即使先前调用的一个或多个方法失败或被跳过,此配置方法也将运行。

dependsOnGroups

此方法依赖的组列表。

dependsOnMethods

此方法依赖的方法列表。

enabled

此类/方法上的方法是否启用。

groups

此类/方法所属的组列表。

inheritGroups

如果为 true,则此方法将属于类级别 @Test 注解中指定的组。

onlyForGroups

仅适用于 @BeforeMethod 和 @AfterMethod。如果指定,则仅当相应的测试方法属于列出的组之一时,才会调用此设置/拆卸方法。

创建类

创建一个要测试的 Java 类,例如,MessageUtil.java/work/testng/src 中。

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message) {
      this.message = message;
   }

   // prints the message
   public String printMessage() {
      System.out.println(message);
      return message;
   }
}

创建测试用例类

  • 创建一个 Java 测试类,例如,TestAnnotationAfterSuite.java/work/testng/src 中。

  • 向测试类中添加一个测试方法 testMethod()。

  • 向 testMethod() 方法添加注解 @Test。

  • 向测试类添加一个带有注解 @AfterSuite 的方法 afterSuite。

  • 实现测试条件并检查 @AfterSuite 注解的行为。

以下是 TestAnnotationAfterSuite.java 的内容

  import org.testng.Assert;
  import org.testng.annotations.Test;
  import org.testng.annotations.AfterSuite;

  public class TestAnnotationAfterSuite {
    MessageUtil messageUtil = new MessageUtil("Test method");
    @AfterSuite
    public void afterSuite(){
      System.out.println("After Suite method");
    }
    @Test
    public void testMethod(){
      Assert.assertEquals("Test method", messageUtil.printMessage());
    }

  }

创建 testng.xml

接下来,让我们在 /work/testng/src 中创建 testng.xml 文件,以执行测试用例。此文件以 XML 格式捕获您的整个测试。此文件使您可以轻松地在单个文件中描述所有测试套件及其参数,您可以将其检入代码库或通过电子邮件发送给同事。它还可以轻松地提取测试子集或拆分多个运行时配置(例如,testngdatabase.xml 将仅运行测试您的数据库的测试)。

  <?xml version="1.0" encoding="UTF-8"?>
  <!DOCTYPE suite SYSTEM "https://testng.org/testng-1.0.dtd">
  <suite name="Suite">
    <test thread-count="5" name="Test">
      <classes>
        <class name="TestAnnotationAfterSuite"/>
      </classes>
    </test> <!-- Test -->
  </suite> <!-- Suite -->

使用 javac 编译测试用例。

/work/testng/src$ javac TestAnnotationAfterSuite.java MessageUtil.java

现在,运行 testng.xml,它将运行在 <test> 标签中定义的测试用例。正如您所看到的,@AfterSuite 在所有其他测试用例之后被调用。

/work/testng/src$ java org.testng.TestNG testng.xml

验证输出。

  Test method
  After Suite method

  ===============================================
  Suite
  Total tests run: 1, Passes: 1, Failures: 0, Skips: 0
  ===============================================
广告