debian-mirror-gitlab/spec/models/integrations/base_chat_notification_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

368 lines
12 KiB
Ruby
Raw Permalink Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2023-03-17 16:20:25 +05:30
RSpec.describe Integrations::BaseChatNotification, feature_category: :integrations do
2023-01-13 00:05:48 +05:30
describe 'default values' do
it { expect(subject.category).to eq(:chat) }
end
2022-07-16 23:28:13 +05:30
describe 'validations' do
2017-08-17 22:00:37 +05:30
before do
2023-04-23 21:23:45 +05:30
subject.active = active
2022-07-16 23:28:13 +05:30
allow(subject).to receive(:default_channel_placeholder).and_return('placeholder')
2023-01-13 00:05:48 +05:30
allow(subject).to receive(:webhook_help).and_return('help')
2017-08-17 22:00:37 +05:30
end
2023-04-23 21:23:45 +05:30
def build_channel_list(count)
(1..count).map { |i| "##{i}" }.join(',')
end
context 'when active' do
let(:active) { true }
it { is_expected.to validate_presence_of :webhook }
it { is_expected.to validate_inclusion_of(:labels_to_be_notified_behavior).in_array(%w[match_any match_all]).allow_blank }
it { is_expected.to allow_value(build_channel_list(10)).for(:push_channel) }
it { is_expected.not_to allow_value(build_channel_list(11)).for(:push_channel) }
end
context 'when inactive' do
let(:active) { false }
it { is_expected.not_to validate_presence_of :webhook }
it { is_expected.not_to validate_inclusion_of(:labels_to_be_notified_behavior).in_array(%w[match_any match_all]).allow_blank }
it { is_expected.to allow_value(build_channel_list(10)).for(:push_channel) }
it { is_expected.to allow_value(build_channel_list(11)).for(:push_channel) }
end
2021-06-08 01:23:25 +05:30
end
2018-11-20 20:47:30 +05:30
describe '#execute' do
2021-09-30 23:02:18 +05:30
subject(:chat_integration) { described_class.new }
2019-12-04 20:38:33 +05:30
2021-06-08 01:23:25 +05:30
let_it_be(:project) { create(:project, :repository) }
2023-01-13 00:05:48 +05:30
let(:user) { build_stubbed(:user) }
2018-11-20 20:47:30 +05:30
let(:webhook_url) { 'https://example.gitlab.com/' }
2020-03-13 15:44:24 +05:30
let(:data) { Gitlab::DataBuilder::Push.build_sample(subject.project, user) }
2018-11-20 20:47:30 +05:30
before do
2021-09-30 23:02:18 +05:30
allow(chat_integration).to receive_messages(
2018-11-20 20:47:30 +05:30
project: project,
project_id: project.id,
webhook: webhook_url
)
2023-03-04 22:38:38 +05:30
WebMock.stub_request(:post, webhook_url) if webhook_url.present?
2018-11-20 20:47:30 +05:30
subject.active = true
end
context 'with a repository' do
it 'returns true' do
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:notify).and_return(true)
expect(chat_integration.execute(data)).to be true
2018-11-20 20:47:30 +05:30
end
end
context 'with an empty repository' do
it 'returns true' do
2023-01-13 00:05:48 +05:30
subject.project = build_stubbed(:project, :empty_repo)
2018-11-20 20:47:30 +05:30
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:notify).and_return(true)
expect(chat_integration.execute(data)).to be true
2018-11-20 20:47:30 +05:30
end
end
2023-03-04 22:38:38 +05:30
context 'when webhook is blank' do
let(:webhook_url) { '' }
it 'returns false' do
expect(chat_integration).not_to receive(:notify)
expect(chat_integration.execute(data)).to be false
end
context 'when webhook is not required' do
it 'returns true' do
allow(chat_integration).to receive(:requires_webhook?).and_return(false)
expect(chat_integration).to receive(:notify).and_return(true)
expect(chat_integration.execute(data)).to be true
end
end
end
context 'when event is not supported' do
it 'returns false' do
allow(chat_integration).to receive(:supported_events).and_return(['foo'])
expect(chat_integration).not_to receive(:notify)
expect(chat_integration.execute(data)).to be false
end
end
2020-03-13 15:44:24 +05:30
context 'with a project with name containing spaces' do
it 'does not remove spaces' do
allow(project).to receive(:full_name).and_return('Project Name')
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:get_message).with(any_args, hash_including(project_name: 'Project Name'))
chat_integration.execute(data)
2020-03-13 15:44:24 +05:30
end
end
2020-04-08 14:13:33 +05:30
2021-03-11 19:13:27 +05:30
context 'when the data object has a label' do
2023-01-13 00:05:48 +05:30
let_it_be(:label) { create(:label, project: project, name: 'Bug') }
let_it_be(:label_2) { create(:label, project: project, name: 'Community contribution') }
let_it_be(:label_3) { create(:label, project: project, name: 'Backend') }
2021-06-08 01:23:25 +05:30
let_it_be(:issue) { create(:labeled_issue, project: project, labels: [label, label_2, label_3]) }
let_it_be(:note) { create(:note, noteable: issue, project: project) }
2021-03-11 19:13:27 +05:30
let(:data) { Gitlab::DataBuilder::Note.build(note, user) }
2021-09-30 23:02:18 +05:30
shared_examples 'notifies the chat integration' do
2021-06-08 01:23:25 +05:30
specify do
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:notify).with(any_args)
2021-06-08 01:23:25 +05:30
2021-09-30 23:02:18 +05:30
chat_integration.execute(data)
2021-06-08 01:23:25 +05:30
end
end
2021-03-11 19:13:27 +05:30
2021-09-30 23:02:18 +05:30
shared_examples 'does not notify the chat integration' do
2021-06-08 01:23:25 +05:30
specify do
2021-09-30 23:02:18 +05:30
expect(chat_integration).not_to receive(:notify).with(any_args)
2021-03-11 19:13:27 +05:30
2021-09-30 23:02:18 +05:30
chat_integration.execute(data)
2021-03-11 19:13:27 +05:30
end
end
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-09-04 01:27:46 +05:30
context 'with label filter' do
2021-09-30 23:02:18 +05:30
subject(:chat_integration) { described_class.new(labels_to_be_notified: '~Bug') }
2021-09-04 01:27:46 +05:30
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-09-04 01:27:46 +05:30
context 'MergeRequest events' do
2023-01-13 00:05:48 +05:30
let(:data) { build_stubbed(:merge_request, source_project: project, labels: [label]).to_hook_data(user) }
2021-09-04 01:27:46 +05:30
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-09-04 01:27:46 +05:30
end
context 'Issue events' do
let(:data) { issue.to_hook_data(user) }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-09-04 01:27:46 +05:30
end
2023-03-17 16:20:25 +05:30
context 'Incident events' do
let(:data) { issue.to_hook_data(user).merge!({ object_kind: 'incident' }) }
it_behaves_like 'notifies the chat integration'
end
2021-09-04 01:27:46 +05:30
end
2021-06-08 01:23:25 +05:30
context 'when labels_to_be_notified_behavior is not defined' do
2021-09-30 23:02:18 +05:30
subject(:chat_integration) { described_class.new(labels_to_be_notified: label_filter) }
2021-03-11 19:13:27 +05:30
2021-06-08 01:23:25 +05:30
context 'no matching labels' do
let(:label_filter) { '~some random label' }
2021-03-11 19:13:27 +05:30
2021-09-30 23:02:18 +05:30
it_behaves_like 'does not notify the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'only one label matches' do
let(:label_filter) { '~some random label, ~Bug' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
end
context 'when labels_to_be_notified_behavior is blank' do
2021-09-30 23:02:18 +05:30
subject(:chat_integration) { described_class.new(labels_to_be_notified: label_filter, labels_to_be_notified_behavior: '') }
2021-06-08 01:23:25 +05:30
context 'no matching labels' do
let(:label_filter) { '~some random label' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'does not notify the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'only one label matches' do
let(:label_filter) { '~some random label, ~Bug' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
end
context 'when labels_to_be_notified_behavior is match_any' do
2021-09-30 23:02:18 +05:30
subject(:chat_integration) do
2021-06-08 01:23:25 +05:30
described_class.new(
labels_to_be_notified: label_filter,
labels_to_be_notified_behavior: 'match_any'
)
end
context 'no label filter' do
let(:label_filter) { nil }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'no matching labels' do
let(:label_filter) { '~some random label' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'does not notify the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'only one label matches' do
let(:label_filter) { '~some random label, ~Bug' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
end
context 'when labels_to_be_notified_behavior is match_all' do
2021-09-30 23:02:18 +05:30
subject(:chat_integration) do
2021-06-08 01:23:25 +05:30
described_class.new(
labels_to_be_notified: label_filter,
labels_to_be_notified_behavior: 'match_all'
)
end
context 'no label filter' do
let(:label_filter) { nil }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'no matching labels' do
let(:label_filter) { '~some random label' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'does not notify the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'only one label matches' do
let(:label_filter) { '~some random label, ~Bug' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'does not notify the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'labels matches exactly' do
let(:label_filter) { '~Bug, ~Backend, ~Community contribution' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'labels matches but object has more' do
let(:label_filter) { '~Bug, ~Backend' }
2021-09-30 23:02:18 +05:30
it_behaves_like 'notifies the chat integration'
2021-06-08 01:23:25 +05:30
end
context 'labels are distributed on multiple objects' do
let(:label_filter) { '~Bug, ~Backend' }
let(:data) do
Gitlab::DataBuilder::Note.build(note, user).merge({
issue: {
labels: [
{ title: 'Bug' }
]
},
merge_request: {
labels: [
{
title: 'Backend'
}
]
}
})
end
2021-09-30 23:02:18 +05:30
it_behaves_like 'does not notify the chat integration'
2021-03-11 19:13:27 +05:30
end
end
end
2020-04-22 19:07:51 +05:30
context 'with "channel" property' do
before do
2021-09-30 23:02:18 +05:30
allow(chat_integration).to receive(:channel).and_return(channel)
2020-04-22 19:07:51 +05:30
end
context 'empty string' do
let(:channel) { '' }
it 'does not include the channel' do
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:notify).with(any_args, hash_excluding(:channel)).and_return(true)
expect(chat_integration.execute(data)).to be(true)
2020-04-22 19:07:51 +05:30
end
end
context 'empty spaces' do
let(:channel) { ' ' }
it 'does not include the channel' do
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:notify).with(any_args, hash_excluding(:channel)).and_return(true)
expect(chat_integration.execute(data)).to be(true)
2020-04-22 19:07:51 +05:30
end
end
end
2020-04-08 14:13:33 +05:30
shared_examples 'with channel specified' do |channel, expected_channels|
before do
2021-09-30 23:02:18 +05:30
allow(chat_integration).to receive(:push_channel).and_return(channel)
2020-04-08 14:13:33 +05:30
end
it 'notifies all channels' do
2021-09-30 23:02:18 +05:30
expect(chat_integration).to receive(:notify).with(any_args, hash_including(channel: expected_channels)).and_return(true)
expect(chat_integration.execute(data)).to be(true)
2020-04-08 14:13:33 +05:30
end
end
context 'with single channel specified' do
it_behaves_like 'with channel specified', 'slack-integration', ['slack-integration']
end
context 'with multiple channel names specified' do
it_behaves_like 'with channel specified', 'slack-integration,#slack-test', ['slack-integration', '#slack-test']
end
context 'with multiple channel names with spaces specified' do
it_behaves_like 'with channel specified', 'slack-integration, #slack-test, @UDLP91W0A', ['slack-integration', '#slack-test', '@UDLP91W0A']
end
2023-04-23 21:23:45 +05:30
context 'with duplicate channel names' do
it_behaves_like 'with channel specified', '#slack-test,#slack-test,#slack-test-2', ['#slack-test', '#slack-test-2']
end
2018-11-20 20:47:30 +05:30
end
2022-07-16 23:28:13 +05:30
describe '#default_channel_placeholder' do
it 'raises an error' do
expect { subject.default_channel_placeholder }.to raise_error(NotImplementedError)
end
end
2023-01-13 00:05:48 +05:30
describe '#webhook_help' do
2022-07-16 23:28:13 +05:30
it 'raises an error' do
2023-01-13 00:05:48 +05:30
expect { subject.webhook_help }.to raise_error(NotImplementedError)
2022-07-16 23:28:13 +05:30
end
end
2022-08-13 15:12:31 +05:30
describe '#event_channel_name' do
it 'returns the channel field name for the given event' do
expect(subject.event_channel_name(:event)).to eq('event_channel')
end
end
describe '#event_channel_value' do
it 'returns the channel field value for the given event' do
subject.push_channel = '#pushes'
expect(subject.event_channel_value(:push)).to eq('#pushes')
end
it 'raises an error for unsupported events' do
expect { subject.event_channel_value(:foo) }.to raise_error(NoMethodError)
end
end
2017-08-17 22:00:37 +05:30
end