- 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 vs JUnit
- TestNG 有用資源
- TestNG - 快速指南
- TestNG - 有用資源
- TestNG - 討論
TestNG - 基本註解 - BeforeSuite
@BeforeSuite 註解的方法將在執行資料夾中或TestNG套件內定義的所有測試用例之前執行。例如,當您有單獨的URL來測試所有測試用例時,可以使用此註解。環境變數可以在@BeforeSuite註解的方法中設定。接下來,在執行所有測試用例之前,您需要先載入框架的所有環境變數,然後開始執行測試用例。
@BeforeSuite 註解支援以下屬性列表
| 屬性 | 描述 |
|---|---|
alwaysRun |
對於before方法(beforeSuite、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中建立TestAnnotationBeforeSuite.java。
向測試類新增測試方法testMethod()。
向testMethod()方法新增@Test註解。
向測試類新增一個帶有@BeforeSuite註解的beforeSuite方法。
實現測試條件並檢查@BeforeSuite註解的行為。
以下是TestAnnotationBeforeSuite.java的內容
import org.testng.Assert;
import org.testng.annotations.Test;
import org.testng.annotations.BeforeSuite;
public class TestAnnotationBeforeSuite {
MessageUtil messageUtil = new MessageUtil("Test method");
@BeforeSuite
public void beforeSuite(){
System.out.println("Before 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="TestAnnotationBeforeSuite"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->
使用javac編譯測試用例。
/work/testng/src$ javac TestAnnotationBeforeSuite.java MessageUtil.java
現在,執行testng.xml,它將執行在<test>標籤中定義的測試用例。正如您所看到的,@BeforeSuite在所有其他測試用例之前被呼叫。
/work/testng/src$ java org.testng.TestNG testng.xml
驗證輸出。
Before Suite method Test method =============================================== Suite Total tests run: 1, Passes: 1, Failures: 0, Skips: 0 ===============================================