Testng-dependency-test

提供:Dev Guides
移動先:案内検索

TestNG-依存関係テスト

テストケース内のメソッドを特定の順序で呼び出す必要がある場合や、メソッド間でデータと状態を共有したい場合があります。 この種の依存関係は、テストメソッド間の明示的な依存関係の宣言をサポートするため、TestNGでサポートされています。

TestNGでは、次のいずれかの方法で依存関係を指定できます-

  • @Testアノテーションで属性_dependsOnMethods_を使用、または。
  • @Testアノテーションで_dependsOnGroups_属性を使用します。

_dependsOnMethods_を使用した例

クラスを作成する

*C:\> TestNG_WORKSPACE* に *MessageUtil.java* などのテスト対象のJavaクラスを作成します。
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;
   }
}

テストケースクラスを作成する

  • DependencyTestUsingAnnotation.javaなどのJavaテストクラスを作成します。

  • テストクラスにテストメソッドtestPrintMessage()とtestSalutationMessage()、およびinitEnvironmentTest()を追加します。

  • 属性 dependsOnMethods = \ {"initEnvironmentTest"} を* testSalutationMessage()*メソッドの@Testアノテーションに追加します。

    *C:\> TestNG_WORKSPACE* にJavaクラスファイル名 *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を作成する

*C:\> TestNG_WORKSPACE* に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、テストケースクラスをコンパイルします。

C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java

次に、testng.xmlを実行します。これは、initEnvironmentTest()メソッドの実行後にのみtestSalutationMessage()メソッドを実行します。

C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" 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_を使用した例

グループ全体に依存するメソッドを持つこともできます。 これを実証する例があります。

クラスを作成する

*C:\> TestNG_WORKSPACE* に *MessageUtil.java* などのテスト対象のJavaクラスを作成します。
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;
   }
}

テストケースクラスを作成する

  • DependencyTestUsingAnnotation.javaなどのJavaテストクラスを作成します。

  • テストメソッド、testPrintMessage()、testSalutationMessage()、およびinitEnvironmentTest()をテストクラスに追加し、それらをグループ「init」に追加します。

  • 属性* dependsOnMethods = \ {"init。"} *を testSalutationMessage()*メソッドの@Testアノテーションに追加します。

    *DependencyTestUsingAnnotation.java* という名前のJavaクラスファイルを *C:\> TestNG_WORKSPACE* に作成します。
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を作成する

*C:\> TestNG_WORKSPACE* に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、テストケースクラスをコンパイルします。

C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java

次に、testinit.xmlを実行します。これは、_initEnvironmentTest()_メソッドの実行後にのみ_testSalutationMessage()_メソッドを実行します。

C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" 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

  • グループを使用すると、リファクタリングの問題にさらされなくなります。 dependOnGroupsまたはgroups属性を変更しない限り、適切な依存関係を設定してテストを実行し続けます。
  • 依存関係グラフに新しいメソッドを追加する必要があるときはいつでも、適切なグループにそれを配置し、正しいグループに依存することを確認するだけです。 他の方法を変更する必要はありません。