FIX: Redeeming an invitation fails if inviter has been destroyed.

This commit is contained in:
Guo Xiang Tan 2016-07-13 11:58:31 +08:00
parent 15a46d419f
commit 973a7c9d3a
2 changed files with 34 additions and 3 deletions

View File

@ -112,8 +112,10 @@ InviteRedeemer = Struct.new(:invite, :username, :name) do
end end
def notify_invitee def notify_invitee
invite.invited_by.notifications.create(notification_type: Notification.types[:invitee_accepted], if inviter = invite.invited_by
data: {display_username: invited_user.username}.to_json) inviter.notifications.create(notification_type: Notification.types[:invitee_accepted],
data: {display_username: invited_user.username}.to_json)
end
end end
def delete_duplicate_invites def delete_duplicate_invites

View File

@ -2,8 +2,9 @@ require 'rails_helper'
describe InviteRedeemer do describe InviteRedeemer do
describe '#create_for_email' do describe '#create_user_from_invite' do
let(:user) { InviteRedeemer.create_user_from_invite(Fabricate(:invite, email: 'walter.white@email.com'), 'walter', 'Walter White') } let(:user) { InviteRedeemer.create_user_from_invite(Fabricate(:invite, email: 'walter.white@email.com'), 'walter', 'Walter White') }
it "should be created correctly" do it "should be created correctly" do
expect(user.username).to eq('walter') expect(user.username).to eq('walter')
expect(user.name).to eq('Walter White') expect(user.name).to eq('Walter White')
@ -11,4 +12,32 @@ describe InviteRedeemer do
expect(user.email).to eq('walter.white@email.com') expect(user.email).to eq('walter.white@email.com')
end end
end end
describe "#redeem" do
let(:invite) { Fabricate(:invite) }
let(:name) { 'john snow' }
let(:username) { 'kingofthenorth' }
let(:invite_redeemer) { InviteRedeemer.new(invite, username, name) }
it "should redeem the invite" do
inviter = invite.invited_by
user = invite_redeemer.redeem
expect(user.name).to eq(name)
expect(user.username).to eq(username)
expect(user.invited_by).to eq(inviter)
expect(inviter.notifications.count).to eq(1)
end
it "should not blow up if invited_by user has been removed" do
invite.invited_by.destroy!
invite.reload
user = invite_redeemer.redeem
expect(user.name).to eq(name)
expect(user.username).to eq(username)
expect(user.invited_by).to eq(nil)
end
end
end end