Improve e-mail MX validator and add tests (#9489)
parent
3f12c07ff5
commit
dbb1ee269f
@ -0,0 +1,75 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
require 'rails_helper' |
||||
|
||||
describe EmailMxValidator do |
||||
describe '#validate' do |
||||
let(:user) { double(email: 'foo@example.com', errors: double(add: nil)) } |
||||
|
||||
it 'adds an error if there are no DNS records for the e-mail domain' do |
||||
resolver = double |
||||
|
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::MX).and_return([]) |
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::A).and_return([]) |
||||
allow(resolver).to receive(:timeouts=).and_return(nil) |
||||
allow(Resolv::DNS).to receive(:open).and_yield(resolver) |
||||
|
||||
subject.validate(user) |
||||
expect(user.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'adds an error if a MX record exists but does not lead to an IP' do |
||||
resolver = double |
||||
|
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::MX).and_return([double(exchange: 'mail.example.com')]) |
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::A).and_return([]) |
||||
allow(resolver).to receive(:getresources).with('mail.example.com', Resolv::DNS::Resource::IN::A).and_return([]) |
||||
allow(resolver).to receive(:timeouts=).and_return(nil) |
||||
allow(Resolv::DNS).to receive(:open).and_yield(resolver) |
||||
|
||||
subject.validate(user) |
||||
expect(user.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'adds an error if the A record is blacklisted' do |
||||
EmailDomainBlock.create!(domain: '1.2.3.4') |
||||
resolver = double |
||||
|
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::MX).and_return([]) |
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::A).and_return([double(address: '1.2.3.4')]) |
||||
allow(resolver).to receive(:timeouts=).and_return(nil) |
||||
allow(Resolv::DNS).to receive(:open).and_yield(resolver) |
||||
|
||||
subject.validate(user) |
||||
expect(user.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'adds an error if the MX record is blacklisted' do |
||||
EmailDomainBlock.create!(domain: '2.3.4.5') |
||||
resolver = double |
||||
|
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::MX).and_return([double(exchange: 'mail.example.com')]) |
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::A).and_return([]) |
||||
allow(resolver).to receive(:getresources).with('mail.example.com', Resolv::DNS::Resource::IN::A).and_return([double(address: '2.3.4.5')]) |
||||
allow(resolver).to receive(:timeouts=).and_return(nil) |
||||
allow(Resolv::DNS).to receive(:open).and_yield(resolver) |
||||
|
||||
subject.validate(user) |
||||
expect(user.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'adds an error if the MX hostname is blacklisted' do |
||||
EmailDomainBlock.create!(domain: 'mail.example.com') |
||||
resolver = double |
||||
|
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::MX).and_return([double(exchange: 'mail.example.com')]) |
||||
allow(resolver).to receive(:getresources).with('example.com', Resolv::DNS::Resource::IN::A).and_return([]) |
||||
allow(resolver).to receive(:getresources).with('mail.example.com', Resolv::DNS::Resource::IN::A).and_return([double(address: '2.3.4.5')]) |
||||
allow(resolver).to receive(:timeouts=).and_return(nil) |
||||
allow(Resolv::DNS).to receive(:open).and_yield(resolver) |
||||
|
||||
subject.validate(user) |
||||
expect(user.errors).to have_received(:add) |
||||
end |
||||
end |
||||
end |
Loading…
Reference in new issue