Commit 5d24ea16 authored by Doug Stull's avatar Doug Stull

Decouple acceptance of invitations from query

- should not mutate and ask as part of if query
parent e90e6d49
...@@ -6,7 +6,8 @@ module AcceptsPendingInvitations ...@@ -6,7 +6,8 @@ module AcceptsPendingInvitations
def accept_pending_invitations def accept_pending_invitations
return unless resource.active_for_authentication? return unless resource.active_for_authentication?
if resource.accept_pending_invitations!.any? if resource.pending_invitations.load.any?
resource.accept_pending_invitations!
clear_stored_location_for_resource clear_stored_location_for_resource
after_pending_invitations_hook after_pending_invitations_hook
end end
......
...@@ -22,7 +22,7 @@ class Email < ApplicationRecord ...@@ -22,7 +22,7 @@ class Email < ApplicationRecord
self.reconfirmable = false # currently email can't be changed, no need to reconfirm self.reconfirmable = false # currently email can't be changed, no need to reconfirm
delegate :username, :can?, to: :user delegate :username, :can?, :pending_invitations, :accept_pending_invitations!, to: :user
def email=(value) def email=(value)
write_attribute(:email, value.downcase.strip) write_attribute(:email, value.downcase.strip)
...@@ -32,10 +32,6 @@ class Email < ApplicationRecord ...@@ -32,10 +32,6 @@ class Email < ApplicationRecord
self.errors.add(:email, 'has already been taken') if User.exists?(email: self.email) self.errors.add(:email, 'has already been taken') if User.exists?(email: self.email)
end end
def accept_pending_invitations!
user.accept_pending_invitations!
end
def validate_email_format def validate_email_format
self.errors.add(:email, I18n.t(:invalid, scope: 'valid_email.validations.email')) unless ValidateEmail.valid?(self.email) self.errors.add(:email, I18n.t(:invalid, scope: 'valid_email.validations.email')) unless ValidateEmail.valid?(self.email)
end end
......
...@@ -4,13 +4,25 @@ require 'spec_helper' ...@@ -4,13 +4,25 @@ require 'spec_helper'
RSpec.describe 'AdditionalEmailToExistingAccount' do RSpec.describe 'AdditionalEmailToExistingAccount' do
describe 'add secondary email associated with account' do describe 'add secondary email associated with account' do
let(:user) { create(:user) } let_it_be(:user) { create(:user) }
let_it_be(:email) { create(:email, user: user) }
it 'verifies confirmation of additional email' do before do
sign_in(user) sign_in(user)
end
it 'verifies confirmation of additional email' do
visit email_confirmation_path(confirmation_token: email.confirmation_token)
expect(page).to have_content 'Your email address has been successfully confirmed.'
end
it 'accepts any pending invites for an email confirmation' do
member = create(:group_member, :invited, invite_email: email.email)
email = create(:email, user: user)
visit email_confirmation_path(confirmation_token: email.confirmation_token) visit email_confirmation_path(confirmation_token: email.confirmation_token)
expect(member.reload.user).to eq(user)
expect(page).to have_content 'Your email address has been successfully confirmed.' expect(page).to have_content 'Your email address has been successfully confirmed.'
end end
end end
......
...@@ -44,12 +44,11 @@ RSpec.describe Email do ...@@ -44,12 +44,11 @@ RSpec.describe Email do
end end
end end
describe 'delegation' do describe 'delegations' do
let(:user) { create(:user) } it { is_expected.to delegate_method(:can?).to(:user) }
it { is_expected.to delegate_method(:username).to(:user) }
it 'delegates to :user' do it { is_expected.to delegate_method(:pending_invitations).to(:user) }
expect(build(:email, user: user).username).to eq user.username it { is_expected.to delegate_method(:accept_pending_invitations!).to(:user) }
end
end end
describe 'Devise emails' do describe 'Devise emails' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment