Учебники

TestNG — тест зависимостей

Иногда вам может потребоваться вызвать методы в тестовом примере в определенном порядке, или вы можете разделить некоторые данные и состояния между методами. Этот вид зависимостей поддерживается TestNG, так как он поддерживает объявление явных зависимостей между методами тестирования.

TestNG позволяет указывать зависимости либо с помощью —

  • Использование атрибутов depennoSnMethods в аннотациях @Test, ИЛИ.

  • Использование атрибутов depennoSnGroups в аннотациях @Test.

Использование атрибутов depennoSnMethods в аннотациях @Test, ИЛИ.

Использование атрибутов depennoSnGroups в аннотациях @Test.

Пример использования зависимости от методы

Создать класс

Создайте Java-класс для тестирования, скажем, MessageUtil.java в 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;
   }
}

Создать тестовый класс

  • Создайте тестовый класс Java, скажем, DependencyTestUsingAnnotation.java.

  • Добавьте тестовые методы testPrintMessage () и testSalutationMessage () и initEnvironmentTest () в ваш тестовый класс.

  • Добавьте атрибут depenOnMethods = {«initEnvironmentTest»} в аннотацию @Test метода testSalutationMessage () .

Создайте тестовый класс Java, скажем, DependencyTestUsingAnnotation.java.

Добавьте тестовые методы testPrintMessage () и testSalutationMessage () и initEnvironmentTest () в ваш тестовый класс.

Добавьте атрибут depenOnMethods = {«initEnvironmentTest»} в аннотацию @Test метода testSalutationMessage () .

Создайте имя файла Java-класса DependencyTestUsingAnnotation.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
   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

Создайте testng.xml в C: \> TestNG_WORKSPACE для выполнения тестовых наборов .

<?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>

Скомпилируйте классы MessageUtil, Test case, используя javac.

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

Теперь запустите testng.xml, который запустит метод testSalutationMessage () только после выполнения метода initEnvironmentTest ().

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

Пример использования depenOnGroups

Вы также можете иметь методы, которые зависят от целых групп. Давайте иметь пример, чтобы продемонстрировать это.

Создать класс

Создайте Java-класс для тестирования, скажем, MessageUtil.java в 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;
   }
}

Создать тестовый класс

  • Создайте тестовый класс Java, скажем, DependencyTestUsingAnnotation.java.

  • Добавьте тестовые методы testPrintMessage () testSalutationMessage () и initEnvironmentTest () в ваш тестовый класс и добавьте их в группу «init».

  • Добавьте атрибут variableOnMethods = {«init. *»} В аннотацию @Test метода testSalutationMessage () .

Создайте тестовый класс Java, скажем, DependencyTestUsingAnnotation.java.

Добавьте тестовые методы testPrintMessage () testSalutationMessage () и initEnvironmentTest () в ваш тестовый класс и добавьте их в группу «init».

Добавьте атрибут variableOnMethods = {«init. *»} В аннотацию @Test метода testSalutationMessage () .

Создайте файл Java-класса с именем DependencyTestUsingAnnotation.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. *», Что гарантирует, что методы testPrintMessage () и initEnvironmentTest () всегда будут вызываться перед testSalutationMessage ().

Если метод зависел от сбоев, и у вас есть жесткая зависимость от него (AlwaysRun = false, который используется по умолчанию), методы, которые зависят от него, помечаются не как FAIL, а как SKIP. Пропущенные методы будут указаны как таковые в окончательном отчете (цветом, который не является ни красным, ни зеленым в HTML), что важно, поскольку пропущенные методы не обязательно являются сбоями.

Создать testng.xml

Создайте testng.xml в C: \> TestNG_WORKSPACE для выполнения тестовых наборов .

<?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>

Скомпилируйте классы MessageUtil, Test case, используя javac.

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

Теперь запустите testng.xml, который запустит метод testSalutationMessage () только после выполнения метода initEnvironmentTest () .

C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml

Проверьте вывод.

При использовании групп мы больше не сталкиваемся с проблемами рефакторинга. До тех пор, пока мы не изменим атрибуты depenOnGroups или groups, наши тесты будут продолжаться с правильной настройкой зависимостей.

Всякий раз, когда необходимо добавить новый метод в граф зависимостей, все, что нам нужно сделать, это поместить его в нужную группу и убедиться, что он зависит от правильной группы. Нам не нужно изменять любой другой метод.