0

我在让 Liquibase 变更集上下文在我的 Grails 应用程序中正常运行时遇到问题。我有一组变更集,我只想在“测试”上下文中运行。但是,它们每次都在执行。我想我有一个配置问题。

Liquibase 文档指出您只需将 context="test" 属性添加到您的更改集。对于我的概念验证测试,我将创建一个我想在测试中插入的患者记录的插入,而不是在我的本地开发环境中。我的变更集添加了上下文:

<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 执行时,它不应该运行我上面的变更集,因为它是在“测试”中定义的语境。

然而,当我运行应用程序时,我的变更集被执行。我在设置中搞砸或错过了什么?

4

1 回答 1

0

我敢打赌,最后一个配置行没有达到您的预期。

根据http://grails-plugins.github.io/grails-database-migration/docs/manual/guide/3%20Configuration.html上的“多数据源示例”部分,此语法用于多个数据源。因此,在您的情况下,该updateOnStartContexts参数将应用于dataSource_development您显然没有的名为的数据源...

您可以尝试以下方法:

environments {
    development{
        grails.plugin.databasemigration.updateOnStartContexts = ['development']
    }
}
于 2013-10-04T19:05:32.913 回答