-
Notifications
You must be signed in to change notification settings - Fork 74
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Remove redundant configs for Capybara (#3947)
* Remove redundant configs for Capybara * Some improvements from #3911 Remove session creation Revert to :prefer_exact capybara matching Remove default capybara values * Fix test with pagination * Bring back ensure_javascript * Refactoring * Restore @Firefox driver for capybara
- Loading branch information
Showing
10 changed files
with
57 additions
and
123 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,117 +1,59 @@ | ||
# frozen_string_literal: true | ||
|
||
require 'selenium/webdriver' | ||
require 'capybara/minitest' | ||
include Capybara::Minitest::Assertions | ||
|
||
# in case firefox is needed! | ||
#Capybara.register_driver :selenium do |app| | ||
# Capybara::Selenium::Driver.new(app, :browser => :firefox) | ||
#end | ||
# When width < 1200px, vertical navigation overlaps the page's main content, | ||
# and that will make some cucumbers fail | ||
WINDOW_SIZE_ARG = '--window-size=1280,2048' | ||
|
||
DEFAULT_JS_DRIVER = :headless_chrome | ||
# in case firefox is needed! | ||
# DEFAULT_JS_DRIVER = :headless_firefox | ||
|
||
Capybara.default_driver = :rack_test | ||
Capybara.javascript_driver = DEFAULT_JS_DRIVER | ||
Capybara.default_selector = :css | ||
Capybara.disable_animation = true | ||
|
||
# Capybara 3 changes the default server to Puma. It can be reverted to the previous default of WEBRick by specifying: | ||
Capybara.server = :webrick | ||
|
||
# see http://www.elabs.se/blog/60-introducing-capybara-2-1 | ||
Capybara.configure do |config| | ||
config.default_driver = :rack_test | ||
config.javascript_driver = DEFAULT_JS_DRIVER | ||
config.raise_server_errors = true | ||
config.match = :prefer_exact | ||
config.javascript_driver = :headless_chrome | ||
config.always_include_port = true | ||
config.default_max_wait_time = 10 | ||
end | ||
|
||
# Needed because cucumber-rails requires capybara/cucumber | ||
# https://github.com/cucumber/cucumber-rails/blob/7b47bf1dda3368247bf2d45bcb17a224e80ec6fd/lib/cucumber/rails/capybara.rb#L3 | ||
# https://github.com/teamcapybara/capybara/blob/2.18.0/lib/capybara/cucumber.rb#L17-L19 | ||
Before '@javascript' do | ||
Capybara.current_driver = DEFAULT_JS_DRIVER | ||
end | ||
|
||
Before '@chrome' do | ||
Capybara.current_driver = :chrome | ||
end | ||
|
||
Before '@firefox' do | ||
Capybara.current_driver = :firefox | ||
end | ||
|
||
Around '@security' do |scenario, block| | ||
with_forgery_protection(&block) | ||
end | ||
|
||
# monkeypatch to fix | ||
# not opened for reading (IOError) | ||
# /cucumber-1.3.20/lib/cucumber/formatter/interceptor.rb:33:in `each' | ||
# /cucumber-1.3.20/lib/cucumber/formatter/interceptor.rb:33:in `collect' | ||
# /cucumber-1.3.20/lib/cucumber/formatter/interceptor.rb:33:in `method_missing' | ||
require 'cucumber/formatter/interceptor' | ||
class Cucumber::Formatter::Interceptor::Pipe | ||
def is_a?(klass) | ||
super || klass == IO | ||
end | ||
end | ||
|
||
Capybara.register_driver :firefox do |app| | ||
Capybara::Selenium::Driver.new(app, browser: :firefox) | ||
end | ||
|
||
Capybara.register_driver :headless_firefox do |app| | ||
options = Selenium::WebDriver::Firefox::Options.new | ||
|
||
options.add_argument('-headless') | ||
options.add_argument('--window-size=1280,2048') | ||
|
||
driver = Capybara::Selenium::Driver.new(app, browser: :firefox, options: options) | ||
|
||
driver | ||
end | ||
|
||
Capybara.register_driver :firefox do |app| | ||
options = Selenium::WebDriver::Firefox::Options.new | ||
|
||
options.add_argument('--window-size=1280,2048') | ||
|
||
driver = Capybara::Selenium::Driver.new(app, browser: :firefox, options: options) | ||
|
||
driver | ||
config.server = :webrick # default is `:default` (which uses puma) | ||
end | ||
|
||
Capybara.register_driver :chrome do |app| | ||
options = Selenium::WebDriver::Chrome::Options.new | ||
options.add_argument('--window-size=1280,2048') | ||
options = Selenium::WebDriver::Options.chrome | ||
options.add_argument(WINDOW_SIZE_ARG) | ||
options.add_argument('--disable-search-engine-choice-screen') | ||
Capybara::Selenium::Driver.new(app, browser: :chrome, options: options) | ||
end | ||
|
||
Capybara.register_driver :headless_chrome do |app| | ||
options = Selenium::WebDriver::Options.chrome( | ||
logging_prefs: { performance: 'ALL', browser: 'ALL' }, | ||
perf_logging_prefs: { enableNetwork: true } | ||
) | ||
|
||
options = Selenium::WebDriver::Options.chrome | ||
options.add_argument(WINDOW_SIZE_ARG) | ||
options.add_argument('--disable-search-engine-choice-screen') | ||
options.add_argument('--headless=new') | ||
options.add_argument('--no-sandbox') | ||
options.add_argument('--disable-popup-blocking') | ||
options.add_argument('--window-size=1280,2048') | ||
options.add_argument('--host-resolver-rules=MAP * ~NOTFOUND , EXCLUDE *localhost*') | ||
options.add_argument('--disable-search-engine-choice-screen') | ||
options.add_argument('--disable-gpu') | ||
|
||
options.logging_prefs = { performance: 'ALL', browser: 'ALL' } | ||
options.add_option(:perf_logging_prefs, enableNetwork: true) | ||
|
||
options.add_preference(:browser, set_download_behavior: { behavior: 'allow' }) | ||
|
||
timeout = 120 # default 60 | ||
client = Selenium::WebDriver::Remote::Http::Default.new(open_timeout: timeout, read_timeout: timeout) | ||
Capybara::Selenium::Driver.new(app, browser: :chrome, options: options, timeout: 120) | ||
end | ||
|
||
# NOTE: depending on the scenario you will need to add both | ||
# @firefox/@headless_firefox AND @javascript tags | ||
Before '@firefox', '@headless_firefox' do | ||
Capybara.javascript_driver = :headless_firefox | ||
end | ||
|
||
Capybara.register_driver :firefox do |app| | ||
options = Selenium::WebDriver::Options.firefox | ||
options.add_argument(WINDOW_SIZE_ARG) | ||
Capybara::Selenium::Driver.new(app, browser: :firefox, options: options) | ||
end | ||
|
||
Capybara::Selenium::Driver.new(app, browser: :chrome, options: options, http_client: client) | ||
Capybara.register_driver :headless_firefox do |app| | ||
options = Selenium::WebDriver::Options.firefox | ||
options.add_argument(WINDOW_SIZE_ARG) | ||
options.add_argument('-headless') | ||
Capybara::Selenium::Driver.new(app, browser: :firefox, options: options) | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters