TestNG - Test pakietu
ZA test suiteto zbiór przypadków testowych przeznaczonych do testowania zachowania lub zestawu zachowań programu. W TestNG nie możemy zdefiniować zestawu w testowaniu kodu źródłowego, ale jest on reprezentowany przez jeden plik XML, ponieważ zestaw jest funkcją wykonania. Pozwala również na elastyczną konfigurację testów . Zestaw może zawierać jeden lub więcej testów i jest definiowany przez tag <suite>.
<suite> to główny tag pliku testng.xml. Opisuje zestaw testów, który z kolei składa się z kilku sekcji <test>.
W poniższej tabeli wymieniono wszystkie atrybuty prawne, które akceptuje <suite>.
Sr.No. | Atrybut i opis |
---|---|
1 | name Nazwa tego zestawu. To jestmandatory atrybut. |
2 | verbose Poziom lub szczegółowość tego przebiegu. |
3 | parallel Czy TestNG powinien uruchamiać różne wątki, aby uruchomić ten pakiet. |
4 | thread-count Liczba wątków do użycia, jeśli tryb równoległy jest włączony (w przeciwnym razie jest ignorowany). |
5 | annotations Typ adnotacji, których używasz w testach. |
6 | time-out Domyślny limit czasu, który będzie używany we wszystkich metodach testowych znalezionych w tym teście. |
W tym rozdziale pokażemy przykład, w którym dwie klasy testowe, Test1 i Test2, działają razem przy użyciu Test Suite.
Utwórz klasę
Utwórz klasę Java do przetestowania, powiedzmy MessageUtil.java w C:\>JUNIT_WORKSPACE.
/*
* This class prints the given message on console.
*/
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 klasy przypadków testowych
Utwórz plik klasy Java o nazwie Test1.java w C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class Test1 {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
Assert.assertEquals(message, messageUtil.printMessage());
}
}
Utwórz plik klasy Java o nazwie Test2.java w C:\>TestNG_WORKSPACE.
import org.testng.Assert;
import org.testng.annotations.Test;
public class Test2 {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Manisha";
Assert.assertEquals(message,messageUtil.salutationMessage());
}
}
Teraz napiszmy plik testng.xml w formacie C:\>TestNG_WORKSPACE, która zawierałaby następujący tag <suite> -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "exampletest1">
<classes>
<class name = "Test1" />
</classes>
</test>
<test name = "exampletest2">
<classes>
<class name = "Test2" />
</classes>
</test>
</suite>
Suite1 zawiera exampletest1 i exampletest2.
Skompiluj wszystkie klasy Java za pomocą javac.
C:\TestNG_WORKSPACE>javac MessageUtil.java Test1.java Test2.java
Teraz uruchom plik testng.xml, który uruchomi przypadek testowy zdefiniowany w podanej klasie Test Case.
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
Sprawdź dane wyjściowe.
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha
===============================================
Suite1
Total tests run: 2, Failures: 0, Skips: 0
===============================================
Możesz również sprawdzić folder test-output . W folderze Suite1 można zobaczyć dwa utworzone pliki html, exampletest1.html i exampletest2.html, które wyglądałyby następująco -