Liquibase 上下文与 Grails



我在让 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']
    }
}

相关内容

  • 没有找到相关文章

最新更新