Diferencia entre revisiones de «Mockito»
(→Invocación a un método estático) |
(→Invocación a un método estático) |
||
Línea 48: | Línea 48: | ||
Para mockear métodos estáticos, según el [http://code.google.com/p/mockito/wiki/FAQ FAQ] de mockito, esto no es posible. Pero nombra 2 framewors que pueden resultarnos útil [http://jmockit.dev.java.net/ JMockit] y [http://code.google.com/p/powermock PowerMock] | Para mockear métodos estáticos, según el [http://code.google.com/p/mockito/wiki/FAQ FAQ] de mockito, esto no es posible. Pero nombra 2 framewors que pueden resultarnos útil [http://jmockit.dev.java.net/ JMockit] y [http://code.google.com/p/powermock PowerMock] | ||
− | |||
<code java> | <code java> |
Revisión del 14:31 5 nov 2010
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.
Contenido
Características principales
- Se pueden crear mocks de interfaces y clases concretas.
- Verificación de invocaciones (cantidad exacta, al menos una vez, órden de invocación, etc.)
- 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).
- 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
Invocación a un método estático
Para mockear métodos estáticos, según el FAQ de mockito, esto no es posible. Pero nombra 2 framewors que pueden resultarnos útil JMockit y PowerMock
@RunWith(PowerMockRunner.class)
@PrepareForTest(ClaseConMetodosEstaticos.class)
public class DosIdeasTestCase {
@Test public void testMetodo_conInvocacionAMetodosEstaticos() {
//PowerMockito mockea los metodos estaticos que se encuentren en la //clase ClaseConMetodosEstaticos PowerMockito.mockStatic(ClaseConMetodosEstaticos.class);
//Con mockito determinamos el retorno del metodo estatico when(ClaseConMetodosEstaticos.firstStaticMethod(param)).thenReturn(value);
// ejecucion instance.invocarMetodoEstatico();
//Por cada metodo estatico que se quiere verificar se debe invocar //a PowerMockito.verifyStatic(). PowerMockito.verifyStatic(); ClaseConMetodosEstaticos.secondStaticMethod(); }
}
Para mas ejemplos de Mockito junto a PowerMock ver los ejemplos provisto por la documentación de PowerMock.
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.
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);