Merge pull request #4277 from davexunit/feature/4069
Background actual mailing when sending invitations
This commit is contained in:
commit
07083c7076
5 changed files with 29 additions and 36 deletions
|
|
@ -58,9 +58,10 @@ class InvitationsController < ApplicationController
|
|||
session[:invalid_email_invites] = invalid_emails
|
||||
|
||||
unless valid_emails.empty?
|
||||
inviter = EmailInviter.new(valid_emails.join(','), current_user,
|
||||
params[:email_inviter])
|
||||
inviter.send!
|
||||
Workers::Mail::InviteEmail.perform_async(valid_emails.join(','),
|
||||
current_user.id,
|
||||
params[:email_inviter])
|
||||
|
||||
end
|
||||
|
||||
if emails.empty?
|
||||
|
|
|
|||
|
|
@ -4,14 +4,11 @@
|
|||
|
||||
module Workers
|
||||
module Mail
|
||||
class InviteUserByEmail < Base
|
||||
class InviteEmail < Base
|
||||
sidekiq_options queue: :mail
|
||||
|
||||
def perform(invite_id)
|
||||
invite = Invitation.find(invite_id)
|
||||
I18n.with_locale(invite.language) do
|
||||
invite.send!
|
||||
end
|
||||
def perform(emails, inviter_id, options={})
|
||||
EmailInviter.new(emails, User.find(inviter_id), options).send!
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
@ -26,7 +26,7 @@ describe InvitationsController do
|
|||
end
|
||||
|
||||
it 'does not create an EmailInviter' do
|
||||
EmailInviter.should_not_receive(:new)
|
||||
Workers::Mail::InviteEmail.should_not_receive(:perform_async)
|
||||
post :create, @invite
|
||||
end
|
||||
|
||||
|
|
@ -47,10 +47,9 @@ describe InvitationsController do
|
|||
@invite = {'email_inviter' => {'message' => "test", 'emails' => @emails}}
|
||||
end
|
||||
|
||||
it 'creates an EmailInviter' do
|
||||
it 'creates an InviteEmail worker' do
|
||||
inviter = stub(:emails => [@emails], :send! => true)
|
||||
EmailInviter.should_receive(:new).with(@invite['email_inviter']['emails'], @user, @invite['email_inviter']).
|
||||
and_return(inviter)
|
||||
Workers::Mail::InviteEmail.should_receive(:perform_async).with(@invite['email_inviter']['emails'], @user.id, @invite['email_inviter'])
|
||||
post :create, @invite
|
||||
end
|
||||
|
||||
|
|
@ -72,8 +71,8 @@ describe InvitationsController do
|
|||
@invite = {'email_inviter' => {'message' => "test", 'emails' => @emails}}
|
||||
end
|
||||
|
||||
it 'does not create an EmailInviter' do
|
||||
EmailInviter.should_not_receive(:new)
|
||||
it 'does not create an InviteEmail worker' do
|
||||
Workers::Mail::InviteEmail.should_not_receive(:perform_async)
|
||||
post :create, @invite
|
||||
end
|
||||
|
||||
|
|
@ -98,10 +97,9 @@ describe InvitationsController do
|
|||
@valid_emails + ',' + @invalid_emails}}
|
||||
end
|
||||
|
||||
it 'creates an EmailInviter' do
|
||||
it 'creates an InviteEmail worker' do
|
||||
inviter = stub(:emails => [@emails], :send! => true)
|
||||
EmailInviter.should_receive(:new).with(@valid_emails, @user, @invite['email_inviter']).
|
||||
and_return(inviter)
|
||||
Workers::Mail::InviteEmail.should_receive(:perform_async).with(@valid_emails, @user.id, @invite['email_inviter'])
|
||||
post :create, @invite
|
||||
end
|
||||
|
||||
|
|
|
|||
14
spec/workers/mail/invite_email_spec.rb
Normal file
14
spec/workers/mail/invite_email_spec.rb
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe Workers::Mail::InviteEmail do
|
||||
let(:emails) { ['foo@bar.com', 'baz@bar.com'] }
|
||||
let(:message) { 'get over here!' }
|
||||
let(:email_inviter) { double('EmailInviter') }
|
||||
|
||||
it 'creates a new email inviter' do
|
||||
EmailInviter.should_receive(:new).with(emails, alice, message: message)
|
||||
.and_return(email_inviter)
|
||||
email_inviter.should_receive(:send!)
|
||||
Workers::Mail::InviteEmail.new.perform(emails, alice, message: message)
|
||||
end
|
||||
end
|
||||
|
|
@ -1,17 +0,0 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe Workers::Mail::InviteUserByEmail do
|
||||
before do
|
||||
@sender = alice
|
||||
@email = 'bob@bob.com'
|
||||
@aspect = alice.aspects.first
|
||||
@message = 'invite message'
|
||||
end
|
||||
|
||||
it 'calls invite_user with email param' do
|
||||
invitation = Invitation.create(:sender => @sender, :identifier => @email, :service => "email", :aspect => @aspect, :message => @message)
|
||||
invitation.should_receive(:send!)
|
||||
Invitation.stub(:find).and_return(invitation)
|
||||
Workers::Mail::InviteUserByEmail.new.perform(invitation.id)
|
||||
end
|
||||
end
|
||||
Loading…
Reference in a new issue