X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/e348aa5023875dbbbd40a0dc2ee32ea6aee53edd..660e8d8345bfe7f34dfc8db655eff6a0af8bd47f:/apps/workbench/test/integration_helper.rb?ds=inline diff --git a/apps/workbench/test/integration_helper.rb b/apps/workbench/test/integration_helper.rb index b3d9f01444..86162834c7 100644 --- a/apps/workbench/test/integration_helper.rb +++ b/apps/workbench/test/integration_helper.rb @@ -5,6 +5,7 @@ require 'uri' require 'yaml' $ARV_API_SERVER_DIR = File.expand_path('../../../../services/api', __FILE__) +SERVER_PID_PATH = 'tmp/pids/server.pid' class ActionDispatch::IntegrationTest # Make the Capybara DSL available in all integration tests @@ -32,12 +33,14 @@ class ActionDispatch::IntegrationTest end class IntegrationTestRunner < MiniTest::Unit - # Launch the API server in test mode, with appropriate environment. - @@APIENV = {'RAILS_ENV' => 'test'} - ['GEM_HOME', 'GEM_PATH', 'PATH'].each { |key| @@APIENV[key] = ENV[key] } + # Make a hash that unsets Bundle's environment variables. + # We'll use this environment when we launch Bundle commands in the API + # server. Otherwise, those commands will try to use Workbench's gems, etc. + @@APIENV = ENV.map { |(key, val)| (key =~ /^BUNDLE_/) ? [key, nil] : nil }. + compact.to_h def _system(*cmd) - if not system(@@APIENV, *cmd, {unsetenv_others: true}) + if not system(@@APIENV, *cmd) raise RuntimeError, "#{cmd[0]} returned exit code #{$?.exitstatus}" end end @@ -48,7 +51,20 @@ class IntegrationTestRunner < MiniTest::Unit _system('bundle', 'exec', 'rake', 'db:test:load') _system('bundle', 'exec', 'rake', 'db:fixtures:load') _system('bundle', 'exec', 'rails', 'server', '-d') - `cat tmp/pids/server.pid`.to_i + timeout = Time.now.tv_sec + 10 + begin + sleep 0.2 + begin + server_pid = IO.read(SERVER_PID_PATH).to_i + good_pid = (server_pid > 0) and (Process.kill(0, pid) rescue false) + rescue Errno::ENOENT + good_pid = false + end + end while (not good_pid) and (Time.now.tv_sec < timeout) + if not good_pid + raise RuntimeError, "could not find API server Rails pid" + end + server_pid end begin super(args)