|
23 | 23 | expect(result.address_strs).to eq(['foo.bar.com:42']) |
24 | 24 | end |
25 | 25 | end |
| 26 | + |
| 27 | + exampleSrvName = ['i-love-rb', 'i-love-rb.mongodb', 'i-love-ruby.mongodb.io']; |
| 28 | + exampleHostName = [ |
| 29 | + 'rb-00.i-love-rb', |
| 30 | + 'rb-00.i-love-rb.mongodb', |
| 31 | + 'i-love-ruby-00.mongodb.io' |
| 32 | + ]; |
| 33 | + exampleHostNameThatDoNotMatchParent = [ |
| 34 | + 'rb-00.i-love-rb-a-little', |
| 35 | + 'rb-00.i-love-rb-a-little.mongodb', |
| 36 | + 'i-love-ruby-00.evil-mongodb.io' |
| 37 | + ]; |
| 38 | + |
| 39 | + (0..2).each do |i| |
| 40 | + context "when srvName has #{i+1} part#{i != 0 ? 's' : ''}" do |
| 41 | + let(:srv_name) { exampleSrvName[i] } |
| 42 | + let(:host_name) { exampleHostName[i] } |
| 43 | + let(:mismatched_host_name) { exampleHostNameThatDoNotMatchParent[i] } |
| 44 | + |
| 45 | + context 'when address does not match parent domain' do |
| 46 | + it 'raises MismatchedDomain error' do |
| 47 | + record = double('record').tap do |record| |
| 48 | + allow(record).to receive(:target).and_return(mismatched_host_name) |
| 49 | + allow(record).to receive(:port).and_return(42) |
| 50 | + allow(record).to receive(:ttl).and_return(1) |
| 51 | + end |
| 52 | + |
| 53 | + expect { |
| 54 | + result = described_class.new(srv_name) |
| 55 | + result.add_record(record) |
| 56 | + }.to raise_error(Mongo::Error::MismatchedDomain) |
| 57 | + end |
| 58 | + end |
| 59 | + |
| 60 | + context 'when address matches parent domain' do |
| 61 | + it 'adds the record' do |
| 62 | + record = double('record').tap do |record| |
| 63 | + allow(record).to receive(:target).and_return(host_name) |
| 64 | + allow(record).to receive(:port).and_return(42) |
| 65 | + allow(record).to receive(:ttl).and_return(1) |
| 66 | + end |
| 67 | + |
| 68 | + result = described_class.new(srv_name) |
| 69 | + result.add_record(record) |
| 70 | + |
| 71 | + expect(result.address_strs).to eq([host_name + ':42']) |
| 72 | + end |
| 73 | + end |
| 74 | + |
| 75 | + if i < 2 |
| 76 | + context 'when the address is less than 3 parts' do |
| 77 | + it 'does not accept address if it does not contain an extra domain level' do |
| 78 | + record = double('record').tap do |record| |
| 79 | + allow(record).to receive(:target).and_return(srv_name) |
| 80 | + allow(record).to receive(:port).and_return(42) |
| 81 | + allow(record).to receive(:ttl).and_return(1) |
| 82 | + end |
| 83 | + |
| 84 | + expect { |
| 85 | + result = described_class.new(srv_name) |
| 86 | + result.add_record(record) |
| 87 | + }.to raise_error(Mongo::Error::MismatchedDomain) |
| 88 | + end |
| 89 | + end |
| 90 | + end |
| 91 | + end |
| 92 | + end |
26 | 93 | end |
27 | 94 |
|
28 | 95 | describe '#normalize_hostname' do |
|
0 commit comments