Diferencia entre revisiones de «Spring Test MVC»
(Página creada con '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 resp…') |
|||
Línea 1: | Línea 1: | ||
− | El objetivo de [[Spring Test Mvc]] es facilitar y mejorar los test de los controladores de | + | 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. |
Línea 8: | Línea 8: | ||
<code java> | <code java> | ||
@RequestMapping(value="/persona",method= RequestMethod.POST) | @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; | |
− | + | } | |
</code> | </code> | ||
Línea 21: | Línea 21: | ||
@Test | @Test | ||
public void guardar_retorna_persona_con_id() throws Exception { | 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")); | |
} | } | ||
<code> | <code> |
Revisión del 12:54 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"));
} <code>