X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/87501e7bf8d4f2303cc25a00e93476784911438b..49b58cc43218106f1633c389598894d59447a26b:/apps/workbench/test/integration_helper.rb diff --git a/apps/workbench/test/integration_helper.rb b/apps/workbench/test/integration_helper.rb index 8e317ba4e2..febcfcfec0 100644 --- a/apps/workbench/test/integration_helper.rb +++ b/apps/workbench/test/integration_helper.rb @@ -4,20 +4,26 @@ require 'capybara/poltergeist' require 'uri' require 'yaml' -$ARV_API_SERVER_DIR = File.expand_path('../../../../services/api', __FILE__) -SERVER_PID_PATH = 'tmp/pids/server.pid' +module WaitForAjax + Capybara.default_wait_time = 5 + def wait_for_ajax + Timeout.timeout(Capybara.default_wait_time) do + loop until finished_all_ajax_requests? + end + end + + def finished_all_ajax_requests? + page.evaluate_script('jQuery.active').zero? + end +end class ActionDispatch::IntegrationTest # Make the Capybara DSL available in all integration tests include Capybara::DSL + include ApiFixtureLoader + include WaitForAjax - def self.api_fixture(name) - # Returns the data structure from the named API server test fixture. - path = File.join($ARV_API_SERVER_DIR, 'test', 'fixtures', "#{name}.yml") - YAML.load(IO.read(path)) - end - - @@API_AUTHS = api_fixture('api_client_authorizations') + @@API_AUTHS = self.api_fixture('api_client_authorizations') def page_with_token(token, path='/') # Generate a page path with an embedded API token. @@ -30,39 +36,39 @@ class ActionDispatch::IntegrationTest q_string = URI.encode_www_form('api_token' => api_token) "#{path}#{sep}#{q_string}" end -end -class IntegrationTestRunner < MiniTest::Unit - # 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 + # Find a page element, but return false instead of raising an + # exception if not found. Use this with assertions to explain that + # the error signifies a failed test rather than an unexpected error + # during a testing procedure. + def find? *args + begin + find *args + rescue Capybara::ElementNotFound + false + end + end - def _system(*cmd) - if not system(@@APIENV, *cmd) - raise RuntimeError, "#{cmd[0]} returned exit code #{$?.exitstatus}" + @@screenshot_count = 1 + def screenshot + image_file = "./tmp/workbench-fail-#{@@screenshot_count}.png" + begin + page.save_screenshot image_file + rescue Capybara::NotSupportedByDriverError + # C'est la vie. + else + puts "Saved #{image_file}" + @@screenshot_count += 1 end end - def _run(args=[]) - Capybara.javascript_driver = :poltergeist - server_pid = Dir.chdir($ARV_API_SERVER_DIR) do |apidir| - _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) - sleep 0.2 - end - IO.read(SERVER_PID_PATH).to_i + teardown do + if not passed? + screenshot end - begin - super(args) - ensure - Process.kill('TERM', server_pid) + if Capybara.current_driver == :selenium + page.execute_script("window.localStorage.clear()") end + Capybara.reset_sessions! end end - -MiniTest::Unit.runner = IntegrationTestRunner.new