TestNG - параметризованный тест
Еще одна интересная функция, доступная в TestNG, - это parametric testing. В большинстве случаев вы столкнетесь со сценарием, в котором бизнес-логика требует чрезвычайно разнообразного количества тестов.Parameterized tests позволяют разработчикам запускать один и тот же тест снова и снова, используя разные значения.
TestNG позволяет передавать параметры непосредственно в методы тестирования двумя разными способами:
- С testng.xml
- С поставщиками данных
Передача параметров с помощью testng.xml
С помощью этого метода вы определяете простые параметры в файле testng.xml, а затем ссылаетесь на эти параметры в исходных файлах. Приведем пример, демонстрирующий, как использовать эту технику для передачи параметров.
Создать класс тестового набора
Создайте тестовый класс java, скажем, ParameterizedTest1.java.
Добавьте тестовый метод parameterTest () в свой тестовый класс. Этот метод принимает строку в качестве входного параметра.
Добавьте к этому методу аннотацию @Parameters ("myName") . Параметру будет передано значение из testng.xml, которое мы увидим на следующем шаге.
Создайте файл класса Java с именем ParameterizedTest1.java в C:\>TestNG_WORKSPACE.
import org.testng.annotations.Parameters;
import org.testng.annotations.Test;
public class ParameterizedTest1 {
@Test
@Parameters("myName")
public void parameterTest(String myName) {
System.out.println("Parameterized value is : " + myName);
}
}
Создать 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">
<parameter name = "myName" value="manisha"/>
<classes>
<class name = "ParameterizedTest1" />
</classes>
</test>
</suite>
Мы также можем определить параметры на уровне <suite>. Предположим, мы определили myName на уровнях <suite> и <test>. В таких случаях применяются обычные правила определения объема работ. Это означает, что любой класс внутри тега <test> увидит значение параметра, определенного в <test>, а классы в остальной части файла testng.xml увидят значение, определенное в <suite>.
Скомпилируйте класс тестового примера с помощью javac.
C:\TestNG_WORKSPACE>javac ParameterizedTest1.java
Теперь запустите testng.xml, который запустит метод parameterTest . TestNG сначала попытается найти параметр с именем myName в теге <test>, а затем, если не сможет его найти, выполнит поиск в теге <suit>, который его включает.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Проверьте вывод.
Parameterized value is : manisha
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
TestNG автоматически попытается преобразовать значение, указанное в testng.xml, в тип вашего параметра. Вот поддерживаемые типы -
- String
- int/Integer
- boolean/Boolean
- byte/Byte
- char/Character
- double/Double
- float/Float
- long/Long
- short/Short
Передача параметров с помощью провайдеров данных
Когда вам нужно передать сложные параметры или параметры, которые необходимо создать из Java (сложные объекты, объекты, считанные из файла свойств или базы данных, и т. Д.), Параметры можно передать с помощью Dataproviders.
Поставщик данных - это метод, помеченный @DataProvider. Эта аннотация имеет только один строковый атрибут: свое имя. Если имя не указано, имя поставщика данных по умолчанию автоматически соответствует имени метода. Поставщик данных возвращает массив объектов.
Следующие примеры демонстрируют, как использовать поставщиков данных. Первый пример касается @DataProvider, использующего Vector, String или Integer в качестве параметра, а второй пример - @DataProvider, использующий объект в качестве параметра.
Пример 1
Здесь @DataProvider передает Integer и Boolean в качестве параметра.
Create Java class
Создайте класс Java с именем PrimeNumberChecker.java. Этот класс проверяет, является ли число простым. Создайте этот класс вC:\>TestNG_WORKSPACE.
public class PrimeNumberChecker {
public Boolean validate(final Integer primeNumber) {
for (int i = 2; i < (primeNumber / 2); i++) {
if (primeNumber % i == 0) {
return false;
}
}
return true;
}
}
Create Test Case Class
Создайте тестовый класс Java, скажем, ParamTestWithDataProvider1.java.
Определите метод primeNumbers (), который определяется как поставщик данных с помощью аннотации. Этот метод возвращает массив объектов.
Добавьте тестовый метод testPrimeNumberChecker () в свой тестовый класс. Этот метод принимает в качестве входных параметров целое число и логическое значение. Этот метод проверяет, является ли переданный параметр простым числом.
Добавьте к этому методу аннотацию @Test (dataProvider = "test1") . Атрибут dataProvider отображается на «test1».
Создайте файл класса Java с именем ParamTestWithDataProvider1.java в C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider1 {
private PrimeNumberChecker primeNumberChecker;
@BeforeMethod
public void initialize() {
primeNumberChecker = new PrimeNumberChecker();
}
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] {{2, true}, {6, false}, {19, true}, {22, false}, {23, true}};
}
// This test will run 4 times since we have 5 parameters defined
@Test(dataProvider = "test1")
public void testPrimeNumberChecker(Integer inputNumber, Boolean expectedResult) {
System.out.println(inputNumber + " " + expectedResult);
Assert.assertEquals(expectedResult, primeNumberChecker.validate(inputNumber));
}
}
Create 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 = "ParamTestWithDataProvider1" />
</classes>
</test>
</suite>
Скомпилируйте класс тестового примера с помощью javac.
C:\TestNG_WORKSPACE>.javac ParamTestWithDataProvider1.java PrimeNumberChecker.java
Теперь запустите testng.xml.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Проверьте вывод.
2 true
6 false
19 true
22 false
23 true
===============================================
Suite1
Total tests run: 5, Failures: 0, Skips: 0
===============================================
Пример 2
Здесь @DataProvider передает Object как параметр.
Create Java class
Создайте Java-класс Bean.java, который представляет собой простой объект с методами get / set, в C:\>TestNG_WORKSPACE.
public class Bean {
private String val;
private int i;
public Bean(String val, int i) {
this.val = val;
this.i = i;
}
public String getVal() {
return val;
}
public void setVal(String val) {
this.val = val;
}
public int getI() {
return i;
}
public void setI(int i) {
this.i = i;
}
}
Create Test Case Class
Создайте тестовый класс Java, скажем, ParamTestWithDataProvider2.java.
Определите метод primeNumbers (), который определяется как поставщик данных с помощью аннотации. Этот метод возвращает массив объекта.
Добавьте тестовый метод testMethod () в свой тестовый класс. Этот метод принимает объектный компонент в качестве параметра.
Добавьте к этому методу аннотацию @Test (dataProvider = "test1") . Атрибут dataProvider отображается на «test1».
Создайте файл класса java с именем ParamTestWithDataProvider2.java в C:\>TestNG_WORKSPACE.
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider2 {
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] { { new Bean("hi I am the bean", 111) } };
}
@Test(dataProvider = "test1")
public void testMethod(Bean myBean) {
System.out.println(myBean.getVal() + " " + myBean.getI());
}
}
Create 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 = "ParamTestWithDataProvider2" />
</classes>
</test>
</suite>
Скомпилируйте класс тестового примера с помощью javac.
C:\TestNG_WORKSPACE>javac ParamTestWithDataProvider2.java Bean.java
Теперь запустите testng.xml.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Проверьте вывод.
hi I am the bean 111
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================