2019-07-25 01:24:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-04-27 06:08:57 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-03 14:08:28 -04:00
|
|
|
RSpec.describe 'Admin::HookLogs' do
|
2017-08-02 15:55:11 -04:00
|
|
|
let(:project) { create(:project) }
|
2017-04-27 06:08:57 -04:00
|
|
|
let(:system_hook) { create(:system_hook) }
|
|
|
|
let(:hook_log) { create(:web_hook_log, web_hook: system_hook, internal_error_message: 'some error') }
|
|
|
|
|
|
|
|
before do
|
2020-11-23 10:09:37 -05:00
|
|
|
admin = create(:admin)
|
|
|
|
sign_in(admin)
|
|
|
|
gitlab_enable_admin_mode_sign_in(admin)
|
2017-04-27 06:08:57 -04:00
|
|
|
end
|
|
|
|
|
2018-07-05 02:32:05 -04:00
|
|
|
it 'show list of hook logs' do
|
2017-04-27 06:08:57 -04:00
|
|
|
hook_log
|
|
|
|
visit edit_admin_hook_path(system_hook)
|
|
|
|
|
2021-10-13 11:12:51 -04:00
|
|
|
expect(page).to have_content('Recent events')
|
|
|
|
expect(page).to have_link('View details', href: admin_hook_hook_log_path(system_hook, hook_log))
|
2017-04-27 06:08:57 -04:00
|
|
|
end
|
|
|
|
|
2018-07-05 02:32:05 -04:00
|
|
|
it 'show hook log details' do
|
2017-04-27 06:08:57 -04:00
|
|
|
hook_log
|
|
|
|
visit edit_admin_hook_path(system_hook)
|
|
|
|
click_link 'View details'
|
|
|
|
|
|
|
|
expect(page).to have_content("POST #{hook_log.url}")
|
|
|
|
expect(page).to have_content(hook_log.internal_error_message)
|
|
|
|
expect(page).to have_content('Resend Request')
|
|
|
|
end
|
|
|
|
|
2018-07-05 02:32:05 -04:00
|
|
|
it 'retry hook log' do
|
2017-04-27 06:08:57 -04:00
|
|
|
WebMock.stub_request(:post, system_hook.url)
|
|
|
|
|
|
|
|
hook_log
|
|
|
|
visit edit_admin_hook_path(system_hook)
|
|
|
|
click_link 'View details'
|
|
|
|
click_link 'Resend Request'
|
|
|
|
|
2022-03-03 10:16:42 -05:00
|
|
|
expect(page).to have_current_path(edit_admin_hook_path(system_hook), ignore_query: true)
|
2017-04-27 06:08:57 -04:00
|
|
|
end
|
2022-06-07 14:09:27 -04:00
|
|
|
|
|
|
|
context 'response data is too large' do
|
|
|
|
let(:hook_log) { create(:web_hook_log, web_hook: system_hook, request_data: WebHookLog::OVERSIZE_REQUEST_DATA) }
|
|
|
|
|
|
|
|
it 'shows request data as too large and disables retry function' do
|
|
|
|
visit(admin_hook_hook_log_path(system_hook, hook_log))
|
|
|
|
|
|
|
|
expect(page).to have_content('Request data is too large')
|
|
|
|
expect(page).not_to have_button(
|
|
|
|
_('Resent request'),
|
|
|
|
disabled: true, class: 'has-tooltip', title: _("Request data is too large")
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
2017-04-27 06:08:57 -04:00
|
|
|
end
|