Diferencia entre revisiones de «Spring Test MVC»
(→Test del método) |
|||
Línea 48: | Línea 48: | ||
El proyecto demo se puede descargar de nuestro proyecto en [http://code.google.com/p/dosideas-aplicaciones-modelo/source/browse/ google-code]. | El proyecto demo se puede descargar de nuestro proyecto en [http://code.google.com/p/dosideas-aplicaciones-modelo/source/browse/ google-code]. | ||
+ | == Ver también == | ||
+ | [https://github.com/SpringSource/spring-test-mvc Spring Test MVC ] | ||
[[Category:Spring MVC]] | [[Category:Spring MVC]] |
Revisión del 14:40 12 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.
Spring Test MVC mockea el contexto web de spring y permite invocar los servicio expuesto en los controladores ejecutando los interceptores de conversión y mapeo de Spring MVC.
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.