问题描述
我们有一个模块化的单体应用,它具有 maven 多模块项目结构,使用 spring-boot 并通过 @SpringBoottest
进行集成测试,它启动特定于模块的 Spring ApplicationContext,在该应用上下文下执行集成测试,使用完整的DI、JPA 连接等
在所有这些模块中,我们使用“AdminControllers”的概念,并在中央“核心”模块 - all 依赖和@ComponentScan
> 其他模块 - 我们有一个中心
AdminControllerIntegrationTest
断言所有 AdminController-Bean 上的某些属性,例如与安全相关的注释的存在。
这个“核心”@SpringBoottest
AdminControllerIntegrationTest 在特定于 core
模块的应用程序上下文中运行一次,在那里它可以看到所有核心的 bean - 这很好。但是,在所有其他模块中,此 IntegrationTest 从不执行并且无法检查它们的任何 bean。
是否有可能让这个中央 @SpringBoottest
在所有模块中分别在它们自己的特定 ApplicationContext 中自动运行?
解决方法
这个设置有点问题,让我解释一下:
所以您说,您有一个带有自己的 @SpringBootTest
测试的“核心”模块,这意味着它是一个 Spring Boot 应用程序。
另一方面,您说,您有模块 A 和 B,它们本身就是 Spring Boot 应用程序。但如果是这样,他们不能依赖另一个 spring 启动应用程序(核心),我的意思是 spring 启动应用程序模块不能依赖另一个 spring 启动应用程序模块,这没有意义,也不能在 maven 中工作。>
我想到的另一场音乐会:在任何 Spring Boot 应用程序中,我们通常使用“插件”之类的东西:计量系统、日志系统、执行器等。通常为此目的有启动器,我们在 maven 中定义它们,Spring Boot 应用程序会自动加载它们。然而,我们在应用程序中将它们视为“第三方”,并且在编译我们的应用程序时从不费心运行“他们的”测试。您所描述的内容与此方法相矛盾。
因此,根据我的理解(同样,我可能完全弄错了),您应该:
-
从您的“核心”模块中创建一个启动器(自动配置模块)。它本身不会是一个 Spring Boot 应用程序,也不会有任何 @SpringBootTest 。只有简单的单元/集成测试(从 @SpringBootTest 的作用来看,可能由 spring 驱动,但不是 Spring boot)。您也不会在该模块的 pom 中包含
spring-boot-maven-plugin
,并且在任何类中也不会有main
方法(根本没有@SpringBootApplication
)。 在模块 A 和 B - 插入此自动配置模块,它将自动加载并提供所需的功能。模块A的测试应该测试模块A的代码/流程,不需要测试“核心”模块的功能,它用于“核心”的测试来检查“核心”模块的功能。
-
在模块 A 和 B 中,当你有
@SpringBootTest
时,核心模块将被加载,你的一些代码可能会中断,因为它不“符合核心模块的期望”(就像你没有放置正确的注释或其他东西) - 在这种情况下,测试将失败,例如,您必须修复模块 A 的代码。
更新 1 看完评论:
我认为这是可能的,解决方案应该包括以下步骤:
-
在包含测试
AdminControllerIntegrationTest
的模块核心之外创建一个额外的测试 jar 工件。 this link 包含应该放置在模块核心的pom.xml
中的技术说明。 -
你的 spring boot 应用程序模块应该依赖于这个测试工件范围测试,像这样:
<dependency>
<groupId>com.foo</groupId>
<artifactId>core</artifactId>
<version>1.0</version>
<type>test-jar</type>
<scope>test</scope>
</dependency>
- 从现在开始它变得棘手,因为它实际上取决于测试中究竟发生了什么以及 spring 如何插入所有内容。在“最简单”的情况下,对于这一步,您必须确保您的万无一失/故障安全插件是2.15+ 版本:此版本添加了对
dependenciesToScan
选项的支持,该选项将包含模块核心,以便在构建 Spring Boot 应用程序期间插件也将运行AdminControllerIntegrationTest
。至少它会在测试类路径中......从那里你可能需要在 spring 级别进行一些自定义,没有看到代码很难说出会发生什么。有关详细信息,请参阅 this thread