diff options
author | Dmitry Polushkin <dmitry.polushkin@gmail.com> | 2015-07-30 09:58:46 +0100 |
---|---|---|
committer | Dmitry Polushkin <dmitry.polushkin@gmail.com> | 2015-07-30 10:05:29 +0100 |
commit | 86e3b047ba0349bd88952d4e54504327c3f7e59c (patch) | |
tree | f2dea38df5f5f4c92427a8fc0613b14b80221356 /activemodel/lib | |
parent | 64c1264419f766a306eba0418c1030b87489ea67 (diff) | |
download | rails-86e3b047ba0349bd88952d4e54504327c3f7e59c.tar.gz rails-86e3b047ba0349bd88952d4e54504327c3f7e59c.tar.bz2 rails-86e3b047ba0349bd88952d4e54504327c3f7e59c.zip |
Validate multiple contexts on `valid?` and `invalid?` at once.
Example:
```ruby
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"]}
```
Diffstat (limited to 'activemodel/lib')
-rw-r--r-- | activemodel/lib/active_model/validations.rb | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/activemodel/lib/active_model/validations.rb b/activemodel/lib/active_model/validations.rb index 5f1dde4aa3..f23c920d87 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]).include?(o.validation_context) + !(Array(options[:on]) & Array(o.validation_context)).empty? } end |