X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/40f9e6c22b1a4f7cbe473bae2e4336ef23feb41a..26446197bb00d7f899673b7f9434e6bd622b8904:/apps/workbench/test/integration_helper.rb?ds=sidebyside diff --git a/apps/workbench/test/integration_helper.rb b/apps/workbench/test/integration_helper.rb index 3cd485797e..86162834c7 100644 --- a/apps/workbench/test/integration_helper.rb +++ b/apps/workbench/test/integration_helper.rb @@ -33,9 +33,10 @@ class ActionDispatch::IntegrationTest end class IntegrationTestRunner < MiniTest::Unit - # Don't try to re-use the current Bundle environment when we launch the - # API server. - @@APIENV = ENV.map { |item| (item[0] =~ /^BUNDLE_/) ? [item[0], nil] : nil }. + # 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) @@ -50,11 +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') - timeout = Time.now.tv_sec + 5 - while (not File.exists? SERVER_PID_PATH) and (Time.now.tv_sec < timeout) + 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 - IO.read(SERVER_PID_PATH).to_i + server_pid end begin super(args)