aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorVijay Dev <vijaydev.cse@gmail.com>2011-06-25 00:01:59 +0530
committerVijay Dev <vijaydev.cse@gmail.com>2011-06-25 17:17:02 +0530
commitc278a2c5e109204ec8a47fcbfdfc327aad7996ce (patch)
tree9aa75fd3a1a81f42aedfdc3786165cc40f5f4f1b /activerecord
parent7e56bf724479ce92eff2f806573f382957f3a2b4 (diff)
downloadrails-c278a2c5e109204ec8a47fcbfdfc327aad7996ce.tar.gz
rails-c278a2c5e109204ec8a47fcbfdfc327aad7996ce.tar.bz2
rails-c278a2c5e109204ec8a47fcbfdfc327aad7996ce.zip
record unsupported methods in CommandRecorder instead of letting the unsupported methods go through to the underlying db causing errors like duplicate columns to occur when rolling back migrations
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/lib/active_record/migration/command_recorder.rb8
-rw-r--r--activerecord/test/cases/migration/command_recorder_test.rb8
2 files changed, 9 insertions, 7 deletions
diff --git a/activerecord/lib/active_record/migration/command_recorder.rb b/activerecord/lib/active_record/migration/command_recorder.rb
index f01e94169f..d06e050db3 100644
--- a/activerecord/lib/active_record/migration/command_recorder.rb
+++ b/activerecord/lib/active_record/migration/command_recorder.rb
@@ -93,11 +93,11 @@ module ActiveRecord
[:remove_timestamps, args]
end
- # Forwards any missing method call to the \target.
+ # Record all the methods called in the +change+ method of a migration.
+ # This will ensure that IrreversibleMigration is raised when the corresponding
+ # invert_method does not exist while the migration is rolled back.
def method_missing(method, *args, &block)
- @delegate.send(method, *args, &block)
- rescue NoMethodError => e
- raise e, e.message.sub(/ for #<.*$/, " via proxy for #{@delegate}")
+ record(method, args)
end
end
diff --git a/activerecord/test/cases/migration/command_recorder_test.rb b/activerecord/test/cases/migration/command_recorder_test.rb
index 0f79c99e1a..a03c80bf93 100644
--- a/activerecord/test/cases/migration/command_recorder_test.rb
+++ b/activerecord/test/cases/migration/command_recorder_test.rb
@@ -14,9 +14,11 @@ module ActiveRecord
assert recorder.respond_to?(:america)
end
- def test_send_calls_super
- assert_raises(NoMethodError) do
- @recorder.send(:non_existing_method, :horses)
+ def test_non_existing_method_records_and_raises_on_inversion
+ @recorder.send(:non_existing_method, :horses)
+ assert_equal 1, @recorder.commands.length
+ assert_raises(ActiveRecord::IrreversibleMigration) do
+ @recorder.inverse
end
end