aboutsummaryrefslogtreecommitdiffstats
path: root/activemodel/lib/active_model/errors.rb
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2012-08-16 16:59:04 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2012-08-16 16:59:04 -0300
commitcfd7f4e9a09df137f1e78ae7194e969e4bacfd87 (patch)
tree633ea06abec347363d73548163f9fe8f83531a2f /activemodel/lib/active_model/errors.rb
parent2a42b12d3b2ccfbdd14893cbc73f78ab229a34c2 (diff)
parent2e4f7986b8ec90d7b41c385388be21b8cee79b9c (diff)
downloadrails-cfd7f4e9a09df137f1e78ae7194e969e4bacfd87.tar.gz
rails-cfd7f4e9a09df137f1e78ae7194e969e4bacfd87.tar.bz2
rails-cfd7f4e9a09df137f1e78ae7194e969e4bacfd87.zip
Merge pull request #7024 from bogdan/strict_validation_custom_exception
AM::Validation#validates: custom exception for :strict option Conflicts: activemodel/CHANGELOG.md
Diffstat (limited to 'activemodel/lib/active_model/errors.rb')
-rw-r--r--activemodel/lib/active_model/errors.rb8
1 files changed, 6 insertions, 2 deletions
diff --git a/activemodel/lib/active_model/errors.rb b/activemodel/lib/active_model/errors.rb
index 1026b0f4d3..b3b9ba8e56 100644
--- a/activemodel/lib/active_model/errors.rb
+++ b/activemodel/lib/active_model/errors.rb
@@ -283,15 +283,19 @@ module ActiveModel
#
# If the <tt>:strict</tt> option is set to true will raise
# ActiveModel::StrictValidationFailed instead of adding the error.
+ # <tt>:strict</tt> option can also be set to any other exception.
#
# person.errors.add(:name, nil, strict: true)
# # => ActiveModel::StrictValidationFailed: name is invalid
+ # person.errors.add(:name, nil, strict: NameIsInvalid)
+ # # => NameIsInvalid: name is invalid
#
# person.errors.messages # => {}
def add(attribute, message = nil, options = {})
message = normalize_message(attribute, message, options)
- if options[:strict]
- raise ActiveModel::StrictValidationFailed, full_message(attribute, message)
+ if exception = options[:strict]
+ exception = ActiveModel::StrictValidationFailed if exception == true
+ raise exception, full_message(attribute, message)
end
self[attribute] << message