mirror of
https://github.com/discourse/discourse.git
synced 2024-11-27 09:33:37 +08:00
493d437e79
* Remove outdated option
04078317ba
* Use the non-globally exposed RSpec syntax
https://github.com/rspec/rspec-core/pull/2803
* Use the non-globally exposed RSpec syntax, cont
https://github.com/rspec/rspec-core/pull/2803
* Comply to strict predicate matchers
See:
- https://github.com/rspec/rspec-expectations/pull/1195
- https://github.com/rspec/rspec-expectations/pull/1196
- https://github.com/rspec/rspec-expectations/pull/1277
39 lines
1.2 KiB
Ruby
39 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe Jobs::InviteEmail do
|
|
|
|
describe '.execute' do
|
|
|
|
it 'raises an error when the invite_id is missing' do
|
|
expect { Jobs::InviteEmail.new.execute({}) }.to raise_error(Discourse::InvalidParameters)
|
|
end
|
|
|
|
context 'with an invite id' do
|
|
|
|
let (:mailer) { Mail::Message.new(to: 'eviltrout@test.domain') }
|
|
fab!(:invite) { Fabricate(:invite) }
|
|
|
|
it 'delegates to the test mailer' do
|
|
Email::Sender.any_instance.expects(:send)
|
|
InviteMailer.expects(:send_invite).with(invite, anything).returns(mailer)
|
|
Jobs::InviteEmail.new.execute(invite_id: invite.id)
|
|
end
|
|
|
|
it "aborts without error when the invite doesn't exist anymore" do
|
|
invite.destroy
|
|
InviteMailer.expects(:send_invite).never
|
|
Jobs::InviteEmail.new.execute(invite_id: invite.id)
|
|
end
|
|
|
|
it "updates invite emailed_status" do
|
|
invite.emailed_status = Invite.emailed_status_types[:pending]
|
|
invite.save!
|
|
Jobs::InviteEmail.new.execute(invite_id: invite.id)
|
|
|
|
invite.reload
|
|
expect(invite.emailed_status).to eq(Invite.emailed_status_types[:sent])
|
|
end
|
|
end
|
|
end
|
|
end
|