X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/58692c916bb6dfe2997838ca4147109d9410c86a..a1592e2c6d6e9768a1918f3c59b74d6d19033a55:/apps/workbench/test/integration_helper.rb diff --git a/apps/workbench/test/integration_helper.rb b/apps/workbench/test/integration_helper.rb index 1cda1275e1..74072caaad 100644 --- a/apps/workbench/test/integration_helper.rb +++ b/apps/workbench/test/integration_helper.rb @@ -4,19 +4,43 @@ require 'capybara/poltergeist' require 'uri' require 'yaml' -POLTERGEIST_OPTS = { - window_size: [1200, 800], - phantomjs_options: ['--ignore-ssl-errors=true'], - inspector: true, -} +def available_port for_what + Addrinfo.tcp("0.0.0.0", 0).listen do |srv| + port = srv.connect_address.ip_port + STDERR.puts "Using port #{port} for #{for_what}" + return port + end +end + +def selenium_opts + { + port: available_port('selenium'), + } +end + +def poltergeist_opts + { + phantomjs_options: ['--ignore-ssl-errors=true'], + port: available_port('poltergeist'), + window_size: [1200, 800], + } +end Capybara.register_driver :poltergeist do |app| - Capybara::Poltergeist::Driver.new app, POLTERGEIST_OPTS + Capybara::Poltergeist::Driver.new app, poltergeist_opts +end + +Capybara.register_driver :poltergeist_debug do |app| + Capybara::Poltergeist::Driver.new app, poltergeist_opts.merge(inspector: true) end Capybara.register_driver :poltergeist_without_file_api do |app| js = File.expand_path '../support/remove_file_api.js', __FILE__ - Capybara::Poltergeist::Driver.new app, POLTERGEIST_OPTS.merge(extensions: [js]) + Capybara::Poltergeist::Driver.new app, poltergeist_opts.merge(extensions: [js]) +end + +Capybara.register_driver :selenium do |app| + Capybara::Selenium::Driver.new app, selenium_opts end Capybara.register_driver :selenium_with_download do |app| @@ -28,13 +52,13 @@ Capybara.register_driver :selenium_with_download do |app| profile['browser.download.manager.showWhenStarting'] = false profile['browser.helperApps.alwaysAsk.force'] = false profile['browser.helperApps.neverAsk.saveToDisk'] = 'text/plain,application/octet-stream' - Capybara::Selenium::Driver.new app, profile: profile + Capybara::Selenium::Driver.new app, selenium_opts.merge(profile: profile) end module WaitForAjax - Capybara.default_wait_time = 5 + Capybara.default_max_wait_time = 5 def wait_for_ajax - Timeout.timeout(Capybara.default_wait_time) do + Timeout.timeout(Capybara.default_max_wait_time) do loop until finished_all_ajax_requests? end end @@ -62,8 +86,10 @@ end module HeadlessHelper class HeadlessSingleton + @display = ENV['ARVADOS_TEST_HEADLESS_DISPLAY'] || rand(400)+100 + STDERR.puts "Using display :#{@display} for headless tests" def self.get - @headless ||= Headless.new reuse: false + @headless ||= Headless.new reuse: false, display: @display end end