]> source.dussan.org Git - redmine.git/commitdiff
Merged r23269 from trunk to 6.0-stable (#41749).
authorGo MAEDA <maeda@farend.jp>
Thu, 14 Nov 2024 23:47:15 +0000 (23:47 +0000)
committerGo MAEDA <maeda@farend.jp>
Thu, 14 Nov 2024 23:47:15 +0000 (23:47 +0000)
git-svn-id: https://svn.redmine.org/redmine/branches/6.0-stable@23273 e93f8b46-1217-0410-a6f0-8f06a7374b81

Gemfile

diff --git a/Gemfile b/Gemfile
index e5890b0829b8f59f8afd001a32541454e02ba1ed..d0d6f37bf9cf9fe943e019f2a3381ab9d492f888 100644 (file)
--- a/Gemfile
+++ b/Gemfile
@@ -52,16 +52,23 @@ end
 
 # Include database gems for the adapters found in the database
 # configuration file
-require 'erb'
-require 'yaml'
 database_file = File.join(File.dirname(__FILE__), "config/database.yml")
 if File.exist?(database_file)
-  yaml_config = ERB.new(IO.read(database_file)).result
-  database_config = YAML.respond_to?(:unsafe_load) ? YAML.unsafe_load(yaml_config) : YAML.load(yaml_config)
-  adapters = database_config.values.filter_map {|c| c['adapter']}.uniq
+  database_config = File.read(database_file)
+
+  # Requiring libraries in a Gemfile may cause Bundler warnings or
+  # unexpected behavior, especially if multiple gem versions are available.
+  # So, process database.yml through ERB only if it contains ERB syntax
+  # in the adapter setting. See https://www.redmine.org/issues/41749.
+  if database_config.match?(/^ *adapter: *<%=/)
+    require 'erb'
+    database_config = ERB.new(database_config).result
+  end
+
+  adapters = database_config.scan(/^ *adapter: *(.*)/).flatten.uniq
   if adapters.any?
     adapters.each do |adapter|
-      case adapter
+      case adapter.strip
       when 'mysql2'
         gem 'mysql2', '~> 0.5.0'
         gem "with_advisory_lock"