- 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 - 基本註解 - AfterMethod
@AfterMethod 註解的方法將在每個測試方法之後執行,例如,如果有三個測試方法(即測試用例),那麼 @AfterMethod 註解的方法將在每個測試方法之後被呼叫三次。
以下是 @AfterMethod 註解支援的屬性列表
| 屬性 | 描述 |
|---|---|
alwaysRun |
對於 before 方法(AfterClass、beforeTest、beforeTestClass 和 beforeTestMethod,但不包括 beforeGroups):如果設定為 true,則無論此配置方法屬於哪個組,它都將執行。 對於 after 方法(afterSuite、afterClass、...):如果設定為 true,則即使先前呼叫的一個或多個方法失敗或被跳過,此配置方法也將執行。 |
dependsOnGroups |
此方法依賴的組列表。 |
dependsOnMethods |
此方法依賴的方法列表。 |
enabled |
此類/方法上的方法是否啟用。 |
groups |
此類/方法所屬的組列表。 |
inheritGroups |
如果為 true,則此方法將屬於類級別 @Test 註解中指定的組。 |
onlyForGroups |
僅適用於 @BeforeMethod 和 @AfterMethod。如果指定,則僅當相應的測試方法屬於列出的組之一時,才會呼叫此設定/拆卸方法。 |
建立類
建立一個要測試的 Java 類,例如,在 /work/testng/src 中建立 MessageUtil.java。
/*
* 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 測試類,例如,在 /work/testng/src 中建立 TestAnnotationAfterMethod.java。
向您的測試類新增一個測試方法 testMethod()。
向方法 testMethod() 添加註解 @Test。
向測試類新增一個帶有註解 @AfterMethod 的方法 afterMethod。
實現測試條件並檢查 @AfterMethod 註解的行為。
以下是 TestAnnotationAfterMethod.java 的內容
import org.testng.Assert;
import org.testng.annotations.Test;
import org.testng.annotations.AfterMethod;
public class TestAnnotationAfterMethod {
@AfterMethod
public void afterMethod(){
System.out.println("executing afterMethod after each method");
}
@Test
public void testMethodOne(){
Assert.assertEquals("Test method one", (new MessageUtil("executing testMethodOne method")).printMessage());
}
@Test
public void testMethodTwo(){
Assert.assertEquals("Test method two", (new MessageUtil("executing testMethodTwo method")).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="TestAnnotationAfterMethod"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
使用 javac 編譯測試用例。
/work/testng/src$ javac TestAnnotationAfterMethod.java MessageUtil.java
現在,執行 testng.xml,它將執行在 <test> 標籤中定義的測試用例。正如您所看到的,@AfterMethod 在所有其他測試用例之後被呼叫。
/work/testng/src$ java org.testng.TestNG testng.xml
驗證輸出。
executing testMethodOne method executing afterMethod after each method executing testMethodTwo method executing afterMethod after each method =============================================== Suite Total tests run: 2, Passes: 0, Failures: 2, Skips: 0 ===============================================