Fix couple of moments in HangoutsChatService and its spec

This commit is contained in:
Kukovskii Vladimir 2018-07-14 19:19:04 +09:00
parent 6cfb0a9e94
commit d64196ddb3
3 changed files with 29 additions and 23 deletions

View file

@ -44,20 +44,22 @@ class HangoutsChatService < ChatNotificationService
private private
def notify(message, opts) def notify(message, opts)
simple_text = compose_simple_message(message) simple_text = parse_simple_text_message(message)
HangoutsChat::Sender.new(webhook).simple(simple_text) HangoutsChat::Sender.new(webhook).simple(simple_text)
end end
def compose_simple_message(message) def parse_simple_text_message(message)
header = message.pretext header = message.pretext
return header if message.attachments.empty? return header if message.attachments.empty?
title = fetch_attachment_title(message.attachments.first) attachment = message.attachments.first
body = message.attachments.first[:text] title = format_attachment_title(attachment)
body = attachment[:text]
[header, title, body].compact.join("\n") [header, title, body].compact.join("\n")
end end
def fetch_attachment_title(attachment) def format_attachment_title(attachment)
return attachment[:title] unless attachment[:title_link] return attachment[:title] unless attachment[:title_link]
"<#{attachment[:title_link]}|#{attachment[:title]}>" "<#{attachment[:title_link]}|#{attachment[:title]}>"

View file

@ -1,5 +1,5 @@
--- ---
title: Add Hangouts Chat integration title: Add Hangouts Chat integration
merge_request: merge_request: 20290
author: Kukovskii Vladimir author: Kukovskii Vladimir
type: added type: added

View file

@ -1,9 +1,6 @@
require 'spec_helper' require 'spec_helper'
describe HangoutsChatService do describe HangoutsChatService do
let(:chat_service) { described_class.new }
let(:webhook_url) { 'https://example.gitlab.com/' }
describe 'Associations' do describe 'Associations' do
it { is_expected.to belong_to :project } it { is_expected.to belong_to :project }
it { is_expected.to have_one :service_hook } it { is_expected.to have_one :service_hook }
@ -31,9 +28,10 @@ describe HangoutsChatService do
describe '#execute' do describe '#execute' do
let(:user) { create(:user) } let(:user) { create(:user) }
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
let(:webhook_url) { 'https://example.gitlab.com/' }
before do before do
allow(chat_service).to receive_messages( allow(subject).to receive_messages(
project: project, project: project,
project_id: project.id, project_id: project.id,
service_hook: true, service_hook: true,
@ -45,7 +43,7 @@ describe HangoutsChatService do
shared_examples 'Hangouts Chat service' do shared_examples 'Hangouts Chat service' do
it 'calls Hangouts Chat API' do it 'calls Hangouts Chat API' do
chat_service.execute(sample_data) subject.execute(sample_data)
expect(WebMock).to have_requested(:post, webhook_url).once expect(WebMock).to have_requested(:post, webhook_url).once
end end
@ -61,22 +59,28 @@ describe HangoutsChatService do
it 'specifies the webhook when it is configured' do it 'specifies the webhook when it is configured' do
expect(HangoutsChat::Sender).to receive(:new).with(webhook_url).and_return(double(:hangouts_chat_service).as_null_object) expect(HangoutsChat::Sender).to receive(:new).with(webhook_url).and_return(double(:hangouts_chat_service).as_null_object)
chat_service.execute(sample_data) subject.execute(sample_data)
end
it 'sends the simple text message to the Hangouts Chat API' do
subject.execute(sample_data)
expect(WebMock).to have_requested(:post, webhook_url).once
.with { |req| req.body =~ /\A{"text":.+}\Z/ }
end end
context 'with not default branch' do context 'with not default branch' do
let(:sample_data) do let(:sample_data) do
ref = "#{Gitlab::Git::BRANCH_REF_PREFIX}test" Gitlab::DataBuilder::Push.build(project, user, nil, nil, 'not-the-default-branch')
Gitlab::DataBuilder::Push.build(project, user, nil, nil, ref, [])
end end
context 'when notify_only_default_branch enabled' do context 'when notify_only_default_branch enabled' do
before do before do
chat_service.notify_only_default_branch = true subject.notify_only_default_branch = true
end end
it 'does not call the Hangouts Chat API' do it 'does not call the Hangouts Chat API' do
result = chat_service.execute(sample_data) result = subject.execute(sample_data)
expect(result).to be_falsy expect(result).to be_falsy
end end
@ -84,7 +88,7 @@ describe HangoutsChatService do
context 'when notify_only_default_branch disabled' do context 'when notify_only_default_branch disabled' do
before do before do
chat_service.notify_only_default_branch = false subject.notify_only_default_branch = false
end end
it_behaves_like 'Hangouts Chat service' it_behaves_like 'Hangouts Chat service'
@ -172,7 +176,7 @@ describe HangoutsChatService do
it_behaves_like 'Hangouts Chat service' it_behaves_like 'Hangouts Chat service'
end end
context 'wiht snippet comment' do context 'with snippet comment' do
let(:note) do let(:note) do
create(:note_on_project_snippet, project: project, create(:note_on_project_snippet, project: project,
note: 'snippet note') note: 'snippet note')
@ -201,7 +205,7 @@ describe HangoutsChatService do
context 'with default notify_only_broken_pipelines' do context 'with default notify_only_broken_pipelines' do
it 'does not call Hangouts Chat API' do it 'does not call Hangouts Chat API' do
result = chat_service.execute(sample_data) result = subject.execute(sample_data)
expect(result).to be_falsy expect(result).to be_falsy
end end
@ -209,7 +213,7 @@ describe HangoutsChatService do
context 'when notify_only_broken_pipelines is false' do context 'when notify_only_broken_pipelines is false' do
before do before do
chat_service.notify_only_broken_pipelines = false subject.notify_only_broken_pipelines = false
end end
it_behaves_like 'Hangouts Chat service' it_behaves_like 'Hangouts Chat service'
@ -223,11 +227,11 @@ describe HangoutsChatService do
context 'when notify_only_default_branch enabled' do context 'when notify_only_default_branch enabled' do
before do before do
chat_service.notify_only_default_branch = true subject.notify_only_default_branch = true
end end
it 'does not call the Hangouts Chat API' do it 'does not call the Hangouts Chat API' do
result = chat_service.execute(sample_data) result = subject.execute(sample_data)
expect(result).to be_falsy expect(result).to be_falsy
end end
@ -235,7 +239,7 @@ describe HangoutsChatService do
context 'when notify_only_default_branch disabled' do context 'when notify_only_default_branch disabled' do
before do before do
chat_service.notify_only_default_branch = false subject.notify_only_default_branch = false
end end
it_behaves_like 'Hangouts Chat service' it_behaves_like 'Hangouts Chat service'