gitlab-org--gitlab-foss/spec/features/admin/admin_hooks_spec.rb

136 lines
3.3 KiB
Ruby
Raw Normal View History

2012-07-18 17:24:37 -04:00
require 'spec_helper'
describe 'Admin::Hooks' do
let(:user) { create(:admin) }
2012-07-18 17:24:37 -04:00
before do
sign_in(user)
2012-07-18 17:24:37 -04:00
end
2017-04-20 04:31:37 -04:00
describe 'GET /admin/hooks' do
it 'is ok' do
2012-07-18 17:24:37 -04:00
visit admin_root_path
page.within '.nav-sidebar' do
click_on 'System Hooks', match: :first
2012-07-18 17:24:37 -04:00
end
expect(current_path).to eq(admin_hooks_path)
2012-07-18 17:24:37 -04:00
end
2017-04-20 04:31:37 -04:00
it 'has hooks list' do
system_hook = create(:system_hook)
2012-07-18 17:24:37 -04:00
visit admin_hooks_path
expect(page).to have_content(system_hook.url)
2012-07-18 17:24:37 -04:00
end
end
2017-04-20 04:31:37 -04:00
describe 'New Hook' do
let(:url) { generate(:url) }
it 'adds new hook' do
2012-07-18 17:24:37 -04:00
visit admin_hooks_path
fill_in 'hook_url', with: url
check 'Enable SSL verification'
2012-07-18 17:24:37 -04:00
2017-04-04 18:36:19 -04:00
expect { click_button 'Add system hook' }.to change(SystemHook, :count).by(1)
expect(page).to have_content 'SSL Verification: enabled'
expect(current_path).to eq(admin_hooks_path)
expect(page).to have_content(url)
2012-07-18 17:24:37 -04:00
end
end
2017-04-20 04:31:37 -04:00
describe 'Update existing hook' do
let(:new_url) { generate(:url) }
before do
create(:system_hook)
end
2017-04-20 04:31:37 -04:00
it 'updates existing hook' do
visit admin_hooks_path
click_link 'Edit'
fill_in 'hook_url', with: new_url
check 'Enable SSL verification'
click_button 'Save changes'
expect(page).to have_content 'SSL Verification: enabled'
expect(current_path).to eq(admin_hooks_path)
expect(page).to have_content(new_url)
end
end
2017-12-18 09:18:40 -05:00
describe 'Remove existing hook', :js do
before do
create(:system_hook)
end
context 'removes existing hook' do
it 'from hooks list page' do
visit admin_hooks_path
2017-10-03 13:02:48 -04:00
expect { accept_confirm { find(:link, 'Remove').send_keys(:return) } }.to change(SystemHook, :count).by(-1)
end
2017-04-20 04:31:37 -04:00
it 'from hook edit page' do
visit admin_hooks_path
click_link 'Edit'
2017-10-03 13:02:48 -04:00
expect { accept_confirm { find(:link, 'Remove').send_keys(:return) } }.to change(SystemHook, :count).by(-1)
end
2017-04-20 04:31:37 -04:00
end
end
describe 'Test', :js do
2012-07-18 17:24:37 -04:00
before do
system_hook = create(:system_hook)
WebMock.stub_request(:post, system_hook.url)
2012-07-18 17:24:37 -04:00
visit admin_hooks_path
2017-07-20 11:12:06 -04:00
find('.hook-test-button.dropdown').click
click_link 'Push events'
2012-07-18 17:24:37 -04:00
end
it { expect(current_path).to eq(admin_hooks_path) }
2012-07-18 17:24:37 -04:00
end
context 'Merge request hook' do
describe 'New Hook' do
let(:url) { generate(:url) }
it 'adds new hook' do
visit admin_hooks_path
fill_in 'hook_url', with: url
uncheck 'Repository update events'
check 'Merge request events'
expect { click_button 'Add system hook' }.to change(SystemHook, :count).by(1)
expect(current_path).to eq(admin_hooks_path)
expect(page).to have_content(url)
end
end
describe 'Test', :js do
before do
system_hook = create(:system_hook)
WebMock.stub_request(:post, system_hook.url)
end
it 'succeeds if the user has a repository with a merge request' do
project = create(:project, :repository)
create(:project_member, user: user, project: project)
create(:merge_request, source_project: project)
visit admin_hooks_path
find('.hook-test-button.dropdown').click
click_link 'Merge requests events'
expect(page).to have_content 'Hook executed successfully'
end
end
end
2012-07-18 17:24:37 -04:00
end