64 lines
1.8 KiB
Ruby
64 lines
1.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module WaitForRequests
|
|
extend self
|
|
|
|
# This is inspired by http://www.salsify.com/blog/engineering/tearing-capybara-ajax-tests
|
|
def block_and_wait_for_requests_complete
|
|
block_requests { wait_for_all_requests }
|
|
end
|
|
|
|
# Block all requests inside block with 503 response
|
|
def block_requests
|
|
Gitlab::Testing::RequestBlockerMiddleware.block_requests!
|
|
yield
|
|
ensure
|
|
Gitlab::Testing::RequestBlockerMiddleware.allow_requests!
|
|
end
|
|
|
|
# Slow down requests inside block by injecting `sleep 0.2` before each response
|
|
def slow_requests
|
|
Gitlab::Testing::RequestBlockerMiddleware.slow_requests!
|
|
yield
|
|
ensure
|
|
Gitlab::Testing::RequestBlockerMiddleware.allow_requests!
|
|
end
|
|
|
|
# Wait for client-side AJAX requests
|
|
def wait_for_requests
|
|
wait_for('JS requests complete', max_wait_time: 2 * Capybara.default_max_wait_time) do
|
|
finished_all_js_requests?
|
|
end
|
|
end
|
|
|
|
# Wait for active Rack requests and client-side AJAX requests
|
|
def wait_for_all_requests
|
|
wait_for('pending requests complete') do
|
|
finished_all_rack_requests? &&
|
|
finished_all_js_requests?
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def finished_all_rack_requests?
|
|
Gitlab::Testing::RequestBlockerMiddleware.num_active_requests == 0
|
|
end
|
|
|
|
def finished_all_js_requests?
|
|
return true unless javascript_test?
|
|
|
|
finished_all_ajax_requests? &&
|
|
finished_all_axios_requests?
|
|
end
|
|
|
|
def finished_all_axios_requests?
|
|
Capybara.page.evaluate_script('window.pendingRequests || 0').zero? # rubocop:disable Style/NumericPredicate
|
|
end
|
|
|
|
def finished_all_ajax_requests?
|
|
return true if Capybara.page.evaluate_script('typeof jQuery === "undefined"')
|
|
|
|
Capybara.page.evaluate_script('jQuery.active').zero? # rubocop:disable Style/NumericPredicate
|
|
end
|
|
end
|