Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/models/project_services/microsoft_teams_service_spec.rb')
-rw-r--r--spec/models/project_services/microsoft_teams_service_spec.rb360
1 files changed, 0 insertions, 360 deletions
diff --git a/spec/models/project_services/microsoft_teams_service_spec.rb b/spec/models/project_services/microsoft_teams_service_spec.rb
deleted file mode 100644
index 5f3a94a5b99..00000000000
--- a/spec/models/project_services/microsoft_teams_service_spec.rb
+++ /dev/null
@@ -1,360 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-
-RSpec.describe MicrosoftTeamsService do
- let(:chat_service) { described_class.new }
- let(:webhook_url) { 'https://example.gitlab.com/' }
-
- describe "Associations" do
- it { is_expected.to belong_to :project }
- it { is_expected.to have_one :service_hook }
- end
-
- describe 'Validations' do
- context 'when service is active' do
- before do
- subject.active = true
- end
-
- it { is_expected.to validate_presence_of(:webhook) }
- it_behaves_like 'issue tracker service URL attribute', :webhook
- end
-
- context 'when service is inactive' do
- before do
- subject.active = false
- end
-
- it { is_expected.not_to validate_presence_of(:webhook) }
- end
- end
-
- describe '.supported_events' do
- it 'does not support deployment_events' do
- expect(described_class.supported_events).not_to include('deployment')
- end
- end
-
- describe "#execute" do
- let(:user) { create(:user) }
-
- let_it_be(:project) { create(:project, :repository, :wiki_repo) }
-
- before do
- allow(chat_service).to receive_messages(
- project: project,
- project_id: project.id,
- service_hook: true,
- webhook: webhook_url
- )
-
- WebMock.stub_request(:post, webhook_url)
- end
-
- context 'with push events' do
- let(:push_sample_data) do
- Gitlab::DataBuilder::Push.build_sample(project, user)
- end
-
- it "calls Microsoft Teams API for push events" do
- chat_service.execute(push_sample_data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
-
- it 'specifies the webhook when it is configured' do
- expect(MicrosoftTeams::Notifier).to receive(:new).with(webhook_url).and_return(double(:microsoft_teams_service).as_null_object)
-
- chat_service.execute(push_sample_data)
- end
- end
-
- context 'with issue events' do
- let(:opts) { { title: 'Awesome issue', description: 'please fix' } }
- let(:issues_sample_data) do
- service = Issues::CreateService.new(project: project, current_user: user, params: opts)
- issue = service.execute
- service.hook_data(issue, 'open')
- end
-
- it "calls Microsoft Teams API" do
- chat_service.execute(issues_sample_data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
-
- context 'with merge events' do
- let(:opts) do
- {
- title: 'Awesome merge_request',
- description: 'please fix',
- source_branch: 'feature',
- target_branch: 'master'
- }
- end
-
- let(:merge_sample_data) do
- service = MergeRequests::CreateService.new(project: project, current_user: user, params: opts)
- merge_request = service.execute
- service.hook_data(merge_request, 'open')
- end
-
- before do
- project.add_developer(user)
- end
-
- it "calls Microsoft Teams API" do
- chat_service.execute(merge_sample_data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
-
- context 'with wiki page events' do
- let(:opts) do
- {
- title: "Awesome wiki_page",
- content: "Some text describing some thing or another",
- format: "md",
- message: "user created page: Awesome wiki_page"
- }
- end
-
- let(:wiki_page) { create(:wiki_page, wiki: project.wiki, **opts) }
- let(:wiki_page_sample_data) { Gitlab::DataBuilder::WikiPage.build(wiki_page, user, 'create') }
-
- it "calls Microsoft Teams API" do
- chat_service.execute(wiki_page_sample_data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
- end
-
- describe "Note events" do
- let(:user) { create(:user) }
- let(:project) { create(:project, :repository, creator: user) }
-
- before do
- allow(chat_service).to receive_messages(
- project: project,
- project_id: project.id,
- service_hook: true,
- webhook: webhook_url
- )
-
- WebMock.stub_request(:post, webhook_url)
- end
-
- context 'when commit comment event executed' do
- let(:commit_note) do
- create(:note_on_commit, author: user,
- project: project,
- commit_id: project.repository.commit.id,
- note: 'a comment on a commit')
- end
-
- it "calls Microsoft Teams API for commit comment events" do
- data = Gitlab::DataBuilder::Note.build(commit_note, user)
-
- chat_service.execute(data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
-
- context 'when merge request comment event executed' do
- let(:merge_request_note) do
- create(:note_on_merge_request, project: project,
- note: "merge request note")
- end
-
- it "calls Microsoft Teams API for merge request comment events" do
- data = Gitlab::DataBuilder::Note.build(merge_request_note, user)
-
- chat_service.execute(data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
-
- context 'when issue comment event executed' do
- let(:issue_note) do
- create(:note_on_issue, project: project, note: "issue note")
- end
-
- it "calls Microsoft Teams API for issue comment events" do
- data = Gitlab::DataBuilder::Note.build(issue_note, user)
-
- chat_service.execute(data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
-
- context 'when snippet comment event executed' do
- let(:snippet_note) do
- create(:note_on_project_snippet, project: project,
- note: "snippet note")
- end
-
- it "calls Microsoft Teams API for snippet comment events" do
- data = Gitlab::DataBuilder::Note.build(snippet_note, user)
-
- chat_service.execute(data)
-
- expect(WebMock).to have_requested(:post, webhook_url).once
- end
- end
- end
-
- describe 'Pipeline events' do
- let(:user) { create(:user) }
- let(:project) { create(:project, :repository) }
-
- let(:pipeline) do
- create(:ci_pipeline,
- project: project, status: status,
- sha: project.commit.sha, ref: project.default_branch)
- end
-
- before do
- allow(chat_service).to receive_messages(
- project: project,
- service_hook: true,
- webhook: webhook_url
- )
- end
-
- shared_examples 'call Microsoft Teams API' do |branches_to_be_notified: nil|
- before do
- WebMock.stub_request(:post, webhook_url)
- chat_service.branches_to_be_notified = branches_to_be_notified if branches_to_be_notified
- end
-
- it 'calls Microsoft Teams API for pipeline events' do
- data = Gitlab::DataBuilder::Pipeline.build(pipeline)
- data[:markdown] = true
-
- chat_service.execute(data)
-
- message = Integrations::ChatMessage::PipelineMessage.new(data)
-
- expect(WebMock).to have_requested(:post, webhook_url)
- .with(body: hash_including({ summary: message.summary }))
- .once
- end
- end
-
- shared_examples 'does not call Microsoft Teams API' do |branches_to_be_notified: nil|
- before do
- chat_service.branches_to_be_notified = branches_to_be_notified if branches_to_be_notified
- end
- it 'does not call Microsoft Teams API for pipeline events' do
- data = Gitlab::DataBuilder::Pipeline.build(pipeline)
- result = chat_service.execute(data)
-
- expect(result).to be_falsy
- end
- end
-
- context 'with failed pipeline' do
- let(:status) { 'failed' }
-
- it_behaves_like 'call Microsoft Teams API'
- end
-
- context 'with succeeded pipeline' do
- let(:status) { 'success' }
-
- context 'with default to notify_only_broken_pipelines' do
- it 'does not call Microsoft Teams API for pipeline events' do
- data = Gitlab::DataBuilder::Pipeline.build(pipeline)
- result = chat_service.execute(data)
-
- expect(result).to be_falsy
- end
- end
-
- context 'with setting notify_only_broken_pipelines to false' do
- before do
- chat_service.notify_only_broken_pipelines = false
- end
-
- it_behaves_like 'call Microsoft Teams API'
- end
- end
-
- context 'with default branch' do
- let(:pipeline) do
- create(:ci_pipeline, project: project, status: 'failed', sha: project.commit.sha, ref: project.default_branch)
- end
-
- context 'only notify for the default branch' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "default"
- end
-
- context 'notify for only protected branches' do
- it_behaves_like 'does not call Microsoft Teams API', branches_to_be_notified: "protected"
- end
-
- context 'notify for only default and protected branches' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "default_and_protected"
- end
-
- context 'notify for all branches' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "all"
- end
- end
-
- context 'with protected branch' do
- before do
- create(:protected_branch, project: project, name: 'a-protected-branch')
- end
-
- let(:pipeline) do
- create(:ci_pipeline, project: project, status: 'failed', sha: project.commit.sha, ref: 'a-protected-branch')
- end
-
- context 'only notify for the default branch' do
- it_behaves_like 'does not call Microsoft Teams API', branches_to_be_notified: "default"
- end
-
- context 'notify for only protected branches' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "protected"
- end
-
- context 'notify for only default and protected branches' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "default_and_protected"
- end
-
- context 'notify for all branches' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "all"
- end
- end
-
- context 'with neither protected nor default branch' do
- let(:pipeline) do
- create(:ci_pipeline, project: project, status: 'failed', sha: project.commit.sha, ref: 'a-random-branch')
- end
-
- context 'only notify for the default branch' do
- it_behaves_like 'does not call Microsoft Teams API', branches_to_be_notified: "default"
- end
-
- context 'notify for only protected branches' do
- it_behaves_like 'does not call Microsoft Teams API', branches_to_be_notified: "protected"
- end
-
- context 'notify for only default and protected branches' do
- it_behaves_like 'does not call Microsoft Teams API', branches_to_be_notified: "default_and_protected"
- end
-
- context 'notify for all branches' do
- it_behaves_like 'call Microsoft Teams API', branches_to_be_notified: "all"
- end
- end
- end
-end