- 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 - 基本註解 - AfterClass
@AfterClass 註解的方法將在當前類中所有測試方法執行完成後執行。
以下是 @AfterClass 註解支援的屬性列表
| 屬性 | 描述 |
|---|---|
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 測試類,例如,TestAnnotationAfterClass.java 在 /work/testng/src 中。
向測試類中新增一個測試方法 testMethod()。
向 testMethod() 方法新增 @Test 註解。
向測試類中新增一個帶有 @AfterClass 註解的方法 afterClass。
實現測試條件並檢查 @AfterClass 註解的行為。
以下是 TestAnnotationAfterClass.java 的內容
import org.testng.Assert;
import org.testng.annotations.Test;
import org.testng.annotations.AfterClass;
public class TestAnnotationAfterClass {
MessageUtil messageUtil = new MessageUtil("Test method");
@AfterClass
public void AfterClass(){
System.out.println("After Class 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="TestAnnotationAfterClass"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
使用 javac 編譯測試用例。
/work/testng/src$ javac TestAnnotationAfterClass.java MessageUtil.java
現在,執行 testng.xml,它將執行在 <test> 標籤中定義的測試用例。如您所見,@AfterClass 在所有其他測試用例之前被呼叫。
/work/testng/src$ java org.testng.TestNG testng.xml
驗證輸出。
Test method After Class method =============================================== Suite Total tests run: 1, Passes: 1, Failures: 0, Skips: 0 ===============================================