Commit 72222e9f authored by Markus Koller's avatar Markus Koller

Move SlackMattermost::Notifier to Integrations namespace

This also moves the module into the concerns folder, and shortens it to
`SlackMattermostNotifier` since this is the only one in the
`SlackMattermost` namespace.

Part of https://gitlab.com/gitlab-org/gitlab/-/issues/201855
parent e7cfd585
...@@ -722,7 +722,6 @@ RSpec/EmptyLineAfterFinalLetItBe: ...@@ -722,7 +722,6 @@ RSpec/EmptyLineAfterFinalLetItBe:
- spec/services/wiki_pages/event_create_service_spec.rb - spec/services/wiki_pages/event_create_service_spec.rb
- spec/support/shared_examples/graphql/design_fields_shared_examples.rb - spec/support/shared_examples/graphql/design_fields_shared_examples.rb
- spec/support/shared_examples/graphql/mutations/set_assignees_shared_examples.rb - spec/support/shared_examples/graphql/mutations/set_assignees_shared_examples.rb
- spec/support/shared_examples/models/slack_mattermost_notifications_shared_examples.rb
- spec/support/shared_examples/quick_actions/issuable/issuable_quick_actions_shared_examples.rb - spec/support/shared_examples/quick_actions/issuable/issuable_quick_actions_shared_examples.rb
- spec/support/shared_examples/services/container_registry_auth_service_shared_examples.rb - spec/support/shared_examples/services/container_registry_auth_service_shared_examples.rb
- spec/support/shared_examples/services/packages_shared_examples.rb - spec/support/shared_examples/services/packages_shared_examples.rb
...@@ -2917,5 +2916,4 @@ Style/RegexpLiteralMixedPreserve: ...@@ -2917,5 +2916,4 @@ Style/RegexpLiteralMixedPreserve:
- 'spec/support/helpers/grafana_api_helpers.rb' - 'spec/support/helpers/grafana_api_helpers.rb'
- 'spec/support/helpers/query_recorder.rb' - 'spec/support/helpers/query_recorder.rb'
- 'spec/support/helpers/require_migration.rb' - 'spec/support/helpers/require_migration.rb'
- 'spec/support/shared_examples/models/slack_mattermost_notifications_shared_examples.rb'
- 'spec/views/layouts/_head.html.haml_spec.rb' - 'spec/views/layouts/_head.html.haml_spec.rb'
# frozen_string_literal: true # frozen_string_literal: true
module SlackMattermost module Integrations
module Notifier module SlackMattermostNotifier
private private
def notify(message, opts) def notify(message, opts)
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
module Integrations module Integrations
class Mattermost < BaseChatNotification class Mattermost < BaseChatNotification
include SlackMattermost::Notifier include SlackMattermostNotifier
include ActionView::Helpers::UrlHelper include ActionView::Helpers::UrlHelper
def title def title
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
module Integrations module Integrations
class Slack < BaseChatNotification class Slack < BaseChatNotification
include SlackMattermost::Notifier include SlackMattermostNotifier
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
SUPPORTED_EVENTS_FOR_USAGE_LOG = %w[ SUPPORTED_EVENTS_FOR_USAGE_LOG = %w[
......
...@@ -3,5 +3,5 @@ ...@@ -3,5 +3,5 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Integrations::Mattermost do RSpec.describe Integrations::Mattermost do
it_behaves_like "slack or mattermost notifications", "Mattermost" it_behaves_like Integrations::SlackMattermostNotifier, "Mattermost"
end end
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Integrations::Slack do RSpec.describe Integrations::Slack do
it_behaves_like "slack or mattermost notifications", 'Slack' it_behaves_like Integrations::SlackMattermostNotifier, "Slack"
describe '#execute' do describe '#execute' do
before do before do
......
# frozen_string_literal: true # frozen_string_literal: true
RSpec.shared_examples 'slack or mattermost notifications' do |service_name| RSpec.shared_examples Integrations::SlackMattermostNotifier do |service_name|
include StubRequests include StubRequests
let(:chat_service) { described_class.new } let(:chat_service) { described_class.new }
let(:webhook_url) { 'https://example.gitlab.com' } let(:webhook_url) { 'https://example.gitlab.com' }
def execute_with_options(options) def execute_with_options(options)
receive(:new).with(webhook_url, options.merge(http_client: SlackMattermost::Notifier::HTTPClient)) receive(:new).with(webhook_url, options.merge(http_client: Integrations::SlackMattermostNotifier::HTTPClient))
.and_return(double(:slack_service).as_null_object) .and_return(double(:slack_service).as_null_object)
end end
...@@ -128,6 +128,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name| ...@@ -128,6 +128,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name|
context 'issue events' do context 'issue events' do
let_it_be(:issue) { create(:issue) } let_it_be(:issue) { create(:issue) }
let(:data) { issue.to_hook_data(user) } let(:data) { issue.to_hook_data(user) }
it_behaves_like 'calls the service API with the event message', /Issue (.*?) opened by/ it_behaves_like 'calls the service API with the event message', /Issue (.*?) opened by/
...@@ -167,6 +168,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name| ...@@ -167,6 +168,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name|
context 'merge request events' do context 'merge request events' do
let_it_be(:merge_request) { create(:merge_request) } let_it_be(:merge_request) { create(:merge_request) }
let(:data) { merge_request.to_hook_data(user) } let(:data) { merge_request.to_hook_data(user) }
it_behaves_like 'calls the service API with the event message', /opened merge request/ it_behaves_like 'calls the service API with the event message', /opened merge request/
...@@ -184,9 +186,10 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name| ...@@ -184,9 +186,10 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name|
context 'wiki page events' do context 'wiki page events' do
let_it_be(:wiki_page) { create(:wiki_page, wiki: project.wiki, message: 'user created page: Awesome wiki_page') } let_it_be(:wiki_page) { create(:wiki_page, wiki: project.wiki, message: 'user created page: Awesome wiki_page') }
let(:data) { Gitlab::DataBuilder::WikiPage.build(wiki_page, user, 'create') } let(:data) { Gitlab::DataBuilder::WikiPage.build(wiki_page, user, 'create') }
it_behaves_like 'calls the service API with the event message', / created (.*?)wikis\/(.*?)|wiki page> in/ it_behaves_like 'calls the service API with the event message', %r{ created (.*?)wikis/(.*?)|wiki page> in}
context 'with event channel' do context 'with event channel' do
let(:chat_service_params) { { wiki_page_channel: 'random' } } let(:chat_service_params) { { wiki_page_channel: 'random' } }
...@@ -201,6 +204,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name| ...@@ -201,6 +204,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name|
context 'deployment events' do context 'deployment events' do
let_it_be(:deployment) { create(:deployment) } let_it_be(:deployment) { create(:deployment) }
let(:data) { Gitlab::DataBuilder::Deployment.build(deployment, Time.current) } let(:data) { Gitlab::DataBuilder::Deployment.build(deployment, Time.current) }
it_behaves_like 'calls the service API with the event message', /Deploy to (.*?) created/ it_behaves_like 'calls the service API with the event message', /Deploy to (.*?) created/
...@@ -208,6 +212,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name| ...@@ -208,6 +212,7 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name|
context 'note event' do context 'note event' do
let_it_be(:issue_note) { create(:note_on_issue, project: project, note: "issue note") } let_it_be(:issue_note) { create(:note_on_issue, project: project, note: "issue note") }
let(:data) { Gitlab::DataBuilder::Note.build(issue_note, user) } let(:data) { Gitlab::DataBuilder::Note.build(issue_note, user) }
it_behaves_like 'calls the service API with the event message', /commented on issue/ it_behaves_like 'calls the service API with the event message', /commented on issue/
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment