Spec coverage and refactor of digest mailer worker (#2961)
parent
7ac092513c
commit
d142544159
@ -0,0 +1,36 @@ |
|||||||
|
# frozen_string_literal: true |
||||||
|
|
||||||
|
require 'rails_helper' |
||||||
|
|
||||||
|
describe DigestMailerWorker do |
||||||
|
describe 'perform' do |
||||||
|
let(:user) { Fabricate(:user, last_emailed_at: 3.days.ago) } |
||||||
|
|
||||||
|
context 'for a user who receives digests' do |
||||||
|
it 'sends the email' do |
||||||
|
service = double(deliver_now!: nil) |
||||||
|
allow(NotificationMailer).to receive(:digest).and_return(service) |
||||||
|
update_user_digest_setting(true) |
||||||
|
described_class.perform_async(user.id) |
||||||
|
|
||||||
|
expect(NotificationMailer).to have_received(:digest) |
||||||
|
expect(user.reload.last_emailed_at).to be_within(1).of(Time.now.utc) |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
context 'for a user who does not receive digests' do |
||||||
|
it 'does not send the email' do |
||||||
|
allow(NotificationMailer).to receive(:digest) |
||||||
|
update_user_digest_setting(false) |
||||||
|
described_class.perform_async(user.id) |
||||||
|
|
||||||
|
expect(NotificationMailer).not_to have_received(:digest) |
||||||
|
expect(user.last_emailed_at).to be_within(1).of(3.days.ago) |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
def update_user_digest_setting(value) |
||||||
|
user.settings['notification_emails'] = user.settings['notification_emails'].merge('digest' => value) |
||||||
|
end |
||||||
|
end |
||||||
|
end |
Loading…
Reference in new issue