将Liquibase迁移应用于多模块渐变项目的集成测试



我正在模块化一个用Java开发的单片,它使用Micronaut框架和Gradle作为构建工具。正如标题所示,它利用Liquibase进行数据库迁移。

旧结构:

这是一个标准的单个Gradlejava项目,带有war插件来生成war文件。它在src/main/java/resources文件夹中有所有的迁移(标准的micronaut液化物(

新结构:

我正在将各种独立的领域分解为单独的Gradle项目。我做了一个startup项目,该项目应该具有所有的项目初始化逻辑,如Micronauts上下文初始化和Liquibase DB迁移。

project/
|
+---gradle-project-A/
|   |
|   +---build.gradle
|   |
|   +---src/main/java/
|   |
|   +---src/test/
|       |
|       +---java/TestIntegration.java
|       |
|       +---resources/application.yml (for testing)
|
+---startup/
|   |
|   +---build.gradle
|   |
|   +---src/main/java/Application.java
|   |
|   +---src/main/java/resources/
|       |
|       +---db/changelog.sql files (These files are referred by the changelog.yml)
|       +---liqiubase-changelog.yml (Liquibase looks for this file in classpath)
|       +---application.yml (Micronaut config)
|
+---settings.gradle
|
|

当然,还会有更多的Gradle项目gradle-project-B, C...

最终,startup将生成一个war文件,其中包含作为jar依赖项的gradle-project-A。这就是我想到的结构。

因此,startup依赖于其他所有Gradle项目

startup/build.gradle的精简版

plugins {
'io.micronaut.application'
'war'
}
dependencies {
implementation project(':gradle-project-A')
}

问题

  • 正如文件夹结构所示,有些集成测试需要将所有liquibase迁移预先应用于数据库(测试容器(
  • 在旧结构中,迁移是在执行测试时进行的,因为它们在同一个Gradle项目中
  • 现在,迁移是startup的一部分,在gradle-project-A中运行集成测试时,显然不会进行迁移

我迄今为止的研究

  • 新的项目结构受到了这篇文章的启发
  • 我的问题似乎与StackOverflow上的这个问题相似,但我不确定我是否理解正确(不是Gradle专家(

问题

  • 运行测试时,如何让gradle-project-A在类路径中检测liqiubase-changelog.yml
  • 我不能将startup作为gradle-project-A的依赖项,因为这将是一个循环依赖项。我的模块结构可以改进吗

欢迎您提出任何建议!感谢您提前提供的帮助。。。

您应该为DB创建变更日志文件,而不是为模块创建(某些模块可能共享一个DB(。然后,您可以将变更日志保存在共享配置中(请参阅gradle多模块项目的更改工作目录(,并在每个需要的模块中声明变更日志模块的DB的路径。对于Spring Boot,它可能看起来像(在application.yaml中(:

spring.liquibase:
changeLog: "file:${PROJECT_ROOT}/config/db/migration/db_a.sql"

我认为您需要为project-Aproject-B等拆分迁移脚本。

因此,在project-A/src/main/java/resources/中,您需要有project-A的迁移脚本,与project-B的迁移脚本相同,等等。然后,在您的startup项目中,您可以有changelog.xml,它看起来像这样:

<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.1.xsd">
<include file="pathToChangeLogFromProjectA.xml" relativeToChangelogFile="true"/>
<include file="pathToChangeLogFromProjectA.xml" relativeToChangelogFile="true"/>
</databaseChangeLog>

这样,启动程序将为所有项目选择迁移脚本,并且当您为project-A运行测试时,将只运行该项目的脚本。

最新更新