summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2024-11-14 09:11:04 +0000
committerGo MAEDA <maeda@farend.jp>2024-11-14 09:11:04 +0000
commit56796759c0d92d86e1e4bee88d5aee0cf509f262 (patch)
tree172c2e3219c036ade82e4b06b4ead5e5fd62b0ad
parentf812b2920132556e8d7dcffed2481bfbb91f6f97 (diff)
downloadredmine-56796759c0d92d86e1e4bee88d5aee0cf509f262.tar.gz
redmine-56796759c0d92d86e1e4bee88d5aee0cf509f262.zip
Fix warning during startup: "Unresolved or ambiguous specs during Gem::Specification.reset" (#41749).
Patch by Katsuya HIDAKA (user:hidakatsuya). git-svn-id: https://svn.redmine.org/redmine/trunk@23269 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--Gemfile19
1 files changed, 13 insertions, 6 deletions
diff --git a/Gemfile b/Gemfile
index cd3e1d0d3..28065e3d0 100644
--- 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"