Add specs for system note and email when all discussions are resolved
This commit is contained in:
parent
e257200459
commit
9d9b7212bc
3 changed files with 111 additions and 0 deletions
19
spec/mailers/emails/merge_requests_spec.rb
Normal file
19
spec/mailers/emails/merge_requests_spec.rb
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
require 'email_spec'
|
||||||
|
require 'mailers/shared/notify'
|
||||||
|
|
||||||
|
describe Notify, "merge request notifications" do
|
||||||
|
include EmailSpec::Matchers
|
||||||
|
|
||||||
|
describe "#resolved_all_discussions_email" do
|
||||||
|
let(:user) { create(:user) }
|
||||||
|
let(:merge_request) { create(:merge_request) }
|
||||||
|
let(:current_user) { create(:user) }
|
||||||
|
|
||||||
|
subject { Notify.resolved_all_discussions_email(user.id, merge_request.id, current_user.id) }
|
||||||
|
|
||||||
|
it "includes the name of the resolver" do
|
||||||
|
expect(subject).to have_body_text current_user.name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,46 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe MergeRequests::AllDiscussionsResolvedService, services: true do
|
||||||
|
let(:merge_request) { create(:merge_request) }
|
||||||
|
let(:user) { create(:user) }
|
||||||
|
let(:project) { merge_request.project }
|
||||||
|
subject { described_class.new(project, user) }
|
||||||
|
|
||||||
|
describe "#execute" do
|
||||||
|
context "when not all discussions are resolved" do
|
||||||
|
before do
|
||||||
|
allow(merge_request).to receive(:discussions_resolved?).and_return(false)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "doesn't add a system note" do
|
||||||
|
expect(SystemNoteService).not_to receive(:resolve_all_discussions)
|
||||||
|
|
||||||
|
subject.execute(merge_request)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "doesn't send a notification email" do
|
||||||
|
expect_any_instance_of(NotificationService).not_to receive(:resolve_all_discussions)
|
||||||
|
|
||||||
|
subject.execute(merge_request)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "when all discussions are resolved" do
|
||||||
|
before do
|
||||||
|
allow(merge_request).to receive(:discussions_resolved?).and_return(true)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "adds a system note" do
|
||||||
|
expect(SystemNoteService).to receive(:resolve_all_discussions).with(merge_request, project, user)
|
||||||
|
|
||||||
|
subject.execute(merge_request)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "sends a notification email" do
|
||||||
|
expect_any_instance_of(NotificationService).to receive(:resolve_all_discussions).with(merge_request, user)
|
||||||
|
|
||||||
|
subject.execute(merge_request)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -1004,6 +1004,52 @@ describe NotificationService, services: true do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "#resolve_all_discussions" do
|
||||||
|
it do
|
||||||
|
notification.resolve_all_discussions(merge_request, @u_disabled)
|
||||||
|
|
||||||
|
should_email(merge_request.assignee)
|
||||||
|
should_email(@u_watcher)
|
||||||
|
should_email(@u_participant_mentioned)
|
||||||
|
should_email(@subscriber)
|
||||||
|
should_email(@watcher_and_subscriber)
|
||||||
|
should_email(@u_guest_watcher)
|
||||||
|
should_not_email(@unsubscriber)
|
||||||
|
should_not_email(@u_participating)
|
||||||
|
should_not_email(@u_disabled)
|
||||||
|
should_not_email(@u_lazy_participant)
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'participating' do
|
||||||
|
context 'by assignee' do
|
||||||
|
before do
|
||||||
|
merge_request.update_attribute(:assignee, @u_lazy_participant)
|
||||||
|
notification.resolve_all_discussions(merge_request, @u_disabled)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { should_email(@u_lazy_participant) }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'by note' do
|
||||||
|
let!(:note) { create(:note_on_issue, noteable: merge_request, project_id: project.id, note: 'anything', author: @u_lazy_participant) }
|
||||||
|
|
||||||
|
before { notification.resolve_all_discussions(merge_request, @u_disabled) }
|
||||||
|
|
||||||
|
it { should_email(@u_lazy_participant) }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'by author' do
|
||||||
|
before do
|
||||||
|
merge_request.author = @u_lazy_participant
|
||||||
|
merge_request.save
|
||||||
|
notification.resolve_all_discussions(merge_request, @u_disabled)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { should_email(@u_lazy_participant) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'Projects' do
|
describe 'Projects' do
|
||||||
|
|
Loading…
Reference in a new issue