aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2015-09-07 17:16:54 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2015-09-07 17:16:54 -0300
commit7b9b0b531f9cb6a64737efc5c46890b4609847bf (patch)
tree22a37eeb9b3418a86b62051b9ece467a45b02443
parent51dd2588433457960cca592d5b5dac6e0537feac (diff)
downloadrails-7b9b0b531f9cb6a64737efc5c46890b4609847bf.tar.gz
rails-7b9b0b531f9cb6a64737efc5c46890b4609847bf.tar.bz2
rails-7b9b0b531f9cb6a64737efc5c46890b4609847bf.zip
Revert "Merge pull request #21069 from dmitry/feature/validate-multiple-contexts-at-once"
This reverts commit 51dd2588433457960cca592d5b5dac6e0537feac, reversing changes made to ecb4e4b21b3222b823fa24d4a0598b1f2f63ecfb. This broke Active Record tests
-rw-r--r--activemodel/CHANGELOG.md18
-rw-r--r--activemodel/lib/active_model/validations.rb2
-rw-r--r--activemodel/test/cases/validations/validations_context_test.rb19
-rw-r--r--activerecord/lib/active_record/validations.rb6
-rw-r--r--activerecord/test/cases/validations_test.rb7
5 files changed, 2 insertions, 50 deletions
diff --git a/activemodel/CHANGELOG.md b/activemodel/CHANGELOG.md
index 769c0d6291..54fe5794e1 100644
--- a/activemodel/CHANGELOG.md
+++ b/activemodel/CHANGELOG.md
@@ -1,21 +1,3 @@
-* Validate multiple contexts on `valid?` and `invalid?` at once.
-
- Example:
-
- class Person
- include ActiveModel::Validations
-
- attr_reader :name, :title
- validates_presence_of :name, on: :create
- validates_presence_of :title, on: :update
- end
-
- person = Person.new
- person.valid?([:create, :update]) # => true
- person.errors.messages # => {:name=>["can't be blank"], :title=>["can't be blank"]}
-
- *Dmitry Polushkin*
-
* Add case_sensitive option for confirmation validator in models.
*Akshat Sharma*
diff --git a/activemodel/lib/active_model/validations.rb b/activemodel/lib/active_model/validations.rb
index f23c920d87..5f1dde4aa3 100644
--- a/activemodel/lib/active_model/validations.rb
+++ b/activemodel/lib/active_model/validations.rb
@@ -162,7 +162,7 @@ module ActiveModel
options = options.dup
options[:if] = Array(options[:if])
options[:if].unshift ->(o) {
- !(Array(options[:on]) & Array(o.validation_context)).empty?
+ Array(options[:on]).include?(o.validation_context)
}
end
diff --git a/activemodel/test/cases/validations/validations_context_test.rb b/activemodel/test/cases/validations/validations_context_test.rb
index b901a1523e..150dce379f 100644
--- a/activemodel/test/cases/validations/validations_context_test.rb
+++ b/activemodel/test/cases/validations/validations_context_test.rb
@@ -8,7 +8,6 @@ class ValidationsContextTest < ActiveModel::TestCase
end
ERROR_MESSAGE = "Validation error from validator"
- ANOTHER_ERROR_MESSAGE = "Another validation error from validator"
class ValidatorThatAddsErrors < ActiveModel::Validator
def validate(record)
@@ -16,12 +15,6 @@ class ValidationsContextTest < ActiveModel::TestCase
end
end
- class AnotherValidatorThatAddsErrors < ActiveModel::Validator
- def validate(record)
- record.errors[:base] << ANOTHER_ERROR_MESSAGE
- end
- end
-
test "with a class that adds errors on create and validating a new model with no arguments" do
Topic.validates_with(ValidatorThatAddsErrors, on: :create)
topic = Topic.new
@@ -53,16 +46,4 @@ class ValidationsContextTest < ActiveModel::TestCase
assert topic.invalid?(:context2), "Validation did not run on context2 when 'on' is set to context1 and context2"
assert topic.errors[:base].include?(ERROR_MESSAGE)
end
-
- test "with a class that validating a model for a multiple contexts" do
- Topic.validates_with(ValidatorThatAddsErrors, on: :context1)
- Topic.validates_with(AnotherValidatorThatAddsErrors, on: :context2)
-
- topic = Topic.new
- assert topic.valid?, "Validation ran with no context given when 'on' is set to context1 and context2"
-
- assert topic.invalid?([:context1, :context2]), "Validation did not run on context1 when 'on' is set to context1 and context2"
- assert topic.errors[:base].include?(ERROR_MESSAGE)
- assert topic.errors[:base].include?(ANOTHER_ERROR_MESSAGE)
- end
end
diff --git a/activerecord/lib/active_record/validations.rb b/activerecord/lib/active_record/validations.rb
index 108fe548c8..34d96b19fe 100644
--- a/activerecord/lib/active_record/validations.rb
+++ b/activerecord/lib/active_record/validations.rb
@@ -54,7 +54,7 @@ module ActiveRecord
# Validations with no <tt>:on</tt> option will run no matter the context. Validations with
# some <tt>:on</tt> option will only run in the specified context.
def valid?(context = nil)
- context ||= default_validation_context
+ context ||= (new_record? ? :create : :update)
output = super(context)
errors.empty? && output
end
@@ -63,10 +63,6 @@ module ActiveRecord
protected
- def default_validation_context
- [new_record? ? :create : :update]
- end
-
def raise_validation_error
raise(RecordInvalid.new(self))
end
diff --git a/activerecord/test/cases/validations_test.rb b/activerecord/test/cases/validations_test.rb
index a429d06aad..f4f316f393 100644
--- a/activerecord/test/cases/validations_test.rb
+++ b/activerecord/test/cases/validations_test.rb
@@ -52,13 +52,6 @@ class ValidationsTest < ActiveRecord::TestCase
assert r.valid?(:special_case)
end
- def test_invalid_using_multiple_contexts
- r = WrongReply.new(:title => 'Wrong Create')
- assert r.invalid?([:special_case, :create])
- assert_equal "Invalid", r.errors[:author_name].join
- assert_equal "is Wrong Create", r.errors[:title].join
- end
-
def test_validate
r = WrongReply.new