summaryrefslogtreecommitdiff
path: root/spec/support
diff options
context:
space:
mode:
authorSean McGivern <sean@mcgivern.me.uk>2018-03-02 16:04:53 +0000
committerSean McGivern <sean@mcgivern.me.uk>2018-03-02 16:04:53 +0000
commit9b704ef327cc0224bf09c1e8d8d27df88ab13734 (patch)
tree0fac87f39fb4bc718d60124af8fcf7bb1edc331f /spec/support
parenta519a346da300972a0061fb341b44afd6d2b857a (diff)
parent158514bba3445b1a8303c6a4d5d7ba2403ef8a9f (diff)
downloadgitlab-ce-9b704ef327cc0224bf09c1e8d8d27df88ab13734.tar.gz
Merge branch '33570-slack-notify-default-branch' into 'master'
Slack notifications - Respect "Notify only default branch" for push events Closes #33570 See merge request gitlab-org/gitlab-ce!17345
Diffstat (limited to 'spec/support')
-rw-r--r--spec/support/slack_mattermost_notifications_shared_examples.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/spec/support/slack_mattermost_notifications_shared_examples.rb b/spec/support/slack_mattermost_notifications_shared_examples.rb
index e827a8da0b7..5e1ce19eafb 100644
--- a/spec/support/slack_mattermost_notifications_shared_examples.rb
+++ b/spec/support/slack_mattermost_notifications_shared_examples.rb
@@ -337,6 +337,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do
before do
chat_service.notify_only_default_branch = true
+ WebMock.stub_request(:post, webhook_url)
end
it 'does not call the Slack/Mattermost API for pipeline events' do
@@ -345,6 +346,23 @@ RSpec.shared_examples 'slack or mattermost notifications' do
expect(result).to be_falsy
end
+
+ it 'does not notify push events if they are not for the default branch' do
+ ref = "#{Gitlab::Git::BRANCH_REF_PREFIX}test"
+ push_sample_data = Gitlab::DataBuilder::Push.build(project, user, nil, nil, ref, [])
+
+ chat_service.execute(push_sample_data)
+
+ expect(WebMock).not_to have_requested(:post, webhook_url)
+ end
+
+ it 'notifies about push events for the default branch' do
+ push_sample_data = Gitlab::DataBuilder::Push.build_sample(project, user)
+
+ chat_service.execute(push_sample_data)
+
+ expect(WebMock).to have_requested(:post, webhook_url).once
+ end
end
context 'when disabled' do