|
@@ -56,66 +56,6 @@ describe EmailMxValidator do
|
|
|
expect(user.errors).to have_received(:add)
|
|
|
end
|
|
|
|
|
|
- it 'adds an error if the A record is blacklisted' do
|
|
|
- EmailDomainBlock.create!(domain: 'alternate-example.com', ips: ['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(:getresources).with('example.com', Resolv::DNS::Resource::IN::AAAA).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 AAAA record is blacklisted' do
|
|
|
- EmailDomainBlock.create!(domain: 'alternate-example.com', ips: ['fd00::1'])
|
|
|
- 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(:getresources).with('example.com', Resolv::DNS::Resource::IN::AAAA).and_return([double(address: 'fd00::1')])
|
|
|
- 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 of the MX record is blacklisted' do
|
|
|
- EmailDomainBlock.create!(domain: 'mail.other-domain.com', ips: ['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('example.com', Resolv::DNS::Resource::IN::AAAA).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(:getresources).with('mail.example.com', Resolv::DNS::Resource::IN::AAAA).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 AAAA record of the MX record is blacklisted' do
|
|
|
- EmailDomainBlock.create!(domain: 'mail.other-domain.com', ips: ['fd00::2'])
|
|
|
- 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('example.com', Resolv::DNS::Resource::IN::AAAA).and_return([])
|
|
|
- allow(resolver).to receive(:getresources).with('mail.example.com', Resolv::DNS::Resource::IN::A).and_return([])
|
|
|
- allow(resolver).to receive(:getresources).with('mail.example.com', Resolv::DNS::Resource::IN::AAAA).and_return([double(address: 'fd00::2')])
|
|
|
- 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: 'mail.example.com')
|
|
|
resolver = double
|