JUnit - Einen Test schreiben

Hier sehen wir ein vollständiges Beispiel für JUnit-Tests mit der POJO-Klasse, der Business-Logik-Klasse und einer Testklasse, die vom Testläufer ausgeführt werden.

Erstellen EmployeeDetails.java in C: \> JUNIT_WORKSPACE, einer POJO-Klasse.

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 Klasse ist es gewohnt -

  • Abrufen / Festlegen des Werts des Namens des Mitarbeiters.
  • den Wert des monatlichen Gehalts des Mitarbeiters abrufen / festlegen.
  • den Wert des Alters des Mitarbeiters abrufen / festlegen.

Erstellen Sie eine Datei mit dem Namen EmpBusinessLogic.java in C: \> JUNIT_WORKSPACE, das die Geschäftslogik enthält.

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 Klasse wird zur Berechnung verwendet -

  • das Jahresgehalt eines Mitarbeiters.
  • der Bewertungsbetrag eines Mitarbeiters.

Erstellen Sie eine Datei mit dem Namen TestEmployeeDetails.java in C: \> JUNIT_WORKSPACE, das die zu testenden Testfälle enthält.

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestEmployeeDetails {
   EmpBusinessLogic empBusinessLogic = new EmpBusinessLogic();
   EmployeeDetails employee = new EmployeeDetails();

   //test to check appraisal
   @Test
   public void testCalculateAppriasal() {
      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);
		
      double appraisal = empBusinessLogic.calculateAppraisal(employee);
      assertEquals(500, appraisal, 0.0);
   }

   // test to check yearly salary
   @Test
   public void testCalculateYearlySalary() {
      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);
		
      double salary = empBusinessLogic.calculateYearlySalary(employee);
      assertEquals(96000, salary, 0.0);
   }
}

TestEmployeeDetails Klasse wird zum Testen der Methoden von verwendet EmpBusinessLogicKlasse. Es

  • testet das Jahresgehalt des Mitarbeiters.
  • testet den Beurteilungsbetrag des Mitarbeiters.

Erstellen Sie als Nächstes eine Java-Klasse mit dem Namen TestRunner.java in C: \> JUNIT_WORKSPACE, um Testfälle auszuführen.

import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;

public class TestRunner {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestEmployeeDetails.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Kompilieren Sie die Testfall- und Test Runner-Klassen mit javac.

C:\JUNIT_WORKSPACE>javac EmployeeDetails.java 
EmpBusinessLogic.java TestEmployeeDetails.java TestRunner.java

Führen Sie nun den Test Runner aus, der den in der bereitgestellten Testfallklasse definierten Testfall ausführt.

C:\JUNIT_WORKSPACE>java TestRunner

Überprüfen Sie die Ausgabe.

true