| This version is still in development and is not considered stable yet. For the latest stable version, please use Spring Framework 6.2.12! | 
Ahead of Time Support for Tests
This chapter covers Spring’s Ahead of Time (AOT) support for integration tests using the Spring TestContext Framework.
The testing support extends Spring’s core AOT support with the following features.
- 
Build-time detection of all integration tests in the current project that use the TestContext framework to load an ApplicationContext.- 
Provides explicit support for test classes based on JUnit Jupiter and JUnit 4 as well as implicit support for TestNG and other testing frameworks that use Spring’s core testing annotations — as long as the tests are run using a JUnit Platform TestEnginethat is registered for the current project.
 
- 
- 
Build-time AOT processing: each unique test ApplicationContextin the current project will be refreshed for AOT processing.
- 
Runtime AOT support: when executing in AOT runtime mode, a Spring integration test will use an AOT-optimized ApplicationContextthat participates transparently with the context cache.
All tests are enabled in AOT mode by default. However, you can selectively disable an
entire test class or individual test method in AOT mode by annotating it with
@DisabledInAotMode.
When using JUnit Jupiter, you may selectively enable or disable tests in a GraalVM native
image via Jupiter’s @EnabledInNativeImage and @DisabledInNativeImage annotations.
Note that @DisabledInAotMode also disables the annotated test class or test method when
running within a GraalVM native image, analogous to JUnit Jupiter’s
@DisabledInNativeImage annotation.
| By default, if an error is encountered during build-time AOT processing, an exception will be thrown, and the overall process will fail immediately. If you would prefer that build-time AOT processing continue after errors are encountered,
you can disable the  The  | 
| The  | 
To provide test-specific runtime hints for use within a GraalVM native image, you have the following options.
- 
Implement a custom TestRuntimeHintsRegistrarand register it globally viaMETA-INF/spring/aot.factories.
- 
Implement a custom RuntimeHintsRegistrarand register it globally viaMETA-INF/spring/aot.factoriesor locally on a test class via@ImportRuntimeHints.
- 
Annotate a test class with @Reflectiveor@RegisterReflectionForBinding.
- 
See Runtime Hints for details on Spring’s core runtime hints and annotation support. 
| The  | 
If you implement a custom ContextLoader, it must implement
AotContextLoader in
order to provide AOT build-time processing and AOT runtime execution support. Note,
however, that all context loader implementations provided by the Spring Framework and
Spring Boot already implement AotContextLoader.
If you implement a custom TestExecutionListener, it must implement
AotTestExecutionListener
in order to participate in AOT processing. See the SqlScriptsTestExecutionListener in
the spring-test module for an example.