Skip to content

Latest commit

 

History

History
255 lines (194 loc) · 9.17 KB

usage.md

File metadata and controls

255 lines (194 loc) · 9.17 KB

Usage

There are 3 basic parts to using the Liquibase Gradle Plugin.

  1. Including the plugin
  2. Setting up the Liquibase runtime dependencies
  3. Configuring the plugin

1. Including the plugin

Groovy

To include the plugin into Gradle builds, simply add the following to your build.gradle file:

plugins {
  id 'org.liquibase.gradle' version '3.0.1'
}

To use the older Gradle 2.0 style, add the following to build.gradle instead:

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath "org.liquibase:liquibase-gradle-plugin:3.0.1"
    }
}
apply plugin: 'org.liquibase.gradle'
Kotlin

To include the plugin into Gradle builds, simply add the following to your build.gradle.kts file:

Coming Soon

2. Setting up the classpath

The plugin will need to be able to find Liquibase on the classpath when it is applied, and again when it runs a task. At apply time, the plugin only needs to be able to see Liquibase itself. At execution time, Liquibase will need to be able to find database drivers, changelog parsers, etc. in the classpath. this is done by adding Liquibase to buildscript dependencies, as well as one or more liquibaseRuntime dependencies to the dependencies block in the build.gradle file. At a minimum, you'll need to include Liquibase itself along with a database driver. Liquibase 4.4.0+ also requires the picocli library. We also recommend including the Liquibase Groovy DSL which parses changelogs written in an elegant Groovy DSL instead of hurtful XML. An example of liquibaseRuntime entries is below:

Groovy
buildscript {
  repositories {
    mavenCentral()
  }
  dependencies {
    classpath 'org.liquibase:liquibase-core:4.26.1'
  }
}
dependencies {
  liquibaseRuntime 'org.liquibase:liquibase-core:4.26.1'
  liquibaseRuntime 'org.liquibase:liquibase-groovy-dsl:3.0.2'
  liquibaseRuntime 'info.picocli:picocli:4.6.1'
  liquibaseRuntime 'mysql:mysql-connector-java:5.1.34'
}
Kotlin

Coming Soon

The dependencies block will contain many other dependencies to build and run your project, but those dependencies are not part of the classpath when liquibase runs, because Liquibase typically only needs to be able to parse the change logs and connect to the database, and I didn't want to clutter up the classpath with dependencies that weren't needed.

Using this plugin with Java 9+ and XML based change sets will need to add JAXB th classpath since JAXB was removed from the core JVM. This can be done by adding the following to your liquibaseRuntime dependencies:

Groovy
  liquibaseRuntime group: 'javax.xml.bind', name: 'jaxb-api', version: '2.3.1'
Kotlin

Coming Soon

Some users have reported issues with logback and needed to add the following:

Groovy
  liquibaseRuntime("ch.qos.logback:logback-core:1.2.3")
  liquibaseRuntime("ch.qos.logback:logback-classic:1.2.3")
Kotlin

Coming Soon

Users of the liquibase-hibernate module who need to run the Hibernate diff command, or generate a changelog from Entity classes will need some extra configuration. You'll need to add something like the following to your liquibaseRuntime dependencies:

Groovy
  liquibaseRuntime 'org.liquibase.ext:liquibase-hibernate5:3.6' 
  liquibaseRuntime sourceSets.main.output
Kotlin

Coming Soon

Adding sourceSets.main.output is necessary for Hibernate to find your entity classes.

If you have a lot of dependencies from your project that you need to have in the liquibase classpath, you could also make liquibaseRuntime extend another configuration like this:

Groovy
configurations {
  liquibaseRuntime.extendsFrom runtime
}
Kotlin

Coming Soon

Or, if you don't already have a configurations block, you can simply add configurations.liquibaseRuntime.extendsFrom configurations.runtime to your build.gradle file.

3. Configuring the plugin

Configuring the plugin involves understanding three basic concepts: commands, parameters, and activities.

  • A command is a liquibase command, such as dropAll, update, or diffChangelog.These are the things you want Liquibase to do, as described in the Liquibase Command Documentation. The Liquibase Gradle plugin creates a task for each Liquibase Command, which is how users tell Gradle what it wants Liquibase to do.

  • Parameters refer to the parameters that get sent to Liquibase to configure how Liquibase will run the command. This includes things like the database credentials, the location of the changelog file, etc. Parameters are also documented in the Liquibase Command Documentation. Parameters are typically set up in an "activity" section of the liquibase block.

  • Activities are introduced by the plugin. A command is a specific Liquibase task to be done, while an activity is a more high level, broad category, and can be used to run the same command in different ways. For example, deploying an application might involve updating the application's schema, but it might also involve inserting metadata about the application in a registry in a different database. The plugin achieves this by allowing users to define 2 activities, each referring to different databases and changelogs. Activities can also be thought of as a collection of parameters that need to be grouped together.

With these concepts in mind, parameters for Liquibase commands are configured in the liquibase block inside the build.gradle file, using one or more "activities", each defining a series of Liquibase parameters. Any method in an "activity" is assumed to be a Liquibase command line parameter. For example, including changelogFile 'myfile.groovy' in an activity does the same thing as --changelog-file=myfile.groovy would do in the Liquibase CLI. Including difftypes 'data' in an activity does the same thing as difftypes=data would do on the command line, etc. The Liquibase documentation details all the valid command line parameters, though the documentation tends to use kebab-case for the parameters, which it calls attributes. The gradle plugin, in keeping with Groovy conventions, uses camelCase, and translates as necessary before calling Liquibase.

The liquibase block also has an optional "runList", which determines which activities are run for each task. If no runList is defined, the Liquibase Plugin will run all the activities. NOTE: the order of execution when there is no runList is not guaranteed.

The parameters in build.gradle can be overridden on the command line using matching Gradle properties, capitalized and prefixed with liquibase. For example, if you wanted to override the log level for a single run, you could run gradlew -PliquibaseLogLevel=debug" and it would print debug messages from liquibase. This can also be used to add extra arguments that weren't in any activity blocks.

Liquibase Changelog Parameters can be specified in an activity with the changelogParameters method. The method takes a map of key-value pairs to be sent to Liquibase. They can be specified at run time with the liquibaseChangelogParameters Gradle property. Multiple parameters can be specified by separating them with a comma, like this: -liquibaseChangelogParameters="param1=value1,param1=value2. Due to limitations of Gradle, spaces are not allowed in the value of the liquibaseChangelogParameters property.

The liquibase block can also set two properties; mainClassName and jvmArgs.

The mainClassName property tells the plugin the name of the class to invoke in order to run Liquibase. By default, the plugin uses liquibase.integration.commandline.LiquibaseCommandLine. This value can be set to call other classes if needed. You will need to make sure whatever class you use with mainClassName can be found in one of the liquibaseRuntime dependencies.

The jvmArgs property tells the plugin what JVM arguments to set when forking the Liquibase process, and defaults to an empty array, which is usually fine.

If you are using liquibase in a subproject structure, due to a limitation in liquibase, you will need to override the user.dir using the jvmArgs. For example:

Groovy
liquibase {
  jvmArgs "-Duser.dir=$project.projectDir" 
}
Kotlin

Coming Soon

See the Examples page for more details and examples of various configurations