使用上下文初始化器进行上下文配置
要使用上下文初始化器配置测试的 ApplicationContext
,请使用 @ContextConfiguration
注解测试类,并将 initializers
属性配置为一个数组,该数组包含实现了 ApplicationContextInitializer
的类的引用。然后,声明的上下文初始化器用于初始化为测试加载的 ConfigurableApplicationContext
。请注意,每个声明的初始化器支持的具体 ConfigurableApplicationContext
类型必须与所使用的 SmartContextLoader
创建的 ApplicationContext
类型兼容(通常是 GenericApplicationContext
)。此外,初始化器的调用顺序取决于它们是否实现了 Spring 的 Ordered
接口,或者是否使用了 Spring 的 @Order
注解或标准的 @Priority
注解。以下示例展示了如何使用初始化器:
-
Java
-
Kotlin
@ExtendWith(SpringExtension.class)
// ApplicationContext will be loaded from TestConfig
// and initialized by TestAppCtxInitializer
@ContextConfiguration(
classes = TestConfig.class,
initializers = TestAppCtxInitializer.class) (1)
class MyTest {
// class body...
}
1 | 使用配置类和初始化器指定配置。 |
@ExtendWith(SpringExtension::class)
// ApplicationContext will be loaded from TestConfig
// and initialized by TestAppCtxInitializer
@ContextConfiguration(
classes = [TestConfig::class],
initializers = [TestAppCtxInitializer::class]) (1)
class MyTest {
// class body...
}
1 | 使用配置类和初始化器指定配置。 |
您也可以完全省略 @ContextConfiguration
中 XML 配置文件、Groovy 脚本或组件类的声明,而只声明 ApplicationContextInitializer
类,由它们负责在上下文中注册 bean,例如通过以编程方式从 XML 文件或配置类加载 bean 定义。以下示例展示了如何做到这一点:
-
Java
-
Kotlin
@ExtendWith(SpringExtension.class)
// ApplicationContext will be initialized by EntireAppInitializer
// which presumably registers beans in the context
@ContextConfiguration(initializers = EntireAppInitializer.class) (1)
class MyTest {
// class body...
}
1 | 仅使用初始化器指定配置。 |
@ExtendWith(SpringExtension::class)
// ApplicationContext will be initialized by EntireAppInitializer
// which presumably registers beans in the context
@ContextConfiguration(initializers = [EntireAppInitializer::class]) (1)
class MyTest {
// class body...
}
1 | 仅使用初始化器指定配置。 |