Improve notification service tests

This commit is contained in:
Dmitriy Zaporozhets 2013-03-28 12:24:04 +02:00
parent f49a2ac0df
commit c04120c1c5
3 changed files with 22 additions and 11 deletions

View file

@ -13,7 +13,7 @@ module Emails
mail(to: recipient(recipient_id), subject: subject("changed issue ##{@issue.id}", @issue.title)) mail(to: recipient(recipient_id), subject: subject("changed issue ##{@issue.id}", @issue.title))
end end
def close_issue_email(recipient_id, issue_id, updated_by_user_id) def closed_issue_email(recipient_id, issue_id, updated_by_user_id)
@issue = Issue.find issue_id @issue = Issue.find issue_id
@project = @issue.project @project = @issue.project
@updated_by = User.find updated_by_user_id @updated_by = User.find updated_by_user_id

View file

@ -33,7 +33,7 @@ class NotificationService
# * project team members with notification level higher then Participating # * project team members with notification level higher then Participating
# #
def close_issue(issue, current_user) def close_issue(issue, current_user)
close_resource_email(issue, current_user, 'close_issue_email') close_resource_email(issue, current_user, 'closed_issue_email')
end end
# When we reassign an issue we should send next emails: # When we reassign an issue we should send next emails:

View file

@ -28,9 +28,20 @@ describe NotificationService do
end end
describe :new_issue do describe :new_issue do
it 'should sent email to issue assignee' do it do
Notify.should_receive(:new_issue_email).with(issue.id) should_email(issue.assignee_id)
notification.new_issue(issue, nil) should_email(@u_watcher.id)
should_not_email(@u_participating.id)
should_not_email(@u_disabled.id)
notification.new_issue(issue, @u_disabled)
end
def should_email(user_id)
Notify.should_receive(:new_issue_email).with(user_id, issue.id)
end
def should_not_email(user_id)
Notify.should_not_receive(:new_issue_email).with(user_id, issue.id)
end end
end end
@ -65,11 +76,11 @@ describe NotificationService do
end end
def should_email(user_id) def should_email(user_id)
Notify.should_receive(:closed_issue_email).with(user_id, issue.id, issue.assignee_id) Notify.should_receive(:closed_issue_email).with(user_id, issue.id, @u_disabled.id)
end end
def should_not_email(user_id) def should_not_email(user_id)
Notify.should_not_receive(:closed_issue_email).with(user_id, issue.id, issue.assignee_id) Notify.should_not_receive(:closed_issue_email).with(user_id, issue.id, @u_disabled.id)
end end
end end
end end
@ -91,11 +102,11 @@ describe NotificationService do
end end
def should_email(user_id) def should_email(user_id)
Notify.should_receive(:new_merge_request_email).with(merge_request.id) Notify.should_receive(:new_merge_request_email).with(user_id, merge_request.id)
end end
def should_not_email(user_id) def should_not_email(user_id)
Notify.should_not_receive(:new_merge_request_email).with(merge_request.id) Notify.should_not_receive(:new_merge_request_email).with(user_id, merge_request.id)
end end
end end
@ -127,11 +138,11 @@ describe NotificationService do
end end
def should_email(user_id) def should_email(user_id)
Notify.should_receive(:closed_merge_request_email).with(user_id, merge_request.id) Notify.should_receive(:closed_merge_request_email).with(user_id, merge_request.id, @u_disabled.id)
end end
def should_not_email(user_id) def should_not_email(user_id)
Notify.should_not_receive(:closed_merge_request_email).with(user_id, merge_request.id) Notify.should_not_receive(:closed_merge_request_email).with(user_id, merge_request.id, @u_disabled.id)
end end
end end