aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorSean Linsley <code@seanlinsley.com>2017-10-18 10:29:27 -0500
committerSean Linsley <code@seanlinsley.com>2018-07-22 12:51:47 -0500
commitdfb0e4b3dc94860e6d484385d31fd399d33dac92 (patch)
treef22a5dbdd3a1af63920001749a038629167148d0 /activerecord
parent97321956e6c2d2bae1bf6f76fce5bfb909ab58b0 (diff)
downloadrails-dfb0e4b3dc94860e6d484385d31fd399d33dac92.tar.gz
rails-dfb0e4b3dc94860e6d484385d31fd399d33dac92.tar.bz2
rails-dfb0e4b3dc94860e6d484385d31fd399d33dac92.zip
add strict argument checking to ActiveRecord callbacks
This ends up adding it to all save-related callbacks defined in `ActiveRecord::DefineCallbacks`, including e.g. `after_create`. Which should be fine: they didn't support `:on` in the first place.
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/test/cases/callbacks_test.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/activerecord/test/cases/callbacks_test.rb b/activerecord/test/cases/callbacks_test.rb
index b9ba51c730..e10a7b34c8 100644
--- a/activerecord/test/cases/callbacks_test.rb
+++ b/activerecord/test/cases/callbacks_test.rb
@@ -476,4 +476,27 @@ class CallbacksTest < ActiveRecord::TestCase
child.save
assert child.after_save_called
end
+
+ def test_on_isnt_allowed
+ exception = assert_raises ArgumentError do
+ Class.new(ActiveRecord::Base) do
+ before_save(on: :create) {}
+ end
+ end
+ assert_equal "Unknown key: :on. Valid keys are: :if, :unless, :prepend", exception.message
+
+ exception = assert_raises ArgumentError do
+ Class.new(ActiveRecord::Base) do
+ around_save(on: :create) {}
+ end
+ end
+ assert_equal "Unknown key: :on. Valid keys are: :if, :unless, :prepend", exception.message
+
+ exception = assert_raises ArgumentError do
+ Class.new(ActiveRecord::Base) do
+ after_save(on: :create) {}
+ end
+ end
+ assert_equal "Unknown key: :on. Valid keys are: :if, :unless, :prepend", exception.message
+ end
end