
- 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 - 依賴測試
有時,您可能需要以特定順序呼叫測試用例中的方法,或者您可能希望在方法之間共享一些資料和狀態。TestNG 支援這種依賴關係,因為它支援宣告測試方法之間的顯式依賴關係。
TestNG 允許您使用以下方法指定依賴關係:
在 @Test 註解中使用屬性 dependsOnMethods,或。
在 @Test 註解中使用屬性 dependsOnGroups。
使用 dependsOnMethods 的示例
建立一個類
建立一個要測試的 Java 類,例如,MessageUtil.java 在 /work/testng/src 目錄下。
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; } // add "Hi!" to the message public String salutationMessage() { message = "Hi!" + message; System.out.println(message); return message; } }
建立測試用例類
建立一個 Java 測試類,例如,DependencyTestUsingAnnotation.java 在 /work/testng/src 目錄下。
向您的測試類新增測試方法 testPrintMessage()、testSalutationMessage() 和 initEnvironmentTest()。
將屬性 dependsOnMethods = {"initEnvironmentTest"} 新增到 testSalutationMessage() 方法的 @Test 註解中。
以下是 DependencyTestUsingAnnotation.java 的內容。
import org.testng.Assert; import org.testng.annotations.Test; public class DependencyTestUsingAnnotation { String message = "Manisha"; MessageUtil messageUtil = new MessageUtil(message); @Test public void testPrintMessage() { System.out.println("Inside testPrintMessage()"); message = "Manisha"; Assert.assertEquals(message, messageUtil.printMessage()); } @Test(dependsOnMethods = { "initEnvironmentTest" }) public void testSalutationMessage() { System.out.println("Inside testSalutationMessage()"); message = "Hi!" + "Manisha"; Assert.assertEquals(message, messageUtil.salutationMessage()); } @Test public void initEnvironmentTest() { System.out.println("This is initEnvironmentTest"); } }
建立 testng.xml
在 /work/testng/src 目錄下建立 testng.xml 來執行測試用例。
<?xml version = "1.0" encoding = "UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > <suite name = "Suite1"> <test name = "test1"> <classes> <class name = "DependencyTestUsingAnnotation" /> </classes> </test> </suite>
使用 javac 編譯 MessageUtil 和測試用例類。
/work/testng/src$ javac MessageUtil.java DependencyTestUsingAnnotation.java
現在,執行 testng.xml,它將僅在執行 initEnvironmentTest() 方法後執行 testSalutationMessage() 方法。
/work/testng/src$ java org.testng.TestNG testng.xml
驗證輸出。
This is initEnvironmentTest Inside testPrintMessage() Manisha Inside testSalutationMessage() Hi!Manisha =============================================== Suite1 Total tests run: 3, Failures: 0, Skips: 0 ===============================================
使用 dependsOnGroups 的示例
您還可以擁有依賴於整個組的方法。讓我們來看一個示例來說明這一點。
建立一個類
建立一個要測試的 Java 類,例如,MessageUtil.java 在 /work/testng/src 目錄下。
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; } // add "Hi!" to the message public String salutationMessage() { message = "Hi!" + message; System.out.println(message); return message; } }
建立測試用例類
建立一個 Java 測試類,例如,DependencyTestUsingAnnotation.java。
向您的測試類新增測試方法 testPrintMessage()、testSalutationMessage() 和 initEnvironmentTest(),並將它們新增到組“init”。
將屬性 dependsOnGroups = {"init"} 新增到 testSalutationMessage() 方法的 @Test 註解中。(原文有誤,應為dependsOnGroups, dependsOnMethods 會導致迴圈依賴)
在 /work/testng/src 目錄下建立一個名為 DependencyTestUsingAnnotation.java 的 Java 類檔案。
import org.testng.Assert; import org.testng.annotations.Test; public class DependencyTestUsingAnnotation { String message = "Manisha"; MessageUtil messageUtil = new MessageUtil(message); @Test(groups = { "init" }) public void testPrintMessage() { System.out.println("Inside testPrintMessage()"); message = "Manisha"; Assert.assertEquals(message, messageUtil.printMessage()); } @Test(dependsOnGroups = { "init.*" }) public void testSalutationMessage() { System.out.println("Inside testSalutationMessage()"); message = "Hi!" + "Manisha"; Assert.assertEquals(message, messageUtil.salutationMessage()); } @Test(groups = { "init" }) public void initEnvironmentTest() { System.out.println("This is initEnvironmentTest"); } }
在此示例中,testSalutationMessage() 宣告為依賴於任何與正則表示式“init.*”匹配的組,這保證了在 testSalutationMessage() 之前始終會呼叫 testPrintMessage() 和 initEnvironmentTest() 方法。
如果依賴的方法失敗,並且您對其具有硬依賴關係 (alwaysRun=false,這是預設值),則依賴它的方法不會標記為 FAIL,而是標記為 SKIP。跳過的測試方法將作為此類在最終報告中報告(在 HTML 中的顏色既不是紅色也不是綠色),這很重要,因為跳過的測試方法不一定是失敗的測試方法。
建立 testng.xml
在 /work/testng/src 目錄下建立 testng.xml 來執行測試用例。
<?xml version = "1.0" encoding = "UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > <suite name = "Suite1"> <test name = "test1"> <classes> <class name = "DependencyTestUsingAnnotation" /> </classes> </test> </suite>
使用 javac 編譯 MessageUtil 和測試用例類。
/work/testng/src$ javac MessageUtil.java DependencyTestUsingAnnotation.java
現在,執行 testng.xml,它將僅在執行 initEnvironmentTest() 方法後執行 testSalutationMessage() 方法。
/work/testng/src$ java org.testng.TestNG testng.xml
驗證輸出。
This is initEnvironmentTest Inside testPrintMessage() Manisha Inside testSalutationMessage() Hi!Manisha =============================================== Suite1 Total tests run: 3, Failures: 0, Skips: 0 ===============================================
dependsOnGroups 與 dependsOnMethods 的比較
使用組時,我們不再會遇到重構問題。只要我們不修改 dependsOnGroups 或 groups 屬性,我們的測試就會繼續使用正確的依賴關係設定執行。
每當需要在依賴關係圖中新增新方法時,我們只需要將其放入正確的組中並確保它依賴於正確的組即可。我們不需要修改任何其他方法。