我在让 Liquibase 变更集上下文在我的 Grails 应用程序中很好地发挥作用时遇到了问题。我有一组变更集,我只想在"测试"上下文中运行。但是,它们每次都在执行。我想我有一个配置问题。
Liquibase 文档指出,您只需将 context="test" 属性添加到您的 changeSet 中。对于我的概念验证测试,我将创建一个患者记录的插入,我想在测试中插入该记录,但不在本地开发环境中插入。我的变更集添加了上下文:
<changeSet id="v1.1-garbage-1" author="Eric" context="test">
<insert tableName="patient">
[...]
</insert>
</changeSet>
然后在我的 DataSource.groovy 文件中,我定义了我的环境:
environments {
development {
dataSource {
dbCreate = "create"
jndiName = "java:comp/env/jdbc/mydatabasename"
}
}
test {
dataSource {
dbCreate = "create"
url = "jdbc:h2:mem:testDb;MVCC=TRUE;LOCK_TIMEOUT=10000"
}
}
[...]
所以我有两个环境,开发和测试。然后在我的 Config.groovy 中,我将 Grails 数据库迁移插件设置为仅具有上下文"开发"(对于此概念验证(:
// Database Migration plugin
grails.plugin.databasemigration.updateOnStart = true
grails.plugin.databasemigration.updateOnStartFileNames = ['changelog.xml']
grails.plugin.databasemigration.autoMigrateScripts = ['RunApp', 'TestApp']
grails.plugin.databasemigration.changelogFileName = "changelog.xml"
grails.plugin.databasemigration.development.updateOnStartContexts = ['development']
据我了解,在最后一行中,我告诉数据库迁移插件将"开发"上下文设置为"开发",因此当 Liquibase 执行时,它不应该运行上面的变更集,因为它是在"测试"上下文中定义的。
然而,当我运行应用程序时,我的变更集被执行。我在设置中搞砸或错过了什么?
我敢打赌,最后一个配置行没有按照您的期望进行。
根据 http://grails-plugins.github.io/grails-database-migration/docs/manual/guide/3%20Configuration.html 的"多数据源示例"部分,此语法用于多个数据源。因此,在您的情况下,updateOnStartContexts
参数将应用于名为 dataSource_development
的数据源,您显然没有该数据源......
您可以尝试以下方法吗:
environments {
development{
grails.plugin.databasemigration.updateOnStartContexts = ['development']
}
}