Commit d4acde2d authored by Andy Soiron's avatar Andy Soiron Committed by Arturo Herrero

Cleanup and optimize chat service specs

parent c4088b82
...@@ -66,193 +66,183 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name| ...@@ -66,193 +66,183 @@ RSpec.shared_examples 'slack or mattermost notifications' do |service_name|
end end
describe "#execute" do describe "#execute" do
let(:user) { create(:user) } let_it_be(:project) { create(:project, :repository, :wiki_repo) }
let(:project) { create(:project, :repository, :wiki_repo) } let_it_be(:user) { create(:user) }
let(:username) { 'slack_username' }
let(:channel) { 'slack_channel' } let(:chat_service) { described_class.new( { project: project, webhook: webhook_url, branches_to_be_notified: 'all' }.merge(chat_service_params)) }
let(:issue_service_options) { { title: 'Awesome issue', description: 'please fix' } } let(:chat_service_params) { {} }
let(:data) { Gitlab::DataBuilder::Push.build_sample(project, user) }
let(:data) do
Gitlab::DataBuilder::Push.build_sample(project, user)
end
let!(:stubbed_resolved_hostname) do let!(:stubbed_resolved_hostname) do
stub_full_request(webhook_url, method: :post).request_pattern.uri_pattern.to_s stub_full_request(webhook_url, method: :post).request_pattern.uri_pattern.to_s
end end
before do subject(:execute_service) { chat_service.execute(data) }
allow(chat_service).to receive_messages(
project: project,
project_id: project.id,
service_hook: true,
webhook: webhook_url
)
issue_service = Issues::CreateService.new(project, user, issue_service_options) context 'with username for slack configured' do
@issue = issue_service.execute let(:chat_service_params) { { username: 'slack_username' } }
@issues_sample_data = issue_service.hook_data(@issue, 'open')
project.add_developer(user)
opts = {
title: 'Awesome merge_request',
description: 'please fix',
source_branch: 'feature',
target_branch: 'master'
}
merge_service = MergeRequests::CreateService.new(project,
user, opts)
@merge_request = merge_service.execute
@merge_sample_data = merge_service.hook_data(@merge_request,
'open')
opts = {
title: "Awesome wiki_page",
content: "Some text describing some thing or another",
format: "md",
message: "user created page: Awesome wiki_page"
}
@wiki_page = create(:wiki_page, wiki: project.wiki, **opts)
@wiki_page_sample_data = Gitlab::DataBuilder::WikiPage.build(@wiki_page, user, 'create')
end
it "calls #{service_name} API for push events" do it 'uses the username as an option' do
chat_service.execute(data) expect(Slack::Messenger).to execute_with_options(username: 'slack_username')
expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once execute_service
end
end end
it "calls #{service_name} API for issue events" do context 'push events' do
chat_service.execute(@issues_sample_data) let(:data) { Gitlab::DataBuilder::Push.build_sample(project, user) }
expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once it "calls #{service_name} API for push events" do
end execute_service
it "calls #{service_name} API for merge requests events" do expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once
chat_service.execute(@merge_sample_data) end
expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once context 'with event channel' do
end let(:chat_service_params) { { push_channel: 'random' } }
it "calls #{service_name} API for wiki page events" do it 'uses the right channel for push event' do
chat_service.execute(@wiki_page_sample_data) expect(Slack::Messenger).to execute_with_options(channel: ['random'])
expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once execute_service
end
end
end end
it "calls #{service_name} API for deployment events" do context 'issue events' do
deployment_event_data = { object_kind: 'deployment' } let_it_be(:issue) { create(:issue) }
let(:data) { issue.to_hook_data(user) }
chat_service.execute(deployment_event_data) it "calls #{service_name} API for issue events" do
execute_service
expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once
end end
it 'uses the username as an option for slack when configured' do context 'whith event channel' do
allow(chat_service).to receive(:username).and_return(username) let(:chat_service_params) { { issue_channel: 'random' } }
expect(Slack::Messenger).to execute_with_options(username: username) it 'uses the right channel for issue event' do
expect(Slack::Messenger).to execute_with_options(channel: ['random'])
chat_service.execute(data) execute_service
end end
it 'uses the channel as an option when it is configured' do context 'for confidential issues' do
allow(chat_service).to receive(:channel).and_return(channel) before_all do
expect(Slack::Messenger).to execute_with_options(channel: [channel]) issue.update!(confidential: true)
chat_service.execute(data) end
end
it 'falls back to issue channel' do
expect(Slack::Messenger).to execute_with_options(channel: ['random'])
execute_service
end
context "event channels" do context 'and confidential_issue_channel is defined' do
it "uses the right channel for push event" do let(:chat_service_params) { { issue_channel: 'random', confidential_issue_channel: 'confidential' } }
chat_service.update!(push_channel: "random")
expect(Slack::Messenger).to execute_with_options(channel: ['random']) it 'uses the confidential issue channel when it is defined' do
expect(Slack::Messenger).to execute_with_options(channel: ['confidential'])
chat_service.execute(data) execute_service
end
end
end
end end
end
it "uses the right channel for merge request event" do context 'merge request events' do
chat_service.update!(merge_request_channel: "random") let_it_be(:merge_request) { create(:merge_request) }
let(:data) { merge_request.to_hook_data(user) }
expect(Slack::Messenger).to execute_with_options(channel: ['random']) it "calls #{service_name} API for merge requests events" do
execute_service
chat_service.execute(@merge_sample_data) expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once
end end
it "uses the right channel for issue event" do context 'with event channel' do
chat_service.update!(issue_channel: "random") let(:chat_service_params) { { merge_request_channel: 'random' } }
expect(Slack::Messenger).to execute_with_options(channel: ['random']) it 'uses the right channel for merge request event' do
expect(Slack::Messenger).to execute_with_options(channel: ['random'])
chat_service.execute(@issues_sample_data) execute_service
end
end end
end
context 'for confidential issues' do context 'wiki page events' do
let(:issue_service_options) { { title: 'Secret', confidential: true } } 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') }
it "uses confidential issue channel" do
chat_service.update!(confidential_issue_channel: 'confidential')
expect(Slack::Messenger).to execute_with_options(channel: ['confidential']) it "calls #{service_name} API for wiki page events" do
execute_service
chat_service.execute(@issues_sample_data) expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once
end end
it 'falls back to issue channel' do context 'with event channel' do
chat_service.update!(issue_channel: 'fallback_channel') let(:chat_service_params) { { wiki_page_channel: 'random' } }
expect(Slack::Messenger).to execute_with_options(channel: ['fallback_channel']) it 'uses the right channel for wiki event' do
expect(Slack::Messenger).to execute_with_options(channel: ['random'])
chat_service.execute(@issues_sample_data) execute_service
end end
end end
end
it "uses the right channel for wiki event" do context 'deployment events' do
chat_service.update!(wiki_page_channel: "random") let_it_be(:deployment) { create(:deployment) }
let(:data) { Gitlab::DataBuilder::Deployment.build(deployment) }
expect(Slack::Messenger).to execute_with_options(channel: ['random']) it "calls #{service_name} API for deployment events" do
execute_service
chat_service.execute(@wiki_page_sample_data) expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once
end end
end
context "note event" do context 'note event' do
let(:issue_note) do let_it_be(:issue_note) { create(:note_on_issue, project: project, note: "issue note") }
create(:note_on_issue, project: project, note: "issue note") let(:data) { Gitlab::DataBuilder::Note.build(issue_note, user) }
end
it "calls #{service_name} API for note events" do
execute_service
it "uses the right channel" do expect(WebMock).to have_requested(:post, stubbed_resolved_hostname).once
chat_service.update!(note_channel: "random") end
note_data = Gitlab::DataBuilder::Note.build(issue_note, user) context 'with event channel' do
let(:chat_service_params) { { note_channel: 'random' } }
it 'uses the right channel' do
expect(Slack::Messenger).to execute_with_options(channel: ['random']) expect(Slack::Messenger).to execute_with_options(channel: ['random'])
chat_service.execute(note_data) execute_service
end end
context 'for confidential notes' do context 'for confidential notes' do
before do before_all do
issue_note.noteable.update!(confidential: true) issue_note.update!(confidential: true)
end end
it "uses confidential channel" do it 'falls back to note channel' do
chat_service.update!(confidential_note_channel: "confidential") expect(Slack::Messenger).to execute_with_options(channel: ['random'])
note_data = Gitlab::DataBuilder::Note.build(issue_note, user)
expect(Slack::Messenger).to execute_with_options(channel: ['confidential'])
chat_service.execute(note_data) execute_service
end end
it 'falls back to note channel' do context 'and confidential_note_channel is defined' do
chat_service.update!(note_channel: "fallback_channel") let(:chat_service_params) { { note_channel: 'random', confidential_note_channel: 'confidential' } }
note_data = Gitlab::DataBuilder::Note.build(issue_note, user)
expect(Slack::Messenger).to execute_with_options(channel: ['fallback_channel']) it 'uses confidential channel' do
expect(Slack::Messenger).to execute_with_options(channel: ['confidential'])
chat_service.execute(note_data) execute_service
end
end end
end end
end end
......
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