aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorbondarev <alexander.i.bondarev@gmail.com>2013-02-25 19:05:22 +0400
committerbondarev <alexander.i.bondarev@gmail.com>2013-04-18 18:18:59 +0400
commit2976558bc3a02019b605a1d70fda76ba5e9b5df2 (patch)
treef7fce26c5be8b73cd7907b5e0fd23e5772d9b3c2 /activerecord/lib
parent130d3a06ade83aec27cf1d2ff841dce9e0ad4dfd (diff)
downloadrails-2976558bc3a02019b605a1d70fda76ba5e9b5df2.tar.gz
rails-2976558bc3a02019b605a1d70fda76ba5e9b5df2.tar.bz2
rails-2976558bc3a02019b605a1d70fda76ba5e9b5df2.zip
Support transactions in Migrator.run
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/migration.rb17
1 files changed, 12 insertions, 5 deletions
diff --git a/activerecord/lib/active_record/migration.rb b/activerecord/lib/active_record/migration.rb
index 451104106c..d2f10cf2ac 100644
--- a/activerecord/lib/active_record/migration.rb
+++ b/activerecord/lib/active_record/migration.rb
@@ -867,11 +867,18 @@ module ActiveRecord
alias :current :current_migration
def run
- target = migrations.detect { |m| m.version == @target_version }
- raise UnknownMigrationVersionError.new(@target_version) if target.nil?
- unless (up? && migrated.include?(target.version.to_i)) || (down? && !migrated.include?(target.version.to_i))
- target.migrate(@direction)
- record_version_state_after_migrating(target.version)
+ migration = migrations.detect { |m| m.version == @target_version }
+ raise UnknownMigrationVersionError.new(@target_version) if migration.nil?
+ unless (up? && migrated.include?(migration.version.to_i)) || (down? && !migrated.include?(migration.version.to_i))
+ begin
+ ddl_transaction(migration) do
+ migration.migrate(@direction)
+ record_version_state_after_migrating(migration.version)
+ end
+ rescue => e
+ canceled_msg = use_transaction?(migration) ? ", the migration canceled" : ""
+ raise StandardError, "An error has occurred#{canceled_msg}:\n\n#{e}", e.backtrace
+ end
end
end