设置功能
无论您使用哪种 MockMvc 构建器,所有 MockMvcBuilder
实现都提供一些通用且非常有用的功能。例如,您可以为所有请求声明一个 Accept
标头,并期望状态为 200 以及所有响应中的 Content-Type
标头,如下所示
-
Java
-
Kotlin
// static import of MockMvcBuilders.standaloneSetup
MockMvc mockMvc = standaloneSetup(new MusicController())
.defaultRequest(get("/").accept(MediaType.APPLICATION_JSON))
.alwaysExpect(status().isOk())
.alwaysExpect(content().contentType("application/json;charset=UTF-8"))
.build();
// Not possible in Kotlin until {kotlin-issues}/KT-22208 is fixed
此外,第三方框架(和应用程序)可以预先打包设置说明,例如 MockMvcConfigurer
中的说明。Spring 框架有一个这样的内置实现,它有助于在请求之间保存和重用 HTTP 会话。您可以按如下方式使用它
-
Java
-
Kotlin
// static import of SharedHttpSessionConfigurer.sharedHttpSession
MockMvc mockMvc = MockMvcBuilders.standaloneSetup(new TestController())
.apply(sharedHttpSession())
.build();
// Use mockMvc to perform requests...
// Not possible in Kotlin until {kotlin-issues}/KT-22208 is fixed
有关所有 MockMvc 构建器功能的列表,请参阅 ConfigurableMockMvcBuilder
的 javadoc,或使用 IDE 探索可用选项。