A simple but yet powerful migration plugin for Grails going a more lightweight direction than the standard "Grails Database Migration Plugin".
This plugin leaves the database creation and update process in hibernates (more or less) skillful hands, but having an easy way to add, change, or delete data on applications startup. Need to access your services? No problem. Use them as you are used to it in Grails.
Simply create a migration file for every feature / task / story / fairy tale you develop, put your changes there and on next startup the changes will be made – once.
No need to maintain (and merge) a changes file.
-
Add this line to the plugins section of your applications BuildConfig.groovy (not that easy yet, see below*)
plugins { .. runtime ":smig:1.3.0" .. .. }
-
Refresh your dependencies
grails refresh-dependencies
-
After refreshing, there will be a new folder in your project
./grails-app/migrations
Create a new groovy file in that new folder. You can use package structure if you like.
This new file has to implement the Migrate interface (com.smig.interfaces.Migrate). Your IDE will generate the migrate(Sql) method you'll need to implement.
Here is an example of what this migration file can look like.class FeatureXmas implements Migrate { UserService userService void migrate(Sql sql) { User.list().each { boolean friendly = userService.isUserFriendly(it) sql.executeUpdate('UPDATE user SET xmas_gifts=? WHERE id=?', [friendly, it.id]) } } }
You can add as many migration files as you like. All new migrations will run on next application startup.
Initial running and working release.
Exclude migration from running in certain environments via config.
Disable migrations running in TEST environment by default.
Specify packages in config to run in certain environments.
Enhance Grails compability down to version Grails 2.0 – currently Grails 2.2.
⤷ Grails 2.0 didn't work, Grails 2.1 is now minimum
Internal: Make Spock test framework to work within plugin tests.
Internal: Inventing a cool smig-ish icon to enhance recognition value.
⤷ idea for an icon ready, see v2.1
Add possibility of a depending migration running before an other migration. The "migration 2" dependsOn "migration 1".
The idea for the smig-ish icon (see v1.3) needs to be polished and digitized.
By default migrations run in every environment except TEST. You can change this behaviour by adding a config. You can make it environment specific, e.g.:
smig.enabled = true
environments {
develop {
smig.enabled = false
}
}
This will run migrations in every environment except DEVELOP.
By default all found, not yet run migrations will be executed. You can change this behaviour by specifying some "patterns" applying to the full migration class names.
smig.included.migrations = ['com.project.migrations.production']
environments {
test {
smig.enabled = true // is disabled by default
smig.included.migrations = ['com.project.migrations.integration']
}
custom-env {
// example with regex pattern
smig.included.migrations = ['com.project.migrations.database', ~/[Cc]ustom/]
}
}
This config specifies the packages for the migrations to run. Using package names is just a recommendation. All migrations will be found
-
containing (not beginning) the specified Strings
-
finding (not matching) the specified Pattern (java.util.regex.Pattern)
Beware:
The config smig.included.migrations has to be a collection. Any other kind of object will fail and abort the application with a meaningful error.
Setting null or an empty list will result in never finding any migrations.
There is logging for migrations as well. Add this line to your log4j config.
log4j = {
..
info 'com.smig.plugin'
..
..
}
"debug" is also possible to squeeze some more information out of it.
If there is more than one migration file the executed order results from sorting the full qualified class name.
Unfortunately it's not that easy yet. Unless this plugin is not hosted on Grails Centrals repository, you have to clone this git repository by doing the following commands:
git clone https://github.com/s-doering/smig.git
cd smig.git
*** change "app.grails.version" in application.properties to your Grails version ***
grails clean
grails compile
grails maven-install
This will generate the plugin on your local harddrive.
If you have an artifactory yourself. You can add it there, too.