|
|
|
@ -11,14 +11,15 @@ RSpec.describe BlacklistedEmailValidator, type: :validator do |
|
|
|
|
|
|
|
|
|
before do |
|
|
|
|
allow(user).to receive(:valid_invitation?).and_return(false) |
|
|
|
|
allow_any_instance_of(described_class).to receive(:blocked_email_provider?) { blocked_email } |
|
|
|
|
allow(EmailDomainBlock).to receive(:block?) { blocked_email } |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
context 'when e-mail provider is blocked' do |
|
|
|
|
let(:blocked_email) { true } |
|
|
|
|
|
|
|
|
|
it 'adds error' do |
|
|
|
|
expect(subject).to have_received(:add).with(:email, :blocked) |
|
|
|
|
described_class.new.validate(user) |
|
|
|
|
expect(errors).to have_received(:add).with(:email, :blocked).once |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
@ -26,7 +27,8 @@ RSpec.describe BlacklistedEmailValidator, type: :validator do |
|
|
|
|
let(:blocked_email) { false } |
|
|
|
|
|
|
|
|
|
it 'does not add errors' do |
|
|
|
|
expect(subject).to_not have_received(:add).with(:email, :blocked) |
|
|
|
|
described_class.new.validate(user) |
|
|
|
|
expect(errors).to_not have_received(:add) |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
context 'when canonical e-mail is blocked' do |
|
|
|
@ -37,7 +39,8 @@ RSpec.describe BlacklistedEmailValidator, type: :validator do |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
it 'adds error' do |
|
|
|
|
expect(subject).to have_received(:add).with(:email, :taken) |
|
|
|
|
described_class.new.validate(user) |
|
|
|
|
expect(errors).to have_received(:add).with(:email, :taken).once |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|