Иногда вам может потребоваться вызвать методы в тестовом примере в определенном порядке, или вы можете разделить некоторые данные и состояния между методами. Этот вид зависимостей поддерживается 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, наши тесты будут продолжаться с правильной настройкой зависимостей.
Всякий раз, когда необходимо добавить новый метод в граф зависимостей, все, что нам нужно сделать, это поместить его в нужную группу и убедиться, что он зависит от правильной группы. Нам не нужно изменять любой другой метод.