|
This version is still in development and is not considered stable yet. For the latest stable version, please use Spring Framework 6.1.13! |
|
This version is still in development and is not considered stable yet. For the latest stable version, please use Spring Framework 6.1.13! |
Bean overriding in tests refers to the ability to override specific beans in the
ApplicationContext for a test class, by annotating one or more fields in the test class.
This feature is intended as a less risky alternative to the practice of registering
a bean via @Bean with the DefaultListableBeanFactory
setAllowBeanDefinitionOverriding flag set to true.
|
The Spring TestContext framework provides two sets of annotations for bean overriding.
The former relies purely on Spring, while the latter set relies on the Mockito third-party library.
This feature is intended as a less risky alternative to the practice of registering
a bean via @Bean with the DefaultListableBeanFactory
setAllowBeanDefinitionOverriding flag set to true.
|
Custom Bean Override Support
The three annotations mentioned above build upon the @BeanOverride meta-annotation and
associated infrastructure, which allows one to define custom bean overriding variants.
To create custom bean override support, the following is needed:
-
An annotation meta-annotated with
@BeanOverridethat defines theBeanOverrideProcessorto use -
A custom
BeanOverrideProcessorimplementation -
One or more concrete
OverrideMetadataimplementations provided by the processor
The Spring TestContext framework includes implementations of the following APIs that support bean overriding and are responsible for setting up the rest of the infrastructure.
-
a
BeanFactoryPostProcessor -
a
ContextCustomizerFactory -
a
TestExecutionListener
The spring-test module registers implementations of the latter two
(BeanOverrideContextCustomizerFactory and BeanOverrideTestExecutionListener) in its
META-INF/spring.factories
properties file.
The bean overriding infrastructure searches in test classes for any field meta-annotated
with @BeanOverride and instantiates the corresponding BeanOverrideProcessor which is
responsible for registering appropriate OverrideMetadata.
The internal BeanOverrideBeanFactoryPostProcessor then uses that information to alter
the test’s ApplicationContext by registering and replacing bean definitions as defined
by the corresponding BeanOverrideStrategy:
-
REPLACE_DEFINITION: Replaces the bean definition. Throws an exception if a corresponding bean definition does not exist. -
REPLACE_OR_CREATE_DEFINITION: Replaces the bean definition if it exists. Creates a new bean definition if a corresponding bean definition does not exist. -
WRAP_BEAN: Retrieves the original bean instance and wraps it.
|
In contrast to Spring’s autowiring mechanism (for example, resolution of an Typically, the bean is selected by type by the Some |
| Only singleton beans can be overridden. Any attempt to override a non-singleton bean will result in an exception. |
|
In contrast to Spring’s autowiring mechanism (for example, resolution of an Typically, the bean is selected by type by the Some |
| Only singleton beans can be overridden. Any attempt to override a non-singleton bean will result in an exception. |