TestNG - Тест на зависимость
Иногда вам может потребоваться вызвать методы в тестовом примере в определенном порядке или вы можете захотеть поделиться некоторыми данными и состоянием между методами. Этот вид зависимости поддерживается TestNG, поскольку он поддерживает объявление явных зависимостей между методами тестирования.
TestNG позволяет вам указывать зависимости либо с помощью -
Использование атрибута dependsOnMethods в аннотациях @Test ИЛИ.
Использование атрибута dependsOnGroups в аннотациях @Test.
Пример использования supportsOnMethods
Создать класс
Создайте класс 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 ().
Добавить атрибут dependsOnMethods = {"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
===============================================
Пример использования dependsOnGroups
У вас также могут быть методы, которые зависят от целых групп. Приведем пример, чтобы продемонстрировать это.
Создать класс
Создайте класс 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».
Добавить атрибут dependsOnMethods = {"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
Проверьте вывод.
This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================
dependsOnGroups Vs dependsOnMethods
При использовании групп мы больше не сталкиваемся с проблемами рефакторинга. До тех пор, пока мы не изменяем атрибуты dependsOnGroups или groups, наши тесты будут продолжать работать с правильными настройками зависимостей.
Каждый раз, когда необходимо добавить новый метод в граф зависимостей, все, что нам нужно сделать, это поместить его в нужную группу и убедиться, что он зависит от правильной группы. Нам не нужно изменять какой-либо другой метод.