1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Fall back to parent locale before it falls back to the :errors namespace

This commit is contained in:
Hugo Vacher 2019-02-27 09:42:02 -05:00
parent d333d85254
commit 2176f4b30c
2 changed files with 32 additions and 11 deletions

View file

@ -479,6 +479,14 @@ module ActiveModel
# * <tt>errors.messages.blank</tt> # * <tt>errors.messages.blank</tt>
def generate_message(attribute, type = :invalid, options = {}) def generate_message(attribute, type = :invalid, options = {})
type = options.delete(:message) if options[:message].is_a?(Symbol) type = options.delete(:message) if options[:message].is_a?(Symbol)
value = (attribute != :base ? @base.send(:read_attribute_for_validation, attribute) : nil)
options = {
model: @base.model_name.human,
attribute: @base.class.human_attribute_name(attribute),
value: value,
object: @base
}.merge!(options)
if @base.class.respond_to?(:i18n_scope) if @base.class.respond_to?(:i18n_scope)
i18n_scope = @base.class.i18n_scope.to_s i18n_scope = @base.class.i18n_scope.to_s
@ -487,6 +495,11 @@ module ActiveModel
:"#{i18n_scope}.errors.models.#{klass.model_name.i18n_key}.#{type}" ] :"#{i18n_scope}.errors.models.#{klass.model_name.i18n_key}.#{type}" ]
end end
defaults << :"#{i18n_scope}.errors.messages.#{type}" defaults << :"#{i18n_scope}.errors.messages.#{type}"
catch(:exception) do
translation = I18n.translate(defaults.first, options.merge(default: defaults.drop(1), throw: true))
return translation unless translation.nil?
end unless options[:message]
else else
defaults = [] defaults = []
end end
@ -496,15 +509,7 @@ module ActiveModel
key = defaults.shift key = defaults.shift
defaults = options.delete(:message) if options[:message] defaults = options.delete(:message) if options[:message]
value = (attribute != :base ? @base.send(:read_attribute_for_validation, attribute) : nil) options[:default] = defaults
options = {
default: defaults,
model: @base.model_name.human,
attribute: @base.class.human_attribute_name(attribute),
value: value,
object: @base
}.merge!(options)
I18n.translate(key, options) I18n.translate(key, options)
end end

View file

@ -4,16 +4,20 @@ require "cases/helper"
require "models/topic" require "models/topic"
class I18nGenerateMessageValidationTest < ActiveRecord::TestCase class I18nGenerateMessageValidationTest < ActiveRecord::TestCase
class Backend < I18n::Backend::Simple
include I18n::Backend::Fallbacks
end
def setup def setup
Topic.clear_validators! Topic.clear_validators!
@topic = Topic.new @topic = Topic.new
I18n.backend = I18n::Backend::Simple.new I18n.backend = Backend.new
end end
def reset_i18n_load_path def reset_i18n_load_path
@old_load_path, @old_backend = I18n.load_path.dup, I18n.backend @old_load_path, @old_backend = I18n.load_path.dup, I18n.backend
I18n.load_path.clear I18n.load_path.clear
I18n.backend = I18n::Backend::Simple.new I18n.backend = Backend.new
yield yield
ensure ensure
I18n.load_path.replace @old_load_path I18n.load_path.replace @old_load_path
@ -83,4 +87,16 @@ class I18nGenerateMessageValidationTest < ActiveRecord::TestCase
assert_equal "Custom taken message", @topic.errors.generate_message(:title, :taken, value: "title") assert_equal "Custom taken message", @topic.errors.generate_message(:title, :taken, value: "title")
end end
end end
test "activerecord attributes scope falls back to parent locale before it falls back to the :errors namespace" do
reset_i18n_load_path do
I18n.backend.store_translations "en", activerecord: { errors: { models: { topic: { attributes: { title: { taken: "custom en message" } } } } } }
I18n.backend.store_translations "en-US", errors: { messages: { taken: "generic en-US fallback" } }
I18n.with_locale "en-US" do
assert_equal "custom en message", @topic.errors.generate_message(:title, :taken, value: "title")
assert_equal "generic en-US fallback", @topic.errors.generate_message(:heading, :taken, value: "heading")
end
end
end
end end