From 143613e78c131cc7807bfcadc26fab3212ab4cca Mon Sep 17 00:00:00 2001 From: Beth Skurrie Date: Mon, 1 Jun 2020 10:26:28 +1000 Subject: [PATCH] feat(database): allow options to be passed to Sequel migrate via the MigrationTask --- lib/pact_broker/tasks/migration_task.rb | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/lib/pact_broker/tasks/migration_task.rb b/lib/pact_broker/tasks/migration_task.rb index 27121e08a..e49c36cc9 100644 --- a/lib/pact_broker/tasks/migration_task.rb +++ b/lib/pact_broker/tasks/migration_task.rb @@ -16,8 +16,10 @@ module DB class MigrationTask < ::Rake::TaskLib attr_accessor :database_connection + attr_accessor :options def initialize &block + @options = {} rake_task &block end @@ -27,12 +29,29 @@ def rake_task &block desc "Run sequel migrations for pact broker database" task :migrate, [:target] do | t, args | require 'pact_broker/db/migrate' + require 'pact_broker/db/version' + instance_eval(&block) - options = {} + if args[:target] options[:target] = args[:target].to_i end + + if (logger = database_connection.loggers.first) + current_version = PactBroker::DB::Version.call(database_connection) + if options[:target] + logger.info "Migrating from schema version #{current_version} to #{options[:target]}" + else + logger.info "Migrating from schema version #{current_version} to latest" + end + end + PactBroker::DB::Migrate.call(database_connection, options) + + if logger + current_version = PactBroker::DB::Version.call(database_connection) + logger.info "Current schema version is now #{current_version}" + end end end end