问题描述
我正在模块化一个用 Java 开发的单体应用,它利用 Micronaut 框架和 Gradle 作为构建工具。正如标题所示,它利用 Liquibase 进行数据库迁移。
旧结构:
这是一个标准的单一 Gradle java 项目,带有用于生成 war 文件的 war 插件。它在 src/main/java/resources
文件夹中包含所有迁移(标准 micronaut-liquibase 内容)
新结构:
我正在将各种独立的域分解为单独的 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
将生成一个包含 gradle-project-A
作为 jar 依赖项的 war 文件。这是我想到的结构。
因此,startup
依赖于所有其他 Gradle 项目
精简版的 startup/build.gradle
plugins {
'io.micronaut.application'
'war'
}
dependencies {
implementation project(':gradle-project-A')
}
问题
- 如文件夹结构所示,有些集成测试需要将所有 liquibase 迁移预先应用到数据库(测试容器)
- 在旧结构中,迁移是在执行测试时获取的,因为它们在同一个 Gradle 项目中。
- 现在,迁移是
startup
的一部分,并且在gradle-project-A
中运行集成测试时显然不会提取它们
我目前的研究
问题
- 如何在运行测试时让
gradle-project-A
检测类路径中的liqiubase-changelog.yml
? - 我不能将
startup
作为gradle-project-A
的依赖项,因为这将是循环依赖项。我的模块结构可以改进吗?
欢迎您提出任何建议!提前感谢您的帮助...
解决方法
我认为您需要为 project-A
、project-B
等拆分迁移脚本。
因此,在 project-A/src/main/java/resources/
中,您需要具有 project-A
的迁移脚本,project-B
的迁移脚本也是如此,等等。然后,在您的 startup
项目中,您可以拥有 {{1 }} 看起来像这样:
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>
运行测试时,只会运行该项目的脚本。