summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/models/setting.rb22
-rw-r--r--test/unit/setting_test.rb16
2 files changed, 37 insertions, 1 deletions
diff --git a/app/models/setting.rb b/app/models/setting.rb
index ca280ebcd..cc4131bec 100644
--- a/app/models/setting.rb
+++ b/app/models/setting.rb
@@ -91,7 +91,10 @@ class Setting < ActiveRecord::Base
def value
v = read_attribute(:value)
# Unserialize serialized settings
- v = YAML::load(v) if available_settings[name]['serialized'] && v.is_a?(String)
+ if available_settings[name]['serialized'] && v.is_a?(String)
+ v = YAML::load(v)
+ force_utf8_strings(v)
+ end
v = v.to_sym if available_settings[name]['format'] == 'symbol' && !v.blank?
v
end
@@ -238,6 +241,23 @@ END_SRC
load_plugin_settings
private
+
+ def force_utf8_strings(arg)
+ if arg.is_a?(String)
+ arg.force_encoding('UTF-8')
+ elsif arg.is_a?(Array)
+ arg.each do |a|
+ force_utf8_strings(a)
+ end
+ elsif arg.is_a?(Hash)
+ arg.each do |k,v|
+ force_utf8_strings(k)
+ force_utf8_strings(v)
+ end
+ end
+ arg
+ end
+
# Returns the Setting instance for the setting named name
# (record found in database or new record with default value)
def self.find_or_default(name)
diff --git a/test/unit/setting_test.rb b/test/unit/setting_test.rb
index 46383e867..d2dee6d6b 100644
--- a/test/unit/setting_test.rb
+++ b/test/unit/setting_test.rb
@@ -1,3 +1,5 @@
+# encoding: utf-8
+#
# Redmine - project management software
# Copyright (C) 2006-2015 Jean-Philippe Lang
#
@@ -101,4 +103,18 @@ class SettingTest < ActiveSupport::TestCase
assert_equal [10, 25, 50], Setting.per_page_options_array
end
end
+
+ def test_serialized_setting_should_be_loaded_as_utf8_encoded_strings
+ scm = 'исправлено'
+ scm.force_encoding('BINARY')
+ Setting.enabled_scm = [scm]
+ Setting.clear_cache
+
+ s = Setting.enabled_scm
+ assert_equal ['исправлено'], s
+ assert_equal 'UTF-8', s.first.encoding.name
+ ensure
+ Setting.where(:name => 'enabled_scm').delete_all
+ Setting.clear_cache
+ end
end