mirror of
https://github.com/github/octodns.git
synced 2024-05-11 05:55:00 +00:00
Merge remote-tracking branch 'origin' into secrets
This commit is contained in:
168
tests/test_octodns_processor_trailing_dots.py
Normal file
168
tests/test_octodns_processor_trailing_dots.py
Normal file
@@ -0,0 +1,168 @@
|
||||
#
|
||||
#
|
||||
#
|
||||
|
||||
from unittest import TestCase
|
||||
|
||||
from octodns.processor.trailing_dots import (
|
||||
EnsureTrailingDots,
|
||||
_ensure_trailing_dots,
|
||||
_no_trailing_dot,
|
||||
)
|
||||
from octodns.record import Record
|
||||
from octodns.zone import Zone
|
||||
|
||||
|
||||
def _find(zone, name):
|
||||
return next(r for r in zone.records if r.name == name)
|
||||
|
||||
|
||||
class EnsureTrailingDotsTest(TestCase):
|
||||
def test_cname(self):
|
||||
etd = EnsureTrailingDots('test')
|
||||
|
||||
zone = Zone('unit.tests.', [])
|
||||
has = Record.new(
|
||||
zone,
|
||||
'has',
|
||||
{'type': 'CNAME', 'ttl': 42, 'value': 'absolute.target.'},
|
||||
)
|
||||
zone.add_record(has)
|
||||
missing = Record.new(
|
||||
zone,
|
||||
'missing',
|
||||
{'type': 'CNAME', 'ttl': 42, 'value': 'relative.target'},
|
||||
lenient=True,
|
||||
)
|
||||
zone.add_record(missing)
|
||||
|
||||
got = etd.process_source_zone(zone, None)
|
||||
self.assertEqual('absolute.target.', _find(got, 'has').value)
|
||||
self.assertEqual('relative.target.', _find(got, 'missing').value)
|
||||
|
||||
# HACK: this should never be done to records outside of specific testing
|
||||
# situations like this
|
||||
has._type = 'ALIAS'
|
||||
missing._type = 'ALIAS'
|
||||
got = etd.process_source_zone(zone, None)
|
||||
self.assertEqual('absolute.target.', _find(got, 'has').value)
|
||||
self.assertEqual('relative.target.', _find(got, 'missing').value)
|
||||
|
||||
has._type = 'DNAME'
|
||||
missing._type = 'DNAME'
|
||||
got = etd.process_source_zone(zone, None)
|
||||
self.assertEqual('absolute.target.', _find(got, 'has').value)
|
||||
self.assertEqual('relative.target.', _find(got, 'missing').value)
|
||||
|
||||
def test_mx(self):
|
||||
etd = EnsureTrailingDots('test')
|
||||
|
||||
zone = Zone('unit.tests.', [])
|
||||
record = Record.new(
|
||||
zone,
|
||||
'record',
|
||||
{
|
||||
'type': 'MX',
|
||||
'ttl': 42,
|
||||
'values': [
|
||||
{'preference': 1, 'exchange': 'absolute.target.'},
|
||||
{'preference': 1, 'exchange': 'relative.target'},
|
||||
],
|
||||
},
|
||||
lenient=True,
|
||||
)
|
||||
zone.add_record(record)
|
||||
|
||||
# processor
|
||||
got = etd.process_source_zone(zone, None)
|
||||
got = next(iter(got.records))
|
||||
self.assertEqual(
|
||||
['absolute.target.', 'relative.target.'],
|
||||
[v.exchange for v in got.values],
|
||||
)
|
||||
|
||||
# specifically test the checker
|
||||
self.assertTrue(_no_trailing_dot(record, 'exchange'))
|
||||
# specifically test the fixer
|
||||
self.assertEqual(
|
||||
['absolute.target.', 'relative.target.'],
|
||||
[
|
||||
v.exchange
|
||||
for v in _ensure_trailing_dots(record, 'exchange').values
|
||||
],
|
||||
)
|
||||
# this time with nothing that matches
|
||||
record.values[1].exchange = 'also.absolute.'
|
||||
self.assertFalse(_no_trailing_dot(record, 'exchange'))
|
||||
|
||||
def test_ns(self):
|
||||
etd = EnsureTrailingDots('test')
|
||||
|
||||
zone = Zone('unit.tests.', [])
|
||||
record = Record.new(
|
||||
zone,
|
||||
'record',
|
||||
{
|
||||
'type': 'NS',
|
||||
'ttl': 42,
|
||||
'values': ['absolute.target.', 'relative.target'],
|
||||
},
|
||||
lenient=True,
|
||||
)
|
||||
zone.add_record(record)
|
||||
|
||||
got = etd.process_source_zone(zone, None)
|
||||
got = next(iter(got.records))
|
||||
self.assertEqual(['absolute.target.', 'relative.target.'], got.values)
|
||||
|
||||
# HACK: this should never be done to records outside of specific testing
|
||||
# situations like this
|
||||
record._type = 'PTR'
|
||||
got = etd.process_source_zone(zone, None)
|
||||
got = next(iter(got.records))
|
||||
self.assertEqual(['absolute.target.', 'relative.target.'], got.values)
|
||||
|
||||
def test_srv(self):
|
||||
etd = EnsureTrailingDots('test')
|
||||
|
||||
zone = Zone('unit.tests.', [])
|
||||
record = Record.new(
|
||||
zone,
|
||||
'record',
|
||||
{
|
||||
'type': 'SRV',
|
||||
'ttl': 42,
|
||||
'values': [
|
||||
{
|
||||
'priority': 1,
|
||||
'weight': 1,
|
||||
'port': 99,
|
||||
'target': 'absolute.target.',
|
||||
},
|
||||
{
|
||||
'priority': 1,
|
||||
'weight': 1,
|
||||
'port': 99,
|
||||
'target': 'relative.target',
|
||||
},
|
||||
],
|
||||
},
|
||||
lenient=True,
|
||||
)
|
||||
zone.add_record(record)
|
||||
|
||||
# processor
|
||||
got = etd.process_source_zone(zone, None)
|
||||
got = next(iter(got.records))
|
||||
self.assertEqual(
|
||||
['absolute.target.', 'relative.target.'],
|
||||
[v.target for v in got.values],
|
||||
)
|
||||
|
||||
# specifically test the checker
|
||||
self.assertTrue(_no_trailing_dot(record, 'target'))
|
||||
# specifically test the fixer
|
||||
self.assertEqual(
|
||||
['absolute.target.', 'relative.target.'],
|
||||
[v.target for v in _ensure_trailing_dots(record, 'target').values],
|
||||
)
|
||||
Reference in New Issue
Block a user