Annotation Interface WebMvcTest
Using this annotation only enables auto-configuration that is relevant to MVC tests. Similarly, component scanning is limited to beans annotated with:
- @Controller
- @ControllerAdvice
- @JsonComponent
as well as beans that implement:
- Converter
- DelegatingFilterProxyRegistrationBean
- ErrorAttributes
- Filter
- FilterRegistrationBean
- GenericConverter
- HandlerInterceptor
- HandlerMethodArgumentResolver
- HttpMessageConverter
- IDialect, if Thymeleaf is available
- Module, if Jackson is available
- SecurityFilterChain
- WebMvcConfigurer
- WebMvcRegistrations
- WebSecurityConfigurer
By default, tests annotated with @WebMvcTest will also auto-configure Spring
Security and MockMvc (include support for HtmlUnit WebClient and Selenium
WebDriver). For more fine-grained control of MockMVC the
@AutoConfigureMockMvc annotation can be used.
Typically @WebMvcTest is used in combination with
@MockitoBean
or @Import to create any collaborators required by your
@Controller beans.
If you are looking to load your full application configuration and use MockMVC, you
should consider @SpringBootTest combined with
@AutoConfigureMockMvc rather than this annotation.
When using JUnit 4, this annotation should be used in combination with
@RunWith(SpringRunner.class).
- Since:
- 4.0.0
- Author:
- Phillip Webb, Artsiom Yudovin
- See Also:
- 
Optional Element SummaryOptional ElementsModifier and TypeOptional ElementDescriptionClass<?>[]Specifies the controllers to test.Class<?>[]Auto-configuration exclusions that should be applied for this test.A set of exclude filters which can be used to filter beans that would otherwise be added to the application context.A set of include filters which can be used to add otherwise filtered beans to the application context.String[]Properties in form key=value that should be added to the SpringEnvironmentbefore the test runs.booleanDetermines if default filtering should be used with@SpringBootApplication.Class<?>[]Specifies the controllers to test.
- 
Element Details- 
propertiesString[] propertiesProperties in form key=value that should be added to the SpringEnvironmentbefore the test runs.- Returns:
- the properties to add
 - Default:
- {}
 
- 
valueSpecifies the controllers to test. This is an alias ofcontrollers()which can be used for brevity if no other attributes are defined. Seecontrollers()for details.- Returns:
- the controllers to test
- See Also:
 - Default:
- {}
 
- 
controllers
- 
useDefaultFiltersboolean useDefaultFiltersDetermines if default filtering should be used with@SpringBootApplication. By default only@Controller(when no explicitcontrollersare defined),@ControllerAdviceandWebMvcConfigurerbeans are included.- Returns:
- if default filters should be used
- See Also:
 - Default:
- true
 
- 
includeFiltersComponentScan.Filter[] includeFiltersA set of include filters which can be used to add otherwise filtered beans to the application context.- Returns:
- include filters to apply
 - Default:
- {}
 
- 
excludeFiltersComponentScan.Filter[] excludeFiltersA set of exclude filters which can be used to filter beans that would otherwise be added to the application context.- Returns:
- exclude filters to apply
 - Default:
- {}
 
- 
excludeAutoConfiguration@AliasFor(annotation=ImportAutoConfiguration.class, attribute="exclude") Class<?>[] excludeAutoConfigurationAuto-configuration exclusions that should be applied for this test.- Returns:
- auto-configuration exclusions to apply
 - Default:
- {}
 
 
-