我正在模块化一个用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-A
、project-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
运行测试时,将只运行该项目的脚本。