Replace selenium-webdriver with playwright (#34867)
This commit is contained in:
parent
b8cc9b3290
commit
629bb74451
6 changed files with 45 additions and 43 deletions
|
@ -9,29 +9,36 @@ end
|
|||
RSpec.configure do |config|
|
||||
config.include BrowserErrorsHelpers, :js, type: :system
|
||||
|
||||
config.before(:each, :js, type: :system) do
|
||||
config.before(:each, :js, type: :system) do |example|
|
||||
@ignored_js_errors_for_spec = []
|
||||
|
||||
example.metadata[:js_console_messages] ||= []
|
||||
Capybara.current_session.driver.with_playwright_page do |page|
|
||||
page.on('console', lambda { |msg|
|
||||
example.metadata[:js_console_messages] << { type: msg.type, text: msg.text, location: msg.location }
|
||||
})
|
||||
end
|
||||
end
|
||||
|
||||
config.after(:each, :js, type: :system) do
|
||||
config.after(:each, :js, type: :system) do |example|
|
||||
# Classes of intermittent ignorable errors
|
||||
ignored_errors = [
|
||||
/Error while trying to use the following icon from the Manifest/, # https://github.com/mastodon/mastodon/pull/30793
|
||||
/Manifest: Line: 1, column: 1, Syntax error/, # Similar parsing/interruption issue as above
|
||||
].concat(@ignored_js_errors_for_spec)
|
||||
|
||||
errors = page.driver.browser.logs.get(:browser).reject do |error|
|
||||
ignored_errors.any? { |pattern| pattern.match(error.message) }
|
||||
errors = example.metadata[:js_console_messages].reject do |msg|
|
||||
ignored_errors.any? { |pattern| pattern.match(msg[:text]) }
|
||||
end
|
||||
|
||||
if errors.present?
|
||||
aggregate_failures 'browser errrors' do
|
||||
errors.each do |error|
|
||||
expect(error.level).to_not eq('SEVERE'), error.message
|
||||
next unless error.level == 'WARNING'
|
||||
expect(error[:type]).to_not eq('error'), error[:text]
|
||||
next unless error[:type] == 'warning'
|
||||
|
||||
warn 'WARN: browser warning'
|
||||
warn error.message
|
||||
warn error[:text]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,36 +4,16 @@ Capybara.server_host = 'localhost'
|
|||
Capybara.server_port = 3000
|
||||
Capybara.app_host = "http://#{Capybara.server_host}:#{Capybara.server_port}"
|
||||
|
||||
require 'selenium/webdriver'
|
||||
|
||||
def common_chrome_options
|
||||
options = Selenium::WebDriver::Chrome::Options.new
|
||||
options.add_argument '--window-size=1680,1050'
|
||||
options.add_argument '--disable-search-engine-choice-screen'
|
||||
options
|
||||
Capybara.register_driver(:playwright) do |app|
|
||||
Capybara::Playwright::Driver.new(app)
|
||||
end
|
||||
Capybara.javascript_driver = :playwright
|
||||
|
||||
Capybara.register_driver :chrome do |app|
|
||||
Capybara::Selenium::Driver.new(app, browser: :chrome, options: common_chrome_options)
|
||||
if ENV['CI'].present?
|
||||
# Reduce intermittent failures from slow CI runner environment
|
||||
Capybara.default_max_wait_time = 2**3
|
||||
end
|
||||
|
||||
Capybara.register_driver :headless_chrome do |app|
|
||||
options = common_chrome_options
|
||||
options.add_argument '--headless=new'
|
||||
|
||||
Capybara::Selenium::Driver.new(
|
||||
app,
|
||||
browser: :chrome,
|
||||
options: options
|
||||
)
|
||||
end
|
||||
|
||||
Capybara.javascript_driver = :headless_chrome
|
||||
|
||||
# Some of the flaky tests seem to be caused by github runners being too slow for the
|
||||
# default timeout of 2 seconds
|
||||
Capybara.default_max_wait_time = 8
|
||||
|
||||
RSpec.configure do |config|
|
||||
config.before(:each, type: :system) do
|
||||
driven_by :rack_test
|
||||
|
|
|
@ -26,7 +26,7 @@ RSpec.describe 'Log out' do
|
|||
describe 'Logging out from the JS app', :js, :streaming do
|
||||
it 'logs the user out' do
|
||||
# The frontend tries to load announcements after a short delay, but the session might be expired by then, and the browser will output an error.
|
||||
ignore_js_error(/Failed to load resource: the server responded with a status of 422/)
|
||||
ignore_js_error(/Failed to load resource: the server responded with a status/)
|
||||
|
||||
visit root_path
|
||||
expect(page)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue