无法在spring-test 5.0.3中的MockMvc异步REST服务上测试HTTP状态(在5.0.0中有效)

时间:2018-02-13 14:56:14

标签: java spring spring-test

我使用Spring Initializer(https://start.spring.io/)生成了新项目 Spring boot - 2.0.0.RC1,版本5.0.3.RELEASE。

添加了以下控制器:

@RestController
@ResponseBody
@RequestMapping(value = "/customer")
public class CustomerController {
    @GetMapping("/")
    public Future<ResponseEntity<String>> get1() {
        return CompletableFuture.supplyAsync(() -> new ResponseEntity<String ("not found", HttpStatus.NOT_FOUND));
    }
}

并在build.gradle中具有以下依赖项部分(问题也可以在maven构建中复制)

dependencies {
    compile('org.springframework.boot:spring-boot-starter')
    compile('org.springframework.boot:spring-boot-starter-web')
    compile('org.springframework:spring-web')
    testCompile('org.springframework:spring-test')
    testCompile('org.springframework.boot:spring-boot-starter-test')
}

以下测试失败:

@SpringBootTest
@RunWith(SpringRunner.class)
@AutoConfigureMockMvc
public class CustomerControllerTest {
    @Autowired
    private MockMvc mockMvc;

    @Test
    public void test404() throws Exception {
        MvcResult asyncResult = mockMvc.perform(MockMvcRequestBuilders.get("/customer/"))
                .andExpect(request().asyncStarted())
                .andReturn();

        mockMvc.perform(asyncDispatch(asyncResult))
                .andExpect(status().isNotFound());
    }
}

使用以下日志:

MockHttpServletRequest:
      HTTP Method = GET
      Request URI = /customer/
       Parameters = {}
          Headers = {}
             Body = null
    Session Attrs = {}

Handler:
             Type = com.example.wkicior.demo.CustomerController
           Method = public java.util.concurrent.Future<org.springframework.http.ResponseEntity<java.lang.String>> com.example.wkicior.demo.CustomerController.get1()

Async:
    Async started = true
     Async result = <404 Not Found,not found,{}>

Resolved Exception:
             Type = null

ModelAndView:
        View name = null
             View = null
            Model = null

FlashMap:
       Attributes = null

MockHttpServletResponse:
           Status = 200
    Error message = null
          Headers = {}
     Content type = null
             Body = 
    Forwarded URL = null
   Redirected URL = null
          Cookies = []

MockHttpServletRequest:
      HTTP Method = GET
      Request URI = /customer/
       Parameters = {}
          Headers = {}
             Body = null
    Session Attrs = {}

Handler:
             Type = com.example.wkicior.demo.CustomerController
           Method = public java.util.concurrent.Future<org.springframework.http.ResponseEntity<java.lang.String>> com.example.wkicior.demo.CustomerController.get1()

Async:
    Async started = false
     Async result = null

Resolved Exception:
             Type = null

ModelAndView:
        View name = null
             View = null
            Model = null

FlashMap:
       Attributes = null

MockHttpServletResponse:
           Status = 200
    Error message = null
          Headers = {Content-Type=[text/plain;charset=UTF-8], Content-Length=[9]}
     Content type = text/plain;charset=UTF-8
             Body = not found
    Forwarded URL = null
   Redirected URL = null
          Cookies = []

java.lang.AssertionError: Status 
Expected :404
Actual   :200

似乎测试将状态代码视为200而不是404.但是正文内容会正确返回。 有意义的是降级到5.0.0.RELEASE的春季测试 - 解决了这个问题:

testCompile('org.springframework:spring-test:5.0.0.RELEASE')

这是一个弹簧测试错误吗?

1 个答案:

答案 0 :(得分:0)

看起来确实像春虫:https://jira.spring.io/browse/SPR-16430 移至5.0.4.BUILD-SNAPSHOT解决了问题