TestNG - Test zależności
Czasami może zajść potrzeba wywołania metod w przypadku testowym w określonej kolejności lub możesz chcieć udostępnić niektóre dane i stan między metodami. Ten rodzaj zależności jest obsługiwany przez TestNG, ponieważ obsługuje deklarację jawnych zależności między metodami testowymi.
TestNG pozwala określić zależności za pomocą -
Korzystanie z atrybutu dependsOnMethods w adnotacjach @Test, LUB.
Korzystanie z atrybutu dependsOnGroups w adnotacjach @Test.
Przykład Korzystanie z dependOnMethods
Utwórz klasę
Utwórz klasę Java do przetestowania, powiedzmy MessageUtil.java w C:\>TestNG_WORKSPACE.
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;
   }
} 
    Utwórz klasę przypadku testowego
Utwórz klasę testową Java, powiedzmy DependencyTestUsingAnnotation.java.
Dodaj metody testowe, testPrintMessage () i testSalutationMessage () oraz initEnvironmentTest () do swojej klasy testowej.
Dodaj atrybut dependsOnMethods = {"initEnvironmentTest"} do adnotacji @Test dla testSalutationMessage() metoda.
Utwórz nazwę pliku klasy Java DependencyTestUsingAnnotation.java w C:\>TestNG_WORKSPACE.
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");
   }
} 
    Utwórz plik testng.xml
Utwórz plik testng.xml w formacie C:\>TestNG_WORKSPACE do wykonania przypadków testowych.
<?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> 
    Skompiluj MessageUtil, klasy przypadków testowych przy użyciu javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java 
    Teraz uruchom testng.xml, który uruchomi metodę testSalutationMessage () dopiero po wykonaniu metody initEnvironmentTest ().
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml 
    Sprawdź dane wyjściowe.
This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
=============================================== 
    Przykład Korzystanie z dependOnGroups
Możesz także mieć metody zależne od całych grup. Zobaczmy przykład, aby to zademonstrować.
Utwórz klasę
Utwórz klasę Java do przetestowania, powiedzmy MessageUtil.java w C:\>TestNG_WORKSPACE.
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;
   }
} 
    Utwórz klasę przypadku testowego
Utwórz klasę testową Java, powiedzmy DependencyTestUsingAnnotation.java.
Dodaj metody testowe, testPrintMessage () testSalutationMessage () i initEnvironmentTest () do swojej klasy testowej, a następnie dodaj je do grupy „init”.
Dodaj atrybut dependsOnMethods = {"init.*"} do adnotacji @Test dla testSalutationMessage() metoda.
Utwórz plik klasy Java o nazwie DependencyTestUsingAnnotation.java w 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");
   }
} 
    W tym przykładzie testSalutationMessage () jest zadeklarowana jako zależna od dowolnej grupy, pasująca do wyrażenia regularnego „init. *”, Co gwarantuje, że metody testPrintMessage () i initEnvironmentTest () będą zawsze wywoływane przed testSalutationMessage ().
Jeśli metoda zależna od niej nie powiedzie się i masz od niej twardą zależność (alwaysRun = false, co jest wartością domyślną), metody od niej zależne nie są oznaczone jako FAIL, ale jako SKIP. Pominięte metody będą zgłaszane jako takie w raporcie końcowym (w kolorze, który nie jest ani czerwony, ani zielony w HTML), co jest ważne, ponieważ pominięte metody niekoniecznie są błędami.
Utwórz plik testng.xml
Utwórz plik testng.xml w formacie C:\>TestNG_WORKSPACE do wykonania przypadków testowych.
<?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> 
    Skompiluj MessageUtil, klasy przypadków testowych przy użyciu javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java DependencyTestUsingAnnotation.java 
    Teraz uruchom testng.xml, który uruchomi metodę testSalutationMessage () dopiero po wykonaniu metody initEnvironmentTest () .
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml 
    Sprawdź dane wyjściowe.
This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
=============================================== 
    dependOnGroups Vs dependsOnMethods
Korzystając z grup, nie jesteśmy już narażeni na problemy z refaktoryzacją. Dopóki nie zmodyfikujemy atrybutów dependOnGroups lub groups, nasze testy będą działać z odpowiednio skonfigurowanymi zależnościami.
Ilekroć trzeba dodać nową metodę do wykresu zależności, wystarczy umieścić ją we właściwej grupie i upewnić się, że zależy od właściwej grupy. Nie musimy modyfikować żadnej innej metody.