
- TestNG 教程
- TestNG - 首頁
- TestNG - 概述
- TestNG - 環境
- TestNG - 編寫測試
- TestNG - 基本註解
- TestNG - 執行過程
- TestNG - 執行測試
- TestNG - 套件測試
- TestNG - 忽略測試
- TestNG - 組測試
- TestNG - 異常測試
- TestNG - 依賴測試
- TestNG - 引數化測試
- TestNG - 執行 JUnit 測試
- TestNG - 測試結果
- TestNG - 註解轉換器
- TestNG - 斷言
- TestNG - 並行執行
- TestNG - 與 ANT 整合
- TestNG - 與 Eclipse 整合
- TestNG - TestNG 與 JUnit 的比較
- TestNG 有用資源
- TestNG - 快速指南
- TestNG - 有用資源
- TestNG - 討論
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 ===============================================