Diferencia entre revisiones de «Spring Test MVC»

De Dos Ideas.
Saltar a: navegación, buscar
Línea 2: Línea 2:
  
  
Ejemplo
+
==Ejemplo==
  
Método del controller.
+
===Método del controller===
  
 
<code java>
 
<code java>
Línea 16: Línea 16:
 
</code>  
 
</code>  
  
Test del método.
+
===Test del método===
  
 
<code java>
 
<code java>
Línea 44: Línea 44:
 
}
 
}
 
</code>
 
</code>
 +
 +
El proyecto demo se puede descargar de nuestro proyecto en [http://code.google.com/p/dosideas-aplicaciones-modelo/source/browse/ google-code].

Revisión del 14:24 8 mar 2012

El objetivo de Spring Test Mvc es facilitar y mejorar los test de los controladores de Spring MVC. Estos controladores utilizan muchos componentes, como el mapeo de respuestas (ResponseBody), conversiones (json, xml), mapeo de excepciones (ExceptionHandler), etc. Estos componentes no pueden ser testeados mediante los test unitarios y hasta ahora solo se podían testear mediante tests de integración, esto implica embeber un contenedor para los servlets, desplegar la aplicación y testear con el cliente REST de Spring RestTemplate o directamente con herramientas como selenium y también un alto costo de mantenimiento.


Ejemplo

Método del controller

@RequestMapping(value="/persona",method= RequestMethod.POST) @ResponseStatus(HttpStatus.CREATED) public @ResponseBody Persona guardar(@RequestBody Persona persona) {

  persona.setId(new Random(Long.MAX_VALUE).nextInt());
  persona.setNombre(persona.getNombre());
  return persona;

}

Test del método

@Test public void guardar_retorna_persona_con_id() throws Exception {

 String personaJson = "{\"nombre\":\"coco\"}";
 MockMvcBuilders.standaloneSetup(new PersonaController()).build()
 /* Operación y servicio */
 .perform(post("/persona")
 /* Content type para indicar formato de la información del body */
 .contentType(MediaType.APPLICATION_JSON)
 /* Accep para que la respuesta sea JSON */
 .accept(MediaType.APPLICATION_JSON)
 /* Set del body */
 .body(personaJson.getBytes()))
 /* Imprime por consola */
 .andDo(print())
 /* Control del status http */
 .andExpect(status().isCreated())
 /* Control de que exista el atributo nombre */
 .andExpect(jsonPath("nombre").exists())
 /* Control de que exista el atributo id */
 .andExpect(jsonPath("id").exists())
 /* Control del valor del atributo nombre */
 .andExpect(jsonPath("nombre").value("coco"));
               

}

El proyecto demo se puede descargar de nuestro proyecto en google-code.