Skip to content

Commit

Permalink
allow ActiveRecord#RecordInvalid exception message to be localized
Browse files Browse the repository at this point in the history
[#2754 state:committed]

Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
  • Loading branch information
Sven Fuchs authored and jeremy committed Aug 26, 2009
1 parent adedf72 commit d672a14
Show file tree
Hide file tree
Showing 3 changed files with 191 additions and 1 deletion.
1 change: 1 addition & 0 deletions activerecord/lib/active_record/locale/en.yml
Expand Up @@ -23,6 +23,7 @@ en:
less_than_or_equal_to: "must be less than or equal to {{count}}" less_than_or_equal_to: "must be less than or equal to {{count}}"
odd: "must be odd" odd: "must be odd"
even: "must be even" even: "must be even"
record_invalid: "Validation failed: {{errors}}"
# Append your own errors here or at the model/attributes scope. # Append your own errors here or at the model/attributes scope.


# You can define own errors for models or model attributes. # You can define own errors for models or model attributes.
Expand Down
3 changes: 2 additions & 1 deletion activerecord/lib/active_record/validations.rb
Expand Up @@ -12,7 +12,8 @@ class RecordInvalid < ActiveRecordError
attr_reader :record attr_reader :record
def initialize(record) def initialize(record)
@record = record @record = record
super("Validation failed: #{@record.errors.full_messages.join(", ")}") errors = @record.errors.full_messages.join(I18n.t('support.array.words_connector', :default => ', '))
super(I18n.t('activerecord.errors.messages.record_invalid', :errors => errors))
end end
end end


Expand Down
188 changes: 188 additions & 0 deletions activerecord/test/cases/validations/i18n_validation_test.rb
Expand Up @@ -709,3 +709,191 @@ def test_validates_with_message_string
assert_equal ["I am a custom error"], @topic.errors[:title] assert_equal ["I am a custom error"], @topic.errors[:title]
end end
end end

class ActiveRecordValidationsGenerateMessageI18nTests < ActiveSupport::TestCase
def setup
reset_callbacks Topic
@topic = Topic.new
I18n.backend.store_translations :'en', {
:activerecord => {
:errors => {
:messages => {
:inclusion => "is not included in the list",
:exclusion => "is reserved",
:invalid => "is invalid",
:confirmation => "doesn't match confirmation",
:accepted => "must be accepted",
:empty => "can't be empty",
:blank => "can't be blank",
:too_long => "is too long (maximum is {{count}} characters)",
:too_short => "is too short (minimum is {{count}} characters)",
:wrong_length => "is the wrong length (should be {{count}} characters)",
:taken => "has already been taken",
:not_a_number => "is not a number",
:greater_than => "must be greater than {{count}}",
:greater_than_or_equal_to => "must be greater than or equal to {{count}}",
:equal_to => "must be equal to {{count}}",
:less_than => "must be less than {{count}}",
:less_than_or_equal_to => "must be less than or equal to {{count}}",
:odd => "must be odd",
:even => "must be even"
}
}
}
}
end

def reset_callbacks(*models)
models.each do |model|
model.instance_variable_set("@validate_callbacks", ActiveSupport::Callbacks::CallbackChain.new)
model.instance_variable_set("@validate_on_create_callbacks", ActiveSupport::Callbacks::CallbackChain.new)
model.instance_variable_set("@validate_on_update_callbacks", ActiveSupport::Callbacks::CallbackChain.new)
end
end

# validates_inclusion_of: generate_message(attr_name, :inclusion, :default => configuration[:message], :value => value)
def test_generate_message_inclusion_with_default_message
assert_equal 'is not included in the list', @topic.errors.generate_message(:title, :inclusion, :default => nil, :value => 'title')
end

def test_generate_message_inclusion_with_custom_message
assert_equal 'custom message title', @topic.errors.generate_message(:title, :inclusion, :default => 'custom message {{value}}', :value => 'title')
end

# validates_exclusion_of: generate_message(attr_name, :exclusion, :default => configuration[:message], :value => value)
def test_generate_message_exclusion_with_default_message
assert_equal 'is reserved', @topic.errors.generate_message(:title, :exclusion, :default => nil, :value => 'title')
end

def test_generate_message_exclusion_with_custom_message
assert_equal 'custom message title', @topic.errors.generate_message(:title, :exclusion, :default => 'custom message {{value}}', :value => 'title')
end

# validates_associated: generate_message(attr_name, :invalid, :default => configuration[:message], :value => value)
# validates_format_of: generate_message(attr_name, :invalid, :default => configuration[:message], :value => value)
def test_generate_message_invalid_with_default_message
assert_equal 'is invalid', @topic.errors.generate_message(:title, :invalid, :default => nil, :value => 'title')
end

def test_generate_message_invalid_with_custom_message
assert_equal 'custom message title', @topic.errors.generate_message(:title, :invalid, :default => 'custom message {{value}}', :value => 'title')
end

# validates_confirmation_of: generate_message(attr_name, :confirmation, :default => configuration[:message])
def test_generate_message_confirmation_with_default_message
assert_equal "doesn't match confirmation", @topic.errors.generate_message(:title, :confirmation, :default => nil)
end

def test_generate_message_confirmation_with_custom_message
assert_equal 'custom message', @topic.errors.generate_message(:title, :confirmation, :default => 'custom message')
end

# validates_acceptance_of: generate_message(attr_name, :accepted, :default => configuration[:message])
def test_generate_message_accepted_with_default_message
assert_equal "must be accepted", @topic.errors.generate_message(:title, :accepted, :default => nil)
end

def test_generate_message_accepted_with_custom_message
assert_equal 'custom message', @topic.errors.generate_message(:title, :accepted, :default => 'custom message')
end

# add_on_empty: generate_message(attr, :empty, :default => custom_message)
def test_generate_message_empty_with_default_message
assert_equal "can't be empty", @topic.errors.generate_message(:title, :empty, :default => nil)
end

def test_generate_message_empty_with_custom_message
assert_equal 'custom message', @topic.errors.generate_message(:title, :empty, :default => 'custom message')
end

# add_on_blank: generate_message(attr, :blank, :default => custom_message)
def test_generate_message_blank_with_default_message
assert_equal "can't be blank", @topic.errors.generate_message(:title, :blank, :default => nil)
end

def test_generate_message_blank_with_custom_message
assert_equal 'custom message', @topic.errors.generate_message(:title, :blank, :default => 'custom message')
end

# validates_length_of: generate_message(attr, :too_long, :default => options[:too_long], :count => option_value.end)
def test_generate_message_too_long_with_default_message
assert_equal "is too long (maximum is 10 characters)", @topic.errors.generate_message(:title, :too_long, :default => nil, :count => 10)
end

def test_generate_message_too_long_with_custom_message
assert_equal 'custom message 10', @topic.errors.generate_message(:title, :too_long, :default => 'custom message {{count}}', :count => 10)
end

# validates_length_of: generate_message(attr, :too_short, :default => options[:too_short], :count => option_value.begin)
def test_generate_message_too_short_with_default_message
assert_equal "is too short (minimum is 10 characters)", @topic.errors.generate_message(:title, :too_short, :default => nil, :count => 10)
end

def test_generate_message_too_short_with_custom_message
assert_equal 'custom message 10', @topic.errors.generate_message(:title, :too_short, :default => 'custom message {{count}}', :count => 10)
end

# validates_length_of: generate_message(attr, key, :default => custom_message, :count => option_value)
def test_generate_message_wrong_length_with_default_message
assert_equal "is the wrong length (should be 10 characters)", @topic.errors.generate_message(:title, :wrong_length, :default => nil, :count => 10)
end

def test_generate_message_wrong_length_with_custom_message
assert_equal 'custom message 10', @topic.errors.generate_message(:title, :wrong_length, :default => 'custom message {{count}}', :count => 10)
end

# validates_uniqueness_of: generate_message(attr_name, :taken, :default => configuration[:message])
def test_generate_message_taken_with_default_message
assert_equal "has already been taken", @topic.errors.generate_message(:title, :taken, :default => nil, :value => 'title')
end

def test_generate_message_taken_with_custom_message
assert_equal 'custom message title', @topic.errors.generate_message(:title, :taken, :default => 'custom message {{value}}', :value => 'title')
end

# validates_numericality_of: generate_message(attr_name, :not_a_number, :value => raw_value, :default => configuration[:message])
def test_generate_message_not_a_number_with_default_message
assert_equal "is not a number", @topic.errors.generate_message(:title, :not_a_number, :default => nil, :value => 'title')
end

def test_generate_message_not_a_number_with_custom_message
assert_equal 'custom message title', @topic.errors.generate_message(:title, :not_a_number, :default => 'custom message {{value}}', :value => 'title')
end

# validates_numericality_of: generate_message(attr_name, option, :value => raw_value, :default => configuration[:message])
def test_generate_message_greater_than_with_default_message
assert_equal "must be greater than 10", @topic.errors.generate_message(:title, :greater_than, :default => nil, :value => 'title', :count => 10)
end

def test_generate_message_greater_than_or_equal_to_with_default_message
assert_equal "must be greater than or equal to 10", @topic.errors.generate_message(:title, :greater_than_or_equal_to, :default => nil, :value => 'title', :count => 10)
end

def test_generate_message_equal_to_with_default_message
assert_equal "must be equal to 10", @topic.errors.generate_message(:title, :equal_to, :default => nil, :value => 'title', :count => 10)
end

def test_generate_message_less_than_with_default_message
assert_equal "must be less than 10", @topic.errors.generate_message(:title, :less_than, :default => nil, :value => 'title', :count => 10)
end

def test_generate_message_less_than_or_equal_to_with_default_message
assert_equal "must be less than or equal to 10", @topic.errors.generate_message(:title, :less_than_or_equal_to, :default => nil, :value => 'title', :count => 10)
end

def test_generate_message_odd_with_default_message
assert_equal "must be odd", @topic.errors.generate_message(:title, :odd, :default => nil, :value => 'title', :count => 10)
end

def test_generate_message_even_with_default_message
assert_equal "must be even", @topic.errors.generate_message(:title, :even, :default => nil, :value => 'title', :count => 10)
end
# ActiveRecord#RecordInvalid exception

test "RecordInvalid exception can be localized" do
topic = Topic.new
topic.errors.add(:title, :invalid)
topic.errors.add(:title, :blank)
assert_equal "Validation failed: Title is invalid, Title can't be blank", ActiveRecord::RecordInvalid.new(topic).message
end
end

0 comments on commit d672a14

Please sign in to comment.