JUnit - pisanie testu

Tutaj zobaczymy jeden kompletny przykład testowania JUnit przy użyciu klasy POJO, klasy logiki biznesowej i klasy testowej, które zostaną uruchomione przez moduł uruchamiający testy.

Stwórz EmployeeDetails.java w C: \> JUNIT_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.

Utwórz plik o nazwie EmpBusinessLogic.java w C: \> JUNIT_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.
  • wycenę pracownika.

Utwórz plik o nazwie TestEmployeeDetails.java w C: \> JUNIT_WORKSPACE, który zawiera przypadki testowe do przetestowania.

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 klasa służy do testowania metod EmpBusinessLogicklasa. To

  • testuje roczne wynagrodzenie pracownika.
  • sprawdza kwotę wyceny pracownika.

Następnie utwórz plik klasy Java o nazwie TestRunner.java w C: \> JUNIT_WORKSPACE, aby wykonać przypadek testowy.

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());
   }
}

Skompiluj przypadek testowy i klasy Test Runner przy użyciu javac.

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

Teraz uruchom Test Runner, który uruchomi przypadek testowy zdefiniowany w podanej klasie Test Case.

C:\JUNIT_WORKSPACE>java TestRunner

Sprawdź dane wyjściowe.

true