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 -