Skip to content
Browse files

:if should not fire on validations when not in context with :on

  • Loading branch information...
1 parent e594913 commit bf5cf5db86fa0aeb818d32541a35310de992f426 Aditya Sanghi committed Apr 29, 2011
View
2 activemodel/lib/active_model/validations.rb
@@ -133,7 +133,7 @@ def validate(*args, &block)
if options.key?(:on)
options = options.dup
options[:if] = Array.wrap(options[:if])
- options[:if] << "validation_context == :#{options[:on]}"
+ options[:if].unshift("validation_context == :#{options[:on]}")
end
args << options
set_callback(:validate, *args, &block)
View
4 activemodel/lib/active_model/validations/callbacks.rb
@@ -31,7 +31,7 @@ def before_validation(*args, &block)
options = args.last
if options.is_a?(Hash) && options[:on]
options[:if] = Array.wrap(options[:if])
- options[:if] << "self.validation_context == :#{options[:on]}"
+ options[:if].unshift("self.validation_context == :#{options[:on]}")
end
set_callback(:validation, :before, *args, &block)
end
@@ -41,7 +41,7 @@ def after_validation(*args, &block)
options[:prepend] = true
options[:if] = Array.wrap(options[:if])
options[:if] << "!halted"
- options[:if] << "self.validation_context == :#{options[:on]}" if options[:on]
+ options[:if].unsfhit("self.validation_context == :#{options[:on]}") if options[:on]
set_callback(:validation, :after, *(args << options), &block)
end
end
View
14 activemodel/test/cases/validations_test.rb
@@ -212,6 +212,20 @@ def test_validation_order
assert_equal 'is too short (minimum is 2 characters)', t.errors[key][0]
end
+ def test_validaton_with_if_and_on
+ Topic.validates_presence_of :title, :if => Proc.new{|x| x.author_name = "bad"; true }, :on => :update
+
+ t = Topic.new(:title => "")
+
+ # If block should not fire
+ assert t.valid?
+ assert t.author_name.nil?
+
+ # If block should fire
+ assert t.invalid?(:update)
+ assert t.author_name == "bad"
+ end
+
def test_invalid_should_be_the_opposite_of_valid
Topic.validates_presence_of :title

0 comments on commit bf5cf5d

Please sign in to comment.
Something went wrong with that request. Please try again.