TestNG - Pisanie testów
Pisanie testu w TestNG obejmuje zasadniczo następujące kroki -
Napisz logikę biznesową swojego testu i wstaw adnotacje TestNG w swoim kodzie.
Dodaj informacje o swoim teście (np. Nazwę klasy, grupy, które chcesz uruchomić, itp.) W pliku testng.xml lub build.xml.
Uruchom TestNG.
Tutaj zobaczymy jeden kompletny przykład testowania TestNG przy użyciu klasy POJO, klasy logiki biznesowej i testowego pliku XML, który zostanie uruchomiony przez TestNG.
Stwórz EmployeeDetails.java w C:\>TestNG_WORKSPACE, która jest klasą POJO.
public class EmployeeDetails {
   private String name;
   private double monthlySalary;
   private int age;
   
   // @return the name
   public String getName() {
      return name;
   }
   
   // @param name the name to set
   
   public void setName(String name) {
      this.name = name;
   }
   
   // @return the monthlySalary
   public double getMonthlySalary() {
      return monthlySalary;
   }
   
   // @param monthlySalary the monthlySalary to set
   
   public void setMonthlySalary(double monthlySalary) {
      this.monthlySalary = monthlySalary;
   }
   
   // @return the age
 
   public int getAge() {
      return age;
   }
   
   // @param age the age to set
 
   public void setAge(int age) {
      this.age = age;
   }
} 
    EmployeeDetails klasa jest używana do -
- pobierz / ustaw wartość nazwiska pracownika.
 - uzyskać / ustawić wysokość miesięcznego wynagrodzenia pracownika.
 - pobrać / ustawić wartość wieku pracownika.
 
Stworzyć EmpBusinessLogic.java w C:\>TestNG_WORKSPACE, który zawiera logikę biznesową.
public class EmpBusinessLogic {
   // Calculate the yearly salary of employee
   public double calculateYearlySalary(EmployeeDetails employeeDetails) {
      double yearlySalary = 0;
      yearlySalary = employeeDetails.getMonthlySalary() * 12;
      return yearlySalary;
   }
	
   // Calculate the appraisal amount of employee
   public double calculateAppraisal(EmployeeDetails employeeDetails) {
   
      double appraisal = 0;
      
      if(employeeDetails.getMonthlySalary() < 10000) {
         appraisal = 500;
         
      } else {
         appraisal = 1000;
      }
      
      return appraisal;
   }
} 
    EmpBusinessLogic klasa służy do obliczania -
- roczne wynagrodzenie pracownika.
 - wyceniona kwota pracownika.
 
Teraz stwórzmy klasę TestNG o nazwie TestEmployeeDetails.javaw C: \> TestNG_WORKSPACE. Klasa TestNG to klasa Java, która zawiera co najmniej jedną adnotację TestNG. Ta klasa zawiera przypadki testowe do przetestowania. Test TestNG można skonfigurować za pomocą adnotacji @BeforeXXX i @AfterXXX (zobaczymy to w rozdziale TestNG - Procedura wykonania ), co pozwala na wykonanie pewnej logiki Javy przed i po określonym punkcie.
import org.testng.Assert;
import org.testng.annotations.Test;
public class TestEmployeeDetails {
   EmpBusinessLogic empBusinessLogic = new EmpBusinessLogic();
   EmployeeDetails employee = new EmployeeDetails();
   @Test
   public void testCalculateAppriasal() {
   
      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);
      
      double appraisal = empBusinessLogic.calculateAppraisal(employee);
      Assert.assertEquals(500, appraisal, 0.0, "500");
   }
   // Test to check yearly salary
   @Test
   public void testCalculateYearlySalary() {
   
      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);
      
      double salary = empBusinessLogic.calculateYearlySalary(employee);
      Assert.assertEquals(96000, salary, 0.0, "8000");
   }
} 
    TestEmployeeDetails klasa służy do testowania metod EmpBusinessLogicklasa. Wykonuje następujące czynności -
Testuje roczne wynagrodzenie pracownika.
Testuje wycenę pracownika.
Zanim będzie można uruchomić testy, należy skonfigurować TestNG przy użyciu specjalnego pliku XML, nazwanego konwencjonalnie testng.xml. Składnia tego pliku jest bardzo prosta, a jego zawartość jest taka, jak pokazano poniżej. Utwórz ten plik wC:\>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 = "TestEmployeeDetails"/>
      </classes>
   </test>
</suite> 
    Szczegóły powyższego pliku są następujące -
Zestaw jest reprezentowany przez jeden plik XML. Może zawierać jeden lub więcej testów i jest definiowany przez tag <suite>.
Tag <test> reprezentuje jeden test i może zawierać jedną lub więcej klas TestNG.
Tag <class> reprezentuje klasę TestNG. Jest to klasa Java, która zawiera co najmniej jedną adnotację TestNG. Może zawierać jedną lub więcej metod testowych.
Skompiluj klasy przypadków testowych przy użyciu javac.
C:\TestNG_WORKSPACE>javac EmployeeDetails.java EmpBusinessLogic.java TestEmployeeDetails.java 
    Teraz TestNG za pomocą następującego polecenia -
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml 
    Jeśli wszystko zostało zrobione poprawnie, powinieneś zobaczyć wyniki swoich testów w konsoli. Ponadto TestNG tworzy bardzo ładny raport HTML w folderze o nazwietest-outputktóry jest automatycznie tworzony w bieżącym katalogu. Jeśli go otworzysz i załadujesz index.html, zobaczysz stronę podobną do tej na obrazku poniżej -