Commit 05886c63 authored by ddavison's avatar ddavison Committed by Sanad Liaquat

Allow QA to run in remote grid environments

Signed-off-by: default avatarddavison <ddavison@gitlab.com>
parent 9370ba6f
...@@ -40,22 +40,23 @@ module QA ...@@ -40,22 +40,23 @@ module QA
return if Capybara.drivers.include?(:chrome) return if Capybara.drivers.include?(:chrome)
Capybara.register_driver :chrome do |app| Capybara.register_driver QA::Runtime::Env.browser do |app|
capabilities = Selenium::WebDriver::Remote::Capabilities.chrome( capabilities = Selenium::WebDriver::Remote::Capabilities.send(QA::Runtime::Env.browser,
# This enables access to logs with `page.driver.manage.get_log(:browser)` # This enables access to logs with `page.driver.manage.get_log(:browser)`
loggingPrefs: { loggingPrefs: {
browser: "ALL", browser: "ALL",
client: "ALL", client: "ALL",
driver: "ALL", driver: "ALL",
server: "ALL" server: "ALL"
} })
)
if QA::Runtime::Env.accept_insecure_certs? if QA::Runtime::Env.accept_insecure_certs?
capabilities['acceptInsecureCerts'] = true capabilities['acceptInsecureCerts'] = true
end end
options = Selenium::WebDriver::Chrome::Options.new # QA::Runtime::Env.browser.capitalize will work for every driver type except PhantomJS.
# We will have no use to use PhantomJS so this shouldn't be a problem.
options = Selenium::WebDriver.const_get(QA::Runtime::Env.browser.capitalize)::Options.new
options.add_argument("window-size=1240,1680") options.add_argument("window-size=1240,1680")
# Chrome won't work properly in a Docker container in sandbox mode # Chrome won't work properly in a Docker container in sandbox mode
...@@ -80,12 +81,18 @@ module QA ...@@ -80,12 +81,18 @@ module QA
# Disable /dev/shm use in CI. See https://gitlab.com/gitlab-org/gitlab-ee/issues/4252 # Disable /dev/shm use in CI. See https://gitlab.com/gitlab-org/gitlab-ee/issues/4252
options.add_argument("disable-dev-shm-usage") if QA::Runtime::Env.running_in_ci? options.add_argument("disable-dev-shm-usage") if QA::Runtime::Env.running_in_ci?
Capybara::Selenium::Driver.new( selenium_options = {
app, browser: QA::Runtime::Env.browser,
browser: :chrome,
clear_local_storage: true, clear_local_storage: true,
desired_capabilities: capabilities, desired_capabilities: capabilities,
options: options options: options
}
selenium_options[:url] = QA::Runtime::Env.remote_grid if QA::Runtime::Env.remote_grid
Capybara::Selenium::Driver.new(
app,
selenium_options
) )
end end
...@@ -93,7 +100,7 @@ module QA ...@@ -93,7 +100,7 @@ module QA
Capybara::Screenshot.prune_strategy = :keep_last_run Capybara::Screenshot.prune_strategy = :keep_last_run
# From https://github.com/mattheworiordan/capybara-screenshot/issues/84#issuecomment-41219326 # From https://github.com/mattheworiordan/capybara-screenshot/issues/84#issuecomment-41219326
Capybara::Screenshot.register_driver(:chrome) do |driver, path| Capybara::Screenshot.register_driver(QA::Runtime::Env.browser) do |driver, path|
driver.browser.save_screenshot(path) driver.browser.save_screenshot(path)
end end
...@@ -102,8 +109,8 @@ module QA ...@@ -102,8 +109,8 @@ module QA
end end
Capybara.configure do |config| Capybara.configure do |config|
config.default_driver = :chrome config.default_driver = QA::Runtime::Env.browser
config.javascript_driver = :chrome config.javascript_driver = QA::Runtime::Env.browser
config.default_max_wait_time = 10 config.default_max_wait_time = 10
# https://github.com/mattheworiordan/capybara-screenshot/issues/164 # https://github.com/mattheworiordan/capybara-screenshot/issues/164
config.save_path = ::File.expand_path('../../tmp', __dir__) config.save_path = ::File.expand_path('../../tmp', __dir__)
......
...@@ -56,6 +56,31 @@ module QA ...@@ -56,6 +56,31 @@ module QA
@personal_access_token ||= ENV['PERSONAL_ACCESS_TOKEN'] @personal_access_token ||= ENV['PERSONAL_ACCESS_TOKEN']
end end
def remote_grid
# if username specified, password/auth token is required
# can be
# - "http://user:pass@somehost.com/wd/hub"
# - "https://user:pass@somehost.com:443/wd/hub"
# - "http://localhost:4444/wd/hub"
"#{remote_grid_protocol}://#{"#{remote_grid_username}:#{remote_grid_access_key}@" if remote_grid_username}#{ENV['QA_REMOTE_GRID']}/wd/hub" if ENV['QA_REMOTE_GRID']
end
def remote_grid_username
ENV['QA_REMOTE_GRID_USERNAME']
end
def remote_grid_access_key
ENV['QA_REMOTE_GRID_ACCESS_KEY']
end
def remote_grid_protocol
ENV['QA_REMOTE_GRID_PROTOCOL'] || 'http'
end
def browser
ENV['QA_BROWSER'] || :chrome
end
def user_username def user_username
ENV['GITLAB_USERNAME'] ENV['GITLAB_USERNAME']
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