Commit 77f41fff authored by Albert Salim's avatar Albert Salim Committed by Rémy Coutable

Fix Bundle config for gitaly bundle

`BUNDLE_FLAGS=--no-deployment` was not picked up
during bundle install in `tmp/tests/gitaly/ruby`.

As a result, `tmp/tests/gitaly/ruby` had `BUNDLE_DEPLOYMENT: "true"`.

This leads to default bundle path being `vendor/bundle`, instead of
using `GEM_HOME`
parent 2e647463
...@@ -17,24 +17,29 @@ Usage: rake "gitlab:gitaly:install[/installation/dir,/storage/path]") ...@@ -17,24 +17,29 @@ Usage: rake "gitlab:gitaly:install[/installation/dir,/storage/path]")
checkout_or_clone_version(version: version, repo: args.repo, target_dir: args.dir, clone_opts: %w[--depth 1]) checkout_or_clone_version(version: version, repo: args.repo, target_dir: args.dir, clone_opts: %w[--depth 1])
command = [] storage_paths = { 'default' => args.storage_path }
_, status = Gitlab::Popen.popen(%w[which gmake]) Gitlab::SetupHelper::Gitaly.create_configuration(args.dir, storage_paths)
command << (status == 0 ? 'gmake' : 'make')
# In CI we run scripts/gitaly-test-build
next if ENV['CI'].present?
Dir.chdir(args.dir) do
Bundler.with_original_env do
env = { "RUBYOPT" => nil, "BUNDLE_GEMFILE" => nil }
if Rails.env.test? if Rails.env.test?
command.push( env["GEM_HOME"] = Bundler.bundle_path.to_s
'BUNDLE_FLAGS=--no-deployment', env["BUNDLE_DEPLOYMENT"] = 'false'
"GEM_HOME=#{Bundler.bundle_path}")
end end
storage_paths = { 'default' => args.storage_path } Gitlab::Popen.popen([make_cmd], nil, env)
Gitlab::SetupHelper::Gitaly.create_configuration(args.dir, storage_paths)
Dir.chdir(args.dir) do
# In CI we run scripts/gitaly-test-build instead of this command
unless ENV['CI'].present?
Bundler.with_original_env { Gitlab::Popen.popen(command, nil, { "RUBYOPT" => nil, "BUNDLE_GEMFILE" => nil }) }
end end
end end
end end
def make_cmd
_, status = Gitlab::Popen.popen(%w[which gmake])
status == 0 ? 'gmake' : 'make'
end
end end
end end
...@@ -41,6 +41,7 @@ RSpec.describe 'gitlab:gitaly namespace rake task' do ...@@ -41,6 +41,7 @@ RSpec.describe 'gitlab:gitaly namespace rake task' do
describe 'checkout or clone' do describe 'checkout or clone' do
before do before do
stub_env('CI', false)
expect(Dir).to receive(:chdir).with(clone_path) expect(Dir).to receive(:chdir).with(clone_path)
end end
...@@ -86,18 +87,14 @@ RSpec.describe 'gitlab:gitaly namespace rake task' do ...@@ -86,18 +87,14 @@ RSpec.describe 'gitlab:gitaly namespace rake task' do
end end
context 'when Rails.env is test' do context 'when Rails.env is test' do
let(:command) do let(:command) { %w[make] }
%W[make
BUNDLE_FLAGS=--no-deployment
GEM_HOME=#{Bundler.bundle_path}]
end
before do before do
stub_rails_env('test') stub_rails_env('test')
end end
it 'calls make in the gitaly directory with --no-deployment flag for bundle' do it 'calls make in the gitaly directory with BUNDLE_DEPLOYMENT and GEM_HOME variables' do
expect(Gitlab::Popen).to receive(:popen).with(command, nil, { "BUNDLE_GEMFILE" => nil, "RUBYOPT" => nil }).and_return(true) expect(Gitlab::Popen).to receive(:popen).with(command, nil, { "BUNDLE_GEMFILE" => nil, "RUBYOPT" => nil, "BUNDLE_DEPLOYMENT" => 'false', "GEM_HOME" => Bundler.bundle_path.to_s }).and_return(true)
subject subject
end end
......
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