Diferencia entre revisiones de «Spring Test MVC»

De Dos Ideas.
Saltar a: navegación, buscar
(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 [[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 de [[Spring]] RestTemplate o directamente con herramientas como selenium y también un alto costo de mantenimiento.
+
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)
+
@ResponseStatus(HttpStatus.CREATED)
    public @ResponseBody Persona guardar(@RequestBody Persona persona) {
+
public @ResponseBody Persona guardar(@RequestBody Persona persona) {
        persona.setId(new Random(Long.MAX_VALUE).nextInt());
+
  persona.setId(new Random(Long.MAX_VALUE).nextInt());
        persona.setNombre(persona.getNombre());
+
  persona.setNombre(persona.getNombre());
        return persona;
+
  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\"}";
+
  String personaJson = "{\"nombre\":\"coco\"}";
        MockMvcBuilders.standaloneSetup(new PersonaController()).build()
+
  MockMvcBuilders.standaloneSetup(new PersonaController()).build()
                /* Operación y servicio */
+
  /* Operación y servicio */
                .perform(post("/persona")
+
  .perform(post("/persona")
                /* Content type para indicar formato de la información del body */
+
  /* Content type para indicar formato de la información del body */
                .contentType(MediaType.APPLICATION_JSON)
+
  .contentType(MediaType.APPLICATION_JSON)
                /* Accep para que la respuesta sea JSON */
+
  /* Accep para que la respuesta sea JSON */
                .accept(MediaType.APPLICATION_JSON)
+
  .accept(MediaType.APPLICATION_JSON)
                /* Set del body */
+
  /* Set del body */
                .body(personaJson.getBytes()))
+
  .body(personaJson.getBytes()))
                /* Imprime por consola */
+
  /* Imprime por consola */
                .andDo(print())
+
  .andDo(print())
                /* Control del status http */
+
  /* Control del status http */
                .andExpect(status().isCreated())
+
  .andExpect(status().isCreated())
                /* Control de que exista el atributo nombre */
+
  /* Control de que exista el atributo nombre */
                .andExpect(jsonPath("nombre").exists())
+
  .andExpect(jsonPath("nombre").exists())
                /* Control de que exista el atributo id */
+
  /* Control de que exista el atributo id */
                .andExpect(jsonPath("id").exists())
+
  .andExpect(jsonPath("id").exists())
                /* Control del valor del atributo nombre */
+
  /* Control del valor del atributo nombre */
                .andExpect(jsonPath("nombre").value("coco"));
+
  .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>