2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2014-09-02 18:07:02 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe WebHook do
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:hook) { build(:project_hook) }
|
|
|
|
|
|
|
|
describe 'associations' do
|
2019-12-21 20:55:43 +05:30
|
|
|
it { is_expected.to have_many(:web_hook_logs) }
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'validations' do
|
2015-04-26 12:48:37 +05:30
|
|
|
it { is_expected.to validate_presence_of(:url) }
|
2014-09-02 18:07:02 +05:30
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
describe 'url' do
|
2017-09-10 17:25:29 +05:30
|
|
|
it { is_expected.to allow_value('http://example.com').for(:url) }
|
|
|
|
it { is_expected.to allow_value('https://example.com').for(:url) }
|
|
|
|
it { is_expected.to allow_value(' https://example.com ').for(:url) }
|
|
|
|
it { is_expected.to allow_value('http://test.com/api').for(:url) }
|
|
|
|
it { is_expected.to allow_value('http://test.com/api?key=abc').for(:url) }
|
|
|
|
it { is_expected.to allow_value('http://test.com/api?key=abc&type=def').for(:url) }
|
2014-09-02 18:07:02 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
it { is_expected.not_to allow_value('example.com').for(:url) }
|
|
|
|
it { is_expected.not_to allow_value('ftp://example.com').for(:url) }
|
|
|
|
it { is_expected.not_to allow_value('herp-and-derp').for(:url) }
|
2016-06-02 11:05:42 +05:30
|
|
|
|
|
|
|
it 'strips :url before saving it' do
|
2017-09-10 17:25:29 +05:30
|
|
|
hook.url = ' https://example.com '
|
|
|
|
hook.save
|
2016-06-02 11:05:42 +05:30
|
|
|
|
|
|
|
expect(hook.url).to eq('https://example.com')
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
describe 'token' do
|
|
|
|
it { is_expected.to allow_value("foobar").for(:token) }
|
|
|
|
|
|
|
|
it { is_expected.not_to allow_values("foo\nbar", "foo\r\nbar").for(:token) }
|
|
|
|
end
|
2018-11-20 20:47:30 +05:30
|
|
|
|
|
|
|
describe 'push_events_branch_filter' do
|
|
|
|
it { is_expected.to allow_values("good_branch_name", "another/good-branch_name").for(:push_events_branch_filter) }
|
|
|
|
it { is_expected.to allow_values("").for(:push_events_branch_filter) }
|
|
|
|
it { is_expected.not_to allow_values("bad branch name", "bad~branchname").for(:push_events_branch_filter) }
|
|
|
|
|
|
|
|
it 'gets rid of whitespace' do
|
|
|
|
hook.push_events_branch_filter = ' branch '
|
|
|
|
hook.save
|
|
|
|
|
|
|
|
expect(hook.push_events_branch_filter).to eq('branch')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'stores whitespace only as empty' do
|
|
|
|
hook.push_events_branch_filter = ' '
|
|
|
|
hook.save
|
|
|
|
|
|
|
|
expect(hook.push_events_branch_filter).to eq('')
|
|
|
|
end
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
describe 'encrypted attributes' do
|
|
|
|
subject { described_class.encrypted_attributes.keys }
|
|
|
|
|
|
|
|
it { is_expected.to contain_exactly(:token, :url) }
|
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe 'execute' do
|
|
|
|
let(:data) { { key: 'value' } }
|
|
|
|
let(:hook_name) { 'project hook' }
|
2015-12-23 02:04:40 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
before do
|
|
|
|
expect(WebHookService).to receive(:new).with(hook, data, hook_name).and_call_original
|
2015-12-23 02:04:40 +05:30
|
|
|
end
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
it '#execute' do
|
|
|
|
expect_any_instance_of(WebHookService).to receive(:execute)
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
hook.execute(data, hook_name)
|
2016-01-14 18:37:52 +05:30
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
it '#async_execute' do
|
|
|
|
expect_any_instance_of(WebHookService).to receive(:async_execute)
|
2016-01-14 18:37:52 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
hook.async_execute(data, hook_name)
|
2016-01-14 18:37:52 +05:30
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
2019-12-21 20:55:43 +05:30
|
|
|
|
|
|
|
describe '#destroy' do
|
|
|
|
it 'cascades to web_hook_logs' do
|
|
|
|
web_hook = create(:project_hook)
|
|
|
|
create_list(:web_hook_log, 3, web_hook: web_hook)
|
|
|
|
|
|
|
|
expect { web_hook.destroy }.to change(web_hook.web_hook_logs, :count).by(-3)
|
|
|
|
end
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|