Diferencia entre revisiones de «Mockito»

De Dos Ideas.
Saltar a: navegación, buscar
(Ejemplo de Mockito para mockear appender de log4j)
(Invocación a un método privado)
Línea 47: Línea 47:
 
I found just what I was ndeeed, and it was entertaining!
 
I found just what I was ndeeed, and it was entertaining!
  
===Invocación a un método privado===
+
Last one to ultiize this is a rotten egg!
 
 
<code java>
 
public class PruebaMetodoPrivado {
 
 
 
    public String decirHola(String nombre) {
 
        return decirHolaNombre(nombre);
 
    }
 
 
 
    private String decirHolaNombre(String nombre) {
 
        return "Hola "+nombre;
 
    }
 
}
 
</code>
 
 
 
<code java>
 
@RunWith(PowerMockRunner.class)
 
@PrepareForTest(PruebaMetodoPrivado.class)
 
public class PruebaMetodoPrivadoTest {
 
 
 
  @Spy
 
  PruebaMetodoPrivado metodoPrivado = new PruebaMetodoPrivado();
 
   
 
    @Test
 
    public void mockMetodoPrivado() throws Exception {
 
 
 
Assert.assertEquals("Hola Juan", metodoPrivado.decirHola("Juan"));
 
        doReturn("Chau Juan").when(metodoPrivado,"decirHolaNombre","Juan");
 
        Assert.assertEquals("Chau Juan",metodoPrivado.decirHola("Juan"));
 
        verifyPrivate(metodoPrivado,
 
                      Mockito.times(2)).invoke("decirHolaNombre","Juan");
 
    }
 
}
 
 
 
</code>
 
  
 
===Inicialización de atributos estaticos===
 
===Inicialización de atributos estaticos===

Revisión del 16:02 7 sep 2011

Mockito es una librería Java para la creación de Mock Object muy usados para el testeo unitario en Test Driven Development, basado en EasyMock.

Mockito fue creado con el objetivo de simplificar y solucionar algunos de los temas antes mencionados. EasyMock y Mockito puede hacer exactamente las mismas cosas, pero Mockito tiene un API más natural y práctico de usar.

Características principales

  1. Se pueden crear mocks de interfaces y clases concretas.
  2. Verificación de invocaciones (cantidad exacta, al menos una vez, órden de invocación, etc.)
  3. El stack trace se mantiene limpio, ya que los errores ocurren en los assert que se hagan (y no dentro del método bajo prueba, como en EasyMock).
  4. Un API más clara para crear stubs y verificaciones

Ejemplo de uso

import static org.mockito.Mockito.*; ..... //creamos el mock y el stub ArrayList instance = mock(ArrayList.class); doReturn("hola mundo").when(instance).get(0);

//ejecutamos la lógica a probar instance.get(0);

//verificamos que se hayan invocado los métodos verify(instance).get(0);

Más de una invocación a un mismo método

Algunas veces necesitamos que un método retorne un valor y que en la segunda invocación retorne nulo o una excepción. Para eso, anidamos los retornos:

//Retornos para las 2 invocaciones doReturn("algo").doReturn(null).when(instance).scrollNext();

//ejecutamos la lógica a probar instance.unMetodoQueUsaScroll();

//verificamos que se haya invocado el mismo método dos veces verify(instance, times(2)).scrollNext();

Ejemplos de Mockito junto a PowerMock

I found just what I was ndeeed, and it was entertaining!

Last one to ultiize this is a rotten egg!

Inicialización de atributos estaticos

public class PruebaInicializacionEstaticos {

   private static final String atributo = new String("CHAU");

   public String crearObjetoLista() {
       return atributo;
   }

}

@RunWith(PowerMockRunner.class) @SuppressStaticInitializationFor("PruebaInicializacionEstaticos") @PrepareForTest(PruebaInicializacionEstaticos.class) public class PruebaMetodoPrivadoTest {


  PruebaInicializacionEstaticos pruebaInicializacionEstaticos = 
                                   new PruebaInicializacionEstaticos();

   @Test
   public void controlCreacionLista() throws Exception {

Assert.assertNull(pruebaInicializacionEstaticos.retornarAtrinbuto());

       String s = "Hola";
       Whitebox.setInternalState(pruebaInicializacionEstaticos.class,"atributo", s);
       Assert.assertEquals(s, pruebaInicializacionEstaticos.retornarAtrinbuto());
   }

}

Captura creación de objetos

public class PruebaCreacionObjeto {

   public List crearObjetoLista() {
       return new ArrayList();
   }

}

@RunWith(PowerMockRunner.class) @PrepareForTest(PruebaCreacionObjeto.class) public class PruebaMetodoPrivadoTest {

  @Spy
  PruebaCreacionObjeto pruebaCreacionObjeto = new PruebaCreacionObjeto();

   @Test
   public void controlCreacionLista() throws Exception {
       List list = new ArrayList();
       list.add("Hola");
       whenNew(ArrayList.class).withNoArguments().thenReturn((ArrayList) list);
       List resultado = pruebaCreacionObjeto.crearObjetoLista();
       Assert.assertEquals(list, resultado);
       verifyNew(ArrayList.class);
   }

}

Para mas ejemplos de Mockito junto a PowerMock ver los ejemplos provisto por la documentación de PowerMock.

Descargar proyecto NetBeans demo de los ejemplos

PowerMockito & Cobertura

Existe un problema al utilizar PowerMockito con Cobertura (versión 1.8.4), este último no registra la corrida de los test con anotación @PrepareForTest, dando como resultados falta de cobertura. Para solucionar este inconveniente solo hay que actualizar la versión de Cobertura.

I didn't know where to find this info then koaobm it was here.

BDDMockito

BDDMokcito es una clase alternativa que ofrece Mockito para crear pruebas al estilo Behavior Driven Development (BDD) (es decir, con bloques dado / cuando / entonces).

El problema es que el API de Mockito usa la palabra "when" y no se integra bien con los comentarios //given //when //then (según BDD, el stubbing forma parte del área //given, y no del //when).

BDDMockito agrega una clase que tiene alias para los métodos de stub, usando given(Object).

import static org.mockito.BDDMockito.*;

Vendedor vendedor = mock(Vendedor.class);
Negocio negocio = new Negocio(vendedor);

@Test
public void comprarPan() throws Exception {
  //given  
  given(vendedor.buscarPan()).willReturn(new Pan());
  
  //when
  Compra compra = negocio.comprarPan();
  
  //then
  assertThat(compra, contienePan());
} 

Stubbing con void y excepciones:

  //given
  willThrow(new RuntimeException("boo")).given(mock).foo();
  
  //when
  Result result = sistemaBajoPrueba.ejecutar();
  
  //then
  assertEquals(failure, result); 

AKAIK you've got the aswner in one!