Commit adf23bdf authored by Lin Jen-Shin's avatar Lin Jen-Shin

Merge branch 'toon-gitaly-bundler-fix' into 'master'

test: Set Gitaly's bundle path as absolute path

See merge request gitlab-org/gitlab!72328
parents cb5df34a 456843de
...@@ -13,8 +13,6 @@ class GitalyTestBuild ...@@ -13,8 +13,6 @@ class GitalyTestBuild
include GitalySetup include GitalySetup
def run def run
set_bundler_config
# If we have the binaries from the cache, we can skip building them again # If we have the binaries from the cache, we can skip building them again
if File.exist?(tmp_tests_gitaly_bin_dir) if File.exist?(tmp_tests_gitaly_bin_dir)
GitalySetup::LOGGER.debug "Gitaly binary already built. Skip building...\n" GitalySetup::LOGGER.debug "Gitaly binary already built. Skip building...\n"
......
...@@ -9,7 +9,6 @@ class GitalyTestSpawn ...@@ -9,7 +9,6 @@ class GitalyTestSpawn
include GitalySetup include GitalySetup
def run def run
set_bundler_config
install_gitaly_gems if ENV['CI'] install_gitaly_gems if ENV['CI']
check_gitaly_config! check_gitaly_config!
......
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
require 'securerandom' require 'securerandom'
require 'socket' require 'socket'
require 'logger' require 'logger'
require 'bundler'
module GitalySetup module GitalySetup
LOGGER = begin LOGGER = begin
...@@ -46,13 +47,26 @@ module GitalySetup ...@@ -46,13 +47,26 @@ module GitalySetup
File.join(tmp_tests_gitlab_shell_dir, '.gitlab_shell_secret') File.join(tmp_tests_gitlab_shell_dir, '.gitlab_shell_secret')
end end
# Return the path of the vendored gems in <gdk>/gitaly, if exists
def gdk_gitaly_ruby_gem_path
gitaly_ruby_path = File.expand_path('../../../../gitaly/ruby/', __dir__)
bundle_config_path = File.join(gitaly_ruby_path, '.bundle')
bundle_path = Bundler::Settings.new(bundle_config_path).path
return if bundle_path.use_system_gems?
File.expand_path(bundle_path.explicit_path, gitaly_ruby_path)
end
def env def env
{ {
'HOME' => File.expand_path('tmp/tests'), 'HOME' => File.expand_path('tmp/tests'),
'GEM_PATH' => Gem.path.join(':'), 'GEM_PATH' => Gem.path.join(':'),
'BUNDLE_APP_CONFIG' => File.join(gemfile_dir, '.bundle'), 'BUNDLE_IGNORE_CONFIG' => '1',
'BUNDLE_INSTALL_FLAGS' => nil,
'BUNDLE_GEMFILE' => gemfile, 'BUNDLE_GEMFILE' => gemfile,
'BUNDLE_PATH' => bundle_path,
'BUNDLE_JOBS' => '4',
'BUNDLE_RETRY' => '3',
'RUBYOPT' => nil, 'RUBYOPT' => nil,
# Git hooks can't run during tests as the internal API is not running. # Git hooks can't run during tests as the internal API is not running.
...@@ -61,17 +75,13 @@ module GitalySetup ...@@ -61,17 +75,13 @@ module GitalySetup
} }
end end
# rubocop:disable GitlabSecurity/SystemCommandInjection def bundle_path
def set_bundler_config
system('bundle config set --local jobs 4', chdir: gemfile_dir)
system('bundle config set --local retry 3', chdir: gemfile_dir)
if ENV['CI'] if ENV['CI']
bundle_path = File.expand_path('../../../vendor/gitaly-ruby', __dir__) File.expand_path('../../../vendor/gitaly-ruby', __dir__)
system('bundle', 'config', 'set', '--local', 'path', bundle_path, chdir: gemfile_dir) else
gdk_gitaly_ruby_gem_path || File.expand_path(Bundler.configured_bundle_path.base_path)
end end
end end
# rubocop:enable GitlabSecurity/SystemCommandInjection
def config_path(service) def config_path(service)
case service case service
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment