aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2010-05-23 13:22:19 +0200
committerJosé Valim <jose.valim@gmail.com>2010-05-23 13:22:19 +0200
commit8d5939c0966fa0255eae75e29f68ec55539206d1 (patch)
tree1708cfdf4768987a140734cddff1df8336317f57
parentf3abc8ac36055afed9fcc902c33ee146e066d17a (diff)
downloadrails-8d5939c0966fa0255eae75e29f68ec55539206d1.tar.gz
rails-8d5939c0966fa0255eae75e29f68ec55539206d1.tar.bz2
rails-8d5939c0966fa0255eae75e29f68ec55539206d1.zip
Fix a bug where I18n fallbacks modules where not included in the proper backend if it was set through config.i18n.backend.
-rw-r--r--activesupport/lib/active_support/railtie.rb5
-rw-r--r--railties/test/railties/i18n_railtie_test.rb17
2 files changed, 13 insertions, 9 deletions
diff --git a/activesupport/lib/active_support/railtie.rb b/activesupport/lib/active_support/railtie.rb
index 0243157e35..59f9ab18b1 100644
--- a/activesupport/lib/active_support/railtie.rb
+++ b/activesupport/lib/active_support/railtie.rb
@@ -48,19 +48,20 @@ module I18n
# Set the i18n configuration from config.i18n but special-case for
# the load_path which should be appended to what's already set instead of overwritten.
config.after_initialize do |app|
+ fallbacks = app.config.i18n.delete(:fallbacks)
+
app.config.i18n.each do |setting, value|
case setting
when :railties_load_path
app.config.i18n.load_path.unshift(*value)
when :load_path
I18n.load_path += value
- when :fallbacks
- init_fallbacks(value) if value && validate_fallbacks(value)
else
I18n.send("#{setting}=", value)
end
end
+ init_fallbacks(fallbacks) if fallbacks && validate_fallbacks(fallbacks)
I18n.reload!
end
diff --git a/railties/test/railties/i18n_railtie_test.rb b/railties/test/railties/i18n_railtie_test.rb
index 51684aa838..2b1950b3d5 100644
--- a/railties/test/railties/i18n_railtie_test.rb
+++ b/railties/test/railties/i18n_railtie_test.rb
@@ -9,12 +9,6 @@ module RailtiesTest
boot_rails
FileUtils.rm_rf("#{app_path}/config/environments")
require "rails/all"
- @old_path = I18n.load_path
- end
-
- def teardown
- I18n.load_path = @old_path || []
- I18n.backend = nil
end
def load_app
@@ -42,7 +36,7 @@ module RailtiesTest
end
test "not using config.i18n.fallbacks does not initialize I18n.fallbacks" do
- I18n.backend = Class.new { include I18n::Backend::Base }.new # can't uninclude modules, so use a tmp backend class
+ I18n.backend = Class.new { include I18n::Backend::Base }.new
load_app
assert_no_fallbacks
end
@@ -50,6 +44,15 @@ module RailtiesTest
test "config.i18n.fallbacks = true initializes I18n.fallbacks with default settings" do
I18n::Railtie.config.i18n.fallbacks = true
load_app
+ assert I18n.backend.class.included_modules.include?(I18n::Backend::Fallbacks)
+ assert_fallbacks :de => [:de, :en]
+ end
+
+ test "config.i18n.fallbacks = true initializes I18n.fallbacks with default settings even when backend changes" do
+ I18n::Railtie.config.i18n.fallbacks = true
+ I18n::Railtie.config.i18n.backend = Class.new { include I18n::Backend::Base }.new
+ load_app
+ assert I18n.backend.class.included_modules.include?(I18n::Backend::Fallbacks)
assert_fallbacks :de => [:de, :en]
end