in

Mockito – Integración JUnit


En este capítulo, aprenderemos cómo integrar JUnit y Mockito juntos. Aquí crearemos una aplicación matemática que usa CalculatorService para realizar operaciones matemáticas básicas como suma, resta, multiplicación y división.

Usaremos Mockito para simular la implementación ficticia de CalculatorService. Además, hemos hecho un uso extensivo de las anotaciones para mostrar su compatibilidad con JUnit y Mockito.

El proceso se analiza a continuación paso a paso.

Paso 1: cree una interfaz llamada CalculatorService para proporcionar funciones matemáticas

Archivo: CalculatorService.java

public interface CalculatorService {
   public double add(double input1, double input2);
   public double subtract(double input1, double input2);
   public double multiply(double input1, double input2);
   public double divide(double input1, double input2);
}

Paso 2: crea una clase JAVA para representar MathApplication

Archivo: MathApplication.java

public class MathApplication {
   private CalculatorService calcService;

   public void setCalculatorService(CalculatorService calcService){
      this.calcService = calcService;
   }
   
   public double add(double input1, double input2){
      return calcService.add(input1, input2);
   }
   
   public double subtract(double input1, double input2){
      return calcService.subtract(input1, input2);
   }
   
   public double multiply(double input1, double input2){
      return calcService.multiply(input1, input2);
   }
   
   public double divide(double input1, double input2){
      return calcService.divide(input1, input2);
   }
}

Paso 3: prueba la clase MathApplication

Probemos la clase MathApplication, inyectando en ella una simulación de calculatorService. Mock será creado por Mockito.

Archivo: MathApplicationTester.java

import static org.mockito.Mockito.when;

import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   //@InjectMocks annotation is used to create and inject the mock object
   @InjectMocks 
   MathApplication mathApplication = new MathApplication();

   //@Mock annotation is used to create the mock object to be injected
   @Mock
   CalculatorService calcService;

   @Test
   public void testAdd(){
      //add the behavior of calc service to add two numbers
      when(calcService.add(10.0,20.0)).thenReturn(30.00);
		
      //test the add functionality
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
   }
}

Paso 4: crear una clase para ejecutar en casos de prueba

Cree un archivo de clase java llamado TestRunner en C> Mockito_WORKSPACE para ejecutar los casos de prueba.

Archivo: TestRunner.java

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(MathApplicationTester.class);
      
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
      
      System.out.println(result.wasSuccessful());
   }
}  	

Paso 5: verificar el resultado

Compila las clases usando javac compilador de la siguiente manera:

C:Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

Ahora ejecute Test Runner para ver el resultado:

C:Mockito_WORKSPACE>java TestRunner

Verifique la salida.

true

Para obtener más información sobre JUnit, consulte el Tutorial de JUnit en Tutorials Point.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

logo motorola

¿Cómo restablecer o reiniciar un teléfono Motorola a la configuración de fábrica?

apple touch icon@2

java: convierte la hora local a UTC y viceversa