中央 SpringBootTest 分别在每个 maven-module 的 ApplicationContext 中运行

问题描述

我们有一个模块化的单体应用,它具有 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 应用程序会自动加载它们。然而,我们在应用程序中将它们视为“第三方”,并且在编译我们的应用程序时从不费心运行“他们的”测试。您所描述的内容与此方法相矛盾。

因此,根据我的理解(同样,我可能完全弄错了),您应该:

  1. 从您的“核心”模块中创建一个启动器(自动配置模块)。它本身不会是一个 Spring Boot 应用程序,也不会有任何 @SpringBootTest 。只有简单的单元/集成测试(从 @SpringBootTest 的作用来看,可能由 spring 驱动,但不是 Spring boot)。您也不会在该模块的 pom 中包含 spring-boot-maven-plugin,并且在任何类中也不会有 main 方法(根本没有 @SpringBootApplication)。

  2. 在模块 A 和 B - 插入此自动配置模块,它将自动加载并提供所需的功能。模块A的测试应该测试模块A的代码/流程,不需要测试“核心”模块的功能,它用于“核心”的测试来检查“核心”模块的功能。

  3. 在模块 A 和 B 中,当你有 @SpringBootTest 时,核心模块将被加载,你的一些代码可能会中断,因为它不“符合核心模块的期望”(就像你没有放置正确的注释或其他东西) - 在这种情况下,测试将失败,例如,您必须修复模块 A 的代码。

更新 1 看完评论:

我认为这是可能的,解决方案应该包括以下步骤:

  1. 在包含测试 AdminControllerIntegrationTest 的模块核心之外创建一个额外的测试 jar 工件。 this link 包含应该放置在模块核心pom.xml中的技术说明。

  2. 你的 spring boot 应用程序模块应该依赖于这个测试工件范围测试,像这样:

<dependency>
  <groupId>com.foo</groupId>
  <artifactId>core</artifactId>
  <version>1.0</version>
  <type>test-jar</type>
  <scope>test</scope>
</dependency>
  1. 从现在开始它变得棘手,因为它实际上取决于测试中究竟发生了什么以及 spring 如何插入所有内容。在“最简单”的情况下,对于这一步,您必须确保您的万无一失/故障安全插件是2.15+ 版本:此版本添加了对 dependenciesToScan 选项的支持,该选项将包含模块核心,以便在构建 Spring Boot 应用程序期间插件也将运行 AdminControllerIntegrationTest。至少它会在测试类路径中......从那里你可能需要在 spring 级别进行一些自定义,没有看到代码很难说出会发生什么。有关详细信息,请参阅 this thread