]> source.dussan.org Git - redmine.git/commitdiff
Merged r21725 from trunk to 5.0-stable (#37450, #37476).
authorGo MAEDA <maeda@farend.jp>
Thu, 21 Jul 2022 01:41:14 +0000 (01:41 +0000)
committerGo MAEDA <maeda@farend.jp>
Thu, 21 Jul 2022 01:41:14 +0000 (01:41 +0000)
git-svn-id: https://svn.redmine.org/redmine/branches/5.0-stable@21729 e93f8b46-1217-0410-a6f0-8f06a7374b81

app/models/setting.rb
test/unit/lib/redmine/plugin_test.rb

index 53b88bcad4627dafd03ffa4fa7554d1b10129a11..aa27d9ecfa39b1e1dc7319baf76a6a6cf0d797e5 100644 (file)
@@ -108,7 +108,7 @@ class Setting < ActiveRecord::Base
     v = read_attribute(:value)
     # Unserialize serialized settings
     if available_settings[name]['serialized'] && v.is_a?(String)
-      v = YAML.safe_load(v, permitted_classes: [ActiveSupport::HashWithIndifferentAccess])
+      v = YAML.safe_load(v, permitted_classes: [Symbol, ActiveSupport::HashWithIndifferentAccess])
       v = force_utf8_strings(v)
     end
     v = v.to_sym if available_settings[name]['format'] == 'symbol' && !v.blank?
index 54394ab5794472738c55f4d4d5a504d938addb63..a5a1b2aa3102eda6ba381b7d555534e0b5800cc5 100644 (file)
@@ -196,6 +196,13 @@ class Redmine::PluginTest < ActiveSupport::TestCase
     end
   end
 
+  def test_default_settings
+    @klass.register(:foo_plugin) {settings :default => {'key1' => 'abc', :key2 => 123}}
+    h = Setting.plugin_foo_plugin
+    assert_equal 'abc', h['key1']
+    assert_equal 123, h[:key2]
+  end
+
   def test_settings_warns_about_possible_partial_collision
     @klass.register(:foo_plugin) {settings :partial => 'foo/settings'}
     Rails.logger.expects(:warn)