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
===============================================
廣告

© . All rights reserved.