Class AbstractTestContextBootstrapper
- All Implemented Interfaces:
- TestContextBootstrapper
- Direct Known Subclasses:
- DefaultTestContextBootstrapper
TestContextBootstrapper interface which
 provides most of the behavior required by a bootstrapper.
 Concrete subclasses typically will only need to provide implementations for the following methods:
- getDefaultContextLoaderClass(java.lang.Class<?>)
- processMergedContextConfiguration(org.springframework.test.context.MergedContextConfiguration)
To plug in custom
 ContextCache
 support, override getCacheAwareContextLoaderDelegate().
- Since:
- 4.1
- Author:
- Sam Brannen, Juergen Hoeller, Phillip Webb
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionBuild the merged context configuration for the test class in theBootstrapContextassociated with this bootstrapper.Build a newDefaultTestContextusing the test class in theBootstrapContextassociated with this bootstrapper and by delegating tobuildMergedContextConfiguration()andgetCacheAwareContextLoaderDelegate().Get theBootstrapContextassociated with this bootstrapper.protected CacheAwareContextLoaderDelegateGet theCacheAwareContextLoaderDelegateto use for transparent interaction with theContextCache.protected List<ContextCustomizerFactory>Get theContextCustomizerFactoryinstances for this bootstrapper.protected abstract Class<? extends ContextLoader>getDefaultContextLoaderClass(Class<?> testClass) Determine the defaultContextLoaderclass to use for the supplied test class.protected Set<Class<? extends TestExecutionListener>>Get the defaultTestExecutionListenerclasses for this bootstrapper.Get the names of the defaultTestExecutionListenerclasses for this bootstrapper.final List<TestExecutionListener>Get a list of newly instantiatedTestExecutionListenersfor the test class in theBootstrapContextassociated with this bootstrapper.protected MergedContextConfigurationprocessMergedContextConfiguration(MergedContextConfiguration mergedConfig) Process the supplied, newly instantiatedMergedContextConfigurationinstance.protected ContextLoaderresolveContextLoader(Class<?> testClass, List<ContextConfigurationAttributes> configAttributesList) Resolve theContextLoaderclass to use for the supplied list ofContextConfigurationAttributesand then instantiate and return thatContextLoader.protected Class<? extends ContextLoader>resolveExplicitContextLoaderClass(List<ContextConfigurationAttributes> configAttributesList) voidsetBootstrapContext(BootstrapContext bootstrapContext) Set theBootstrapContextto be used by this bootstrapper.
- 
Constructor Details- 
AbstractTestContextBootstrapperpublic AbstractTestContextBootstrapper()
 
- 
- 
Method Details- 
setBootstrapContextDescription copied from interface:TestContextBootstrapperSet theBootstrapContextto be used by this bootstrapper.- Specified by:
- setBootstrapContextin interface- TestContextBootstrapper
 
- 
getBootstrapContextDescription copied from interface:TestContextBootstrapperGet theBootstrapContextassociated with this bootstrapper.- Specified by:
- getBootstrapContextin interface- TestContextBootstrapper
 
- 
buildTestContextBuild a newDefaultTestContextusing the test class in theBootstrapContextassociated with this bootstrapper and by delegating tobuildMergedContextConfiguration()andgetCacheAwareContextLoaderDelegate().Concrete subclasses may choose to override this method to return a custom TestContextimplementation.- Specified by:
- buildTestContextin interface- TestContextBootstrapper
- Returns:
- a new TestContext, nevernull
- Since:
- 4.2
- See Also:
 
- 
getTestExecutionListenersDescription copied from interface:TestContextBootstrapperGet a list of newly instantiatedTestExecutionListenersfor the test class in theBootstrapContextassociated with this bootstrapper.If @TestExecutionListenersis not present on the test class in theBootstrapContext, default listeners should be returned. Furthermore, default listeners must be sorted usingAnnotationAwareOrderComparator.Concrete implementations are free to determine what comprises the set of default listeners. However, by default, the Spring TestContext Framework will use the SpringFactoriesLoadermechanism to look up allTestExecutionListenerclass names configured in allMETA-INF/spring.factoriesfiles on the classpath.The inheritListenersflag of@TestExecutionListenersmust be taken into consideration. Specifically, if theinheritListenersflag is set totrue, listeners declared for a given test class must be appended to the end of the list of listeners declared in superclasses.- Specified by:
- getTestExecutionListenersin interface- TestContextBootstrapper
- Returns:
- a list of TestExecutionListenerinstances
 
- 
getDefaultTestExecutionListenerClassesGet the defaultTestExecutionListenerclasses for this bootstrapper.This method is invoked by getTestExecutionListeners()and delegates togetDefaultTestExecutionListenerClassNames()to retrieve the class names.If a particular class cannot be loaded, a DEBUGmessage will be logged, but the associated exception will not be rethrown.
- 
getDefaultTestExecutionListenerClassNamesGet the names of the defaultTestExecutionListenerclasses for this bootstrapper.The default implementation looks up all org.springframework.test.context.TestExecutionListenerentries configured in allMETA-INF/spring.factoriesfiles on the classpath.This method is invoked by getDefaultTestExecutionListenerClasses().- Returns:
- an unmodifiable list of names of default TestExecutionListenerclasses
- See Also:
- 
- SpringFactoriesLoader.loadFactoryNames(java.lang.Class<?>)
 
 
- 
buildMergedContextConfigurationBuild the merged context configuration for the test class in theBootstrapContextassociated with this bootstrapper.Implementations must take the following into account when building the merged configuration: - Context hierarchies declared via @ContextHierarchyand@ContextConfiguration
- Active bean definition profiles declared via @ActiveProfiles
- Context initializers declared via ContextConfiguration.initializers()
- Test property sources declared via @TestPropertySource
 Consult the Javadoc for the aforementioned annotations for details on the required semantics. Note that the implementation of TestContextBootstrapper.buildTestContext()should typically delegate to this method when constructing theTestContext.When determining which ContextLoaderto use for a given test class, the following algorithm should be used:- If a ContextLoaderclass has been explicitly declared viaContextConfiguration.loader(), use it.
- Otherwise, concrete implementations are free to determine which
 ContextLoaderclass to use as a default.
 - Specified by:
- buildMergedContextConfigurationin interface- TestContextBootstrapper
- Returns:
- the merged context configuration, never null
- See Also:
 
- Context hierarchies declared via 
- 
getContextCustomizerFactoriesGet theContextCustomizerFactoryinstances for this bootstrapper.The default implementation uses the SpringFactoriesLoadermechanism for loading factories configured in allMETA-INF/spring.factoriesfiles on the classpath.- Since:
- 4.3
- See Also:
 
- 
resolveContextLoaderprotected ContextLoader resolveContextLoader(Class<?> testClass, List<ContextConfigurationAttributes> configAttributesList) Resolve theContextLoaderclass to use for the supplied list ofContextConfigurationAttributesand then instantiate and return thatContextLoader.If the user has not explicitly declared which loader to use, the value returned from getDefaultContextLoaderClass(java.lang.Class<?>)will be used as the default context loader class. For details on the class resolution process, seeresolveExplicitContextLoaderClass(java.util.List<org.springframework.test.context.ContextConfigurationAttributes>)andgetDefaultContextLoaderClass(java.lang.Class<?>).- Parameters:
- testClass- the test class for which the- ContextLoadershould be resolved; must not be- null
- configAttributesList- the list of configuration attributes to process; must not be- null; must be ordered bottom-up (i.e., as if we were traversing up the class hierarchy)
- Returns:
- the resolved ContextLoaderfor the suppliedtestClass(nevernull)
- Throws:
- IllegalStateException- if- getDefaultContextLoaderClass(Class)returns- null
 
- 
resolveExplicitContextLoaderClass@Nullable protected Class<? extends ContextLoader> resolveExplicitContextLoaderClass(List<ContextConfigurationAttributes> configAttributesList) Resolve theContextLoaderclass to use for the supplied list ofContextConfigurationAttributes.Beginning with the first level in the context configuration attributes hierarchy: - If the contextLoaderClassproperty ofContextConfigurationAttributesis configured with an explicit class, that class will be returned.
- If an explicit ContextLoaderclass is not specified at the current level in the hierarchy, traverse to the next level in the hierarchy and return to step #1.
 - Parameters:
- configAttributesList- the list of configuration attributes to process; must not be- null; must be ordered bottom-up (i.e., as if we were traversing up the class hierarchy)
- Returns:
- the ContextLoaderclass to use for the supplied configuration attributes, ornullif no explicit loader is found
- Throws:
- IllegalArgumentException- if supplied configuration attributes are- nullor empty
 
- If the 
- 
getCacheAwareContextLoaderDelegateGet theCacheAwareContextLoaderDelegateto use for transparent interaction with theContextCache.The default implementation simply delegates to getBootstrapContext().getCacheAwareContextLoaderDelegate().Concrete subclasses may choose to override this method to return a custom CacheAwareContextLoaderDelegateimplementation with customContextCachesupport.- Returns:
- the context loader delegate (never null)
 
- 
getDefaultContextLoaderClassDetermine the defaultContextLoaderclass to use for the supplied test class.The class returned by this method will only be used if a ContextLoaderclass has not been explicitly declared viaContextConfiguration.loader().- Parameters:
- testClass- the test class for which to retrieve the default- ContextLoaderclass
- Returns:
- the default ContextLoaderclass for the supplied test class (nevernull)
 
- 
processMergedContextConfigurationprotected MergedContextConfiguration processMergedContextConfiguration(MergedContextConfiguration mergedConfig) Process the supplied, newly instantiatedMergedContextConfigurationinstance.The returned MergedContextConfigurationinstance may be a wrapper around or a replacement for the original.The default implementation simply returns the supplied instance unmodified. Concrete subclasses may choose to return a specialized subclass of MergedContextConfigurationbased on properties in the supplied instance.- Parameters:
- mergedConfig- the- MergedContextConfigurationto process; never- null
- Returns:
- a fully initialized MergedContextConfiguration; nevernull
 
 
-