Commit fcd0c1fb authored by Sanad Liaquat's avatar Sanad Liaquat

Stablize select kind using retry_on_exception

Introduces retry_on_exception and renames with_retry to retry_unti so
its purpose is clear in presense of retry_on_exception.
parent c7461be9
......@@ -33,7 +33,7 @@ module QA
false
end
def with_retry(max_attempts: 3, reload: false)
def retry_until(max_attempts: 3, reload: false)
attempts = 0
while attempts < max_attempts
......@@ -48,6 +48,21 @@ module QA
false
end
def retry_on_exception(max_attempts: 3, reload: false, sleep_interval: 0.0)
attempts = 0
begin
yield
rescue StandardError
sleep sleep_interval
refresh if reload
attempts += 1
retry if attempts < max_attempts
raise
end
end
def scroll_to(selector, text: nil)
page.execute_script <<~JS
var elements = Array.from(document.querySelectorAll('#{selector}'));
......
......@@ -45,6 +45,7 @@ module QA
private
def select_kind(kind)
retry_on_exception(sleep_interval: 1.0) do
within_element(:new_project_or_subgroup_dropdown) do
# May need to click again because it is possible to click the button quicker than the JS is bound
wait(reload: false) do
......@@ -59,4 +60,5 @@ module QA
end
end
end
end
end
......@@ -57,7 +57,7 @@ module QA
end
def go_to_profile_settings
with_retry(reload: false) do
retry_until(reload: false) do
within_user_menu do
click_link 'Settings'
end
......
......@@ -23,7 +23,7 @@ module QA
check_element :new_user_accept_terms if has_element?(:new_user_accept_terms)
signed_in = with_retry do
signed_in = retry_until do
click_element :new_user_register_button
Page::Main::Menu.act { has_personal_area? }
......
......@@ -80,7 +80,7 @@ module QA
# Retry the attempt to click :commit_button just in case part of the
# animation is still in process even when the buttons have the
# expected visibility.
commit_success_msg_shown = with_retry do
commit_success_msg_shown = retry_until do
click_element :commit_button
wait(reload: false) do
......
......@@ -167,7 +167,7 @@ module QA
def verify_users_synced(expected_users)
EE::Page::Group::Members.perform do |page|
page.click_sync_now
users_synchronised = page.with_retry(reload: true) do
users_synchronised = page.retry_until(reload: true) do
expected_users.map { |user| page.has_content?(user) }.all?
end
expect(users_synchronised).to be_truthy
......
......@@ -2,8 +2,7 @@
require 'securerandom'
module QA
# Failure issue: https://gitlab.com/gitlab-org/quality/nightly/issues/72
context 'Manage', :quarantine do
context 'Manage' do
describe 'Group level project template' do
let(:files) do
[
......
# frozen_string_literal: true
module QA
# Failure issue: https://gitlab.com/gitlab-org/quality/nightly/issues/72
context 'Manage', :smoke, :quarantine do
context 'Manage', :smoke do
describe 'Project creation' do
it 'user creates a new project' do
Runtime::Browser.visit(:gitlab, Page::Main::Login)
......
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