设置功能

无论您使用哪种 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();
// static import of MockMvcBuilders.standaloneSetup

val mockMvc = standaloneSetup(MusicController())
	.defaultRequest<StandaloneMockMvcBuilder>(get("/").accept(MediaType.APPLICATION_JSON))
	.alwaysExpect<StandaloneMockMvcBuilder>(status().isOk())
	.alwaysExpect<StandaloneMockMvcBuilder>(content().contentType("application/json;charset=UTF-8"))
	.build()

此外,第三方框架(和应用程序)可以预打包设置指令,例如 MockMvcConfigurer 中的指令。Spring Framework 内置了这样一个实现,有助于在请求之间保存和重用 HTTP 会话。您可以按如下方式使用它:

  • Java

  • Kotlin

// static import of SharedHttpSessionConfigurer.sharedHttpSession

MockMvc mockMvc = MockMvcBuilders.standaloneSetup(new TestController())
		.apply(sharedHttpSession())
		.build();

// Use mockMvc to perform requests...
// static import of SharedHttpSessionConfigurer.sharedHttpSession

val mockMvc = MockMvcBuilders.standaloneSetup(TestController())
		.apply<StandaloneMockMvcBuilder>(sharedHttpSession())
		.build()

// Use mockMvc to perform requests...

有关所有 MockMvc 构建器功能的列表,请参阅 ConfigurableMockMvcBuilder 的 Javadoc,或使用 IDE 探索可用选项。

© . This site is unofficial and not affiliated with VMware.