Commit 45b9cfc2 authored by Sean McGivern's avatar Sean McGivern

Merge branch 'sdesk_event_update' into 'master'

Move creation of event outside of mailer

See merge request gitlab-org/gitlab!64404
parents cb9e7bb6 bd1c870c
...@@ -20,9 +20,7 @@ module Emails ...@@ -20,9 +20,7 @@ module Emails
options = service_desk_options(email_sender, 'thank_you', @issue.external_author) options = service_desk_options(email_sender, 'thank_you', @issue.external_author)
.merge(subject: "Re: #{subject_base}") .merge(subject: "Re: #{subject_base}")
mail_new_thread(@issue, options).tap do mail_new_thread(@issue, options)
Gitlab::Metrics::BackgroundTransaction.current&.add_event(:service_desk_thank_you_email)
end
end end
def service_desk_new_note_email(issue_id, note_id, recipient) def service_desk_new_note_email(issue_id, note_id, recipient)
...@@ -33,9 +31,7 @@ module Emails ...@@ -33,9 +31,7 @@ module Emails
options = service_desk_options(email_sender, 'new_note', recipient) options = service_desk_options(email_sender, 'new_note', recipient)
.merge(subject: subject_base) .merge(subject: subject_base)
mail_answer_thread(@issue, options).tap do mail_answer_thread(@issue, options)
Gitlab::Metrics::BackgroundTransaction.current&.add_event(:service_desk_new_note_email)
end
end end
private private
......
...@@ -396,6 +396,7 @@ class NotificationService ...@@ -396,6 +396,7 @@ class NotificationService
recipients.each do |recipient| recipients.each do |recipient|
mailer.service_desk_new_note_email(issue.id, note.id, recipient).deliver_later mailer.service_desk_new_note_email(issue.id, note.id, recipient).deliver_later
Gitlab::Metrics::BackgroundTransaction.current&.add_event(:service_desk_new_note_email)
end end
end end
......
...@@ -96,6 +96,7 @@ module Gitlab ...@@ -96,6 +96,7 @@ module Gitlab
def send_thank_you_email def send_thank_you_email
Notify.service_desk_thank_you_email(@issue.id).deliver_later Notify.service_desk_thank_you_email(@issue.id).deliver_later
Gitlab::Metrics::BackgroundTransaction.current&.add_event(:service_desk_thank_you_email)
end end
def message_including_template def message_including_template
......
...@@ -50,6 +50,15 @@ RSpec.describe Gitlab::Email::Handler::ServiceDeskHandler do ...@@ -50,6 +50,15 @@ RSpec.describe Gitlab::Email::Handler::ServiceDeskHandler do
it 'sends thank you email' do it 'sends thank you email' do
expect { receiver.execute }.to have_enqueued_job.on_queue('mailers') expect { receiver.execute }.to have_enqueued_job.on_queue('mailers')
end end
it 'adds metric events for incoming and reply emails' do
metric_transaction = double('Gitlab::Metrics::WebTransaction', increment: true, observe: true)
allow(::Gitlab::Metrics::BackgroundTransaction).to receive(:current).and_return(metric_transaction)
expect(metric_transaction).to receive(:add_event).with(:receive_email_service_desk, anything)
expect(metric_transaction).to receive(:add_event).with(:service_desk_thank_you_email)
receiver.execute
end
end end
context 'when everything is fine' do context 'when everything is fine' do
......
...@@ -115,16 +115,6 @@ RSpec.describe Emails::ServiceDesk do ...@@ -115,16 +115,6 @@ RSpec.describe Emails::ServiceDesk do
end end
end end
shared_examples 'notification with metric event' do |event_type|
it 'adds metric event' do
metric_transaction = double('Gitlab::Metrics::WebTransaction', increment: true, observe: true)
allow(::Gitlab::Metrics::BackgroundTransaction).to receive(:current).and_return(metric_transaction)
expect(metric_transaction).to receive(:add_event).with(event_type)
subject.content_type
end
end
describe '.service_desk_thank_you_email' do describe '.service_desk_thank_you_email' do
let_it_be(:reply_in_subject) { true } let_it_be(:reply_in_subject) { true }
let_it_be(:default_text) do let_it_be(:default_text) do
...@@ -134,7 +124,6 @@ RSpec.describe Emails::ServiceDesk do ...@@ -134,7 +124,6 @@ RSpec.describe Emails::ServiceDesk do
subject { ServiceEmailClass.service_desk_thank_you_email(issue.id) } subject { ServiceEmailClass.service_desk_thank_you_email(issue.id) }
it_behaves_like 'read template from repository', 'thank_you' it_behaves_like 'read template from repository', 'thank_you'
it_behaves_like 'notification with metric event', :service_desk_thank_you_email
context 'handling template markdown' do context 'handling template markdown' do
context 'with a simple text' do context 'with a simple text' do
...@@ -175,7 +164,6 @@ RSpec.describe Emails::ServiceDesk do ...@@ -175,7 +164,6 @@ RSpec.describe Emails::ServiceDesk do
subject { ServiceEmailClass.service_desk_new_note_email(issue.id, note.id, email) } subject { ServiceEmailClass.service_desk_new_note_email(issue.id, note.id, email) }
it_behaves_like 'read template from repository', 'new_note' it_behaves_like 'read template from repository', 'new_note'
it_behaves_like 'notification with metric event', :service_desk_new_note_email
context 'handling template markdown' do context 'handling template markdown' do
context 'with a simple text' do context 'with a simple text' do
......
...@@ -376,41 +376,31 @@ RSpec.describe NotificationService, :mailer do ...@@ -376,41 +376,31 @@ RSpec.describe NotificationService, :mailer do
let(:subject) { NotificationService.new } let(:subject) { NotificationService.new }
let(:mailer) { double(deliver_later: true) } let(:mailer) { double(deliver_later: true) }
let(:issue) { create(:issue, author: User.support_bot) }
let(:project) { issue.project }
let(:note) { create(:note, noteable: issue, project: project) }
def should_email! shared_examples 'notification with exact metric events' do |number_of_events|
expect(Notify).to receive(:service_desk_new_note_email) it 'adds metric event' do
.with(issue.id, note.id, issue.external_author) metric_transaction = double('Gitlab::Metrics::WebTransaction', increment: true, observe: true)
allow(::Gitlab::Metrics::BackgroundTransaction).to receive(:current).and_return(metric_transaction)
expect(metric_transaction).to receive(:add_event).with(:service_desk_new_note_email).exactly(number_of_events).times
subject.new_note(note)
end
end end
def should_not_email! shared_examples 'no participants are notified' do
it 'does not send the email' do
expect(Notify).not_to receive(:service_desk_new_note_email) expect(Notify).not_to receive(:service_desk_new_note_email)
end
def execute!
subject.new_note(note) subject.new_note(note)
end end
def self.it_should_email! it_behaves_like 'notification with exact metric events', 0
it 'sends the email' do
should_email!
execute!
end
end
def self.it_should_not_email!
it 'doesn\'t send the email' do
should_not_email!
execute!
end
end end
let(:issue) { create(:issue, author: User.support_bot) } it_behaves_like 'no participants are notified'
let(:project) { issue.project }
let(:note) { create(:note, noteable: issue, project: project) }
context 'do not exist' do
it_should_not_email!
end
context 'do exist and note not confidential' do context 'do exist and note not confidential' do
let!(:issue_email_participant) { issue.issue_email_participants.create!(email: 'service.desk@example.com') } let!(:issue_email_participant) { issue.issue_email_participants.create!(email: 'service.desk@example.com') }
...@@ -420,7 +410,14 @@ RSpec.describe NotificationService, :mailer do ...@@ -420,7 +410,14 @@ RSpec.describe NotificationService, :mailer do
project.update!(service_desk_enabled: true) project.update!(service_desk_enabled: true)
end end
it_should_email! it 'sends the email' do
expect(Notify).to receive(:service_desk_new_note_email)
.with(issue.id, note.id, issue.external_author)
subject.new_note(note)
end
it_behaves_like 'notification with exact metric events', 1
end end
context 'do exist and note is confidential' do context 'do exist and note is confidential' do
...@@ -432,7 +429,7 @@ RSpec.describe NotificationService, :mailer do ...@@ -432,7 +429,7 @@ RSpec.describe NotificationService, :mailer do
project.update!(service_desk_enabled: true) project.update!(service_desk_enabled: true)
end end
it_should_not_email! it_behaves_like 'no participants are notified'
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