diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-06-16 21:25:58 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-06-16 21:25:58 +0300 |
commit | a5f4bba440d7f9ea47046a0a561d49adf0a1e6d4 (patch) | |
tree | fb69158581673816a8cd895f9d352dcb3c678b1e /spec/models/project_services/microsoft_teams_service_spec.rb | |
parent | d16b2e8639e99961de6ddc93909f3bb5c1445ba1 (diff) |
Add latest changes from gitlab-org/gitlab@14-0-stable-eev14.0.0-rc42
Diffstat (limited to 'spec/models/project_services/microsoft_teams_service_spec.rb')
-rw-r--r-- | spec/models/project_services/microsoft_teams_service_spec.rb | 360 |
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 |