mirror of
				https://github.com/github/octodns.git
				synced 2024-05-11 05:55:00 +00:00 
			
		
		
		
	Merge remote-tracking branch 'origin/master' into configurable-geo-healthcheck
This commit is contained in:
		| @@ -11,8 +11,8 @@ from unittest import TestCase | ||||
| from mock import patch | ||||
|  | ||||
| from octodns.record import Create, Delete, Record, Update | ||||
| from octodns.provider.route53 import _Route53Record, Route53Provider, \ | ||||
|     _octal_replace | ||||
| from octodns.provider.route53 import Route53Provider, _Route53GeoDefault, \ | ||||
|     _Route53GeoRecord, _Route53Record, _octal_replace | ||||
| from octodns.zone import Zone | ||||
|  | ||||
| from helpers import GeoProvider | ||||
| @@ -531,16 +531,6 @@ class TestRoute53Provider(TestCase): | ||||
|         change_resource_record_sets_params = { | ||||
|             'ChangeBatch': { | ||||
|                 'Changes': [{ | ||||
|                     'Action': 'DELETE', | ||||
|                     'ResourceRecordSet': { | ||||
|                         'GeoLocation': {'ContinentCode': 'OC'}, | ||||
|                         'Name': 'simple.unit.tests.', | ||||
|                         'ResourceRecords': [{'Value': '3.2.3.4'}, | ||||
|                                             {'Value': '4.2.3.4'}], | ||||
|                         'SetIdentifier': 'OC', | ||||
|                         'TTL': 61, | ||||
|                         'Type': 'A'} | ||||
|                 }, { | ||||
|                     'Action': 'DELETE', | ||||
|                     'ResourceRecordSet': { | ||||
|                         'GeoLocation': {'CountryCode': '*'}, | ||||
| @@ -550,6 +540,16 @@ class TestRoute53Provider(TestCase): | ||||
|                         'SetIdentifier': 'default', | ||||
|                         'TTL': 61, | ||||
|                         'Type': 'A'} | ||||
|                 }, { | ||||
|                     'Action': 'DELETE', | ||||
|                     'ResourceRecordSet': { | ||||
|                         'GeoLocation': {'ContinentCode': 'OC'}, | ||||
|                         'Name': 'simple.unit.tests.', | ||||
|                         'ResourceRecords': [{'Value': '3.2.3.4'}, | ||||
|                                             {'Value': '4.2.3.4'}], | ||||
|                         'SetIdentifier': 'OC', | ||||
|                         'TTL': 61, | ||||
|                         'Type': 'A'} | ||||
|                 }, { | ||||
|                     'Action': 'CREATE', | ||||
|                     'ResourceRecordSet': { | ||||
| @@ -708,8 +708,7 @@ class TestRoute53Provider(TestCase): | ||||
|                 'AF': ['4.2.3.4'], | ||||
|             } | ||||
|         }) | ||||
|         id = provider._get_health_check_id(record, 'AF', record.geo['AF'], | ||||
|                                            True) | ||||
|         id = provider.get_health_check_id(record, 'AF', record.geo['AF'], True) | ||||
|         self.assertEquals('42', id) | ||||
|  | ||||
|     def test_health_check_create(self): | ||||
| @@ -782,13 +781,12 @@ class TestRoute53Provider(TestCase): | ||||
|         }) | ||||
|  | ||||
|         # if not allowed to create returns none | ||||
|         id = provider._get_health_check_id(record, 'AF', record.geo['AF'], | ||||
|                                            False) | ||||
|         id = provider.get_health_check_id(record, 'AF', record.geo['AF'], | ||||
|                                           False) | ||||
|         self.assertFalse(id) | ||||
|  | ||||
|         # when allowed to create we do | ||||
|         id = provider._get_health_check_id(record, 'AF', record.geo['AF'], | ||||
|                                            True) | ||||
|         id = provider.get_health_check_id(record, 'AF', record.geo['AF'], True) | ||||
|         self.assertEquals('42', id) | ||||
|         stubber.assert_no_pending_responses() | ||||
|  | ||||
| @@ -1201,10 +1199,6 @@ class TestRoute53Provider(TestCase): | ||||
|         self.assertEquals(1, len(extra)) | ||||
|         stubber.assert_no_pending_responses() | ||||
|  | ||||
|     def test_route_53_record(self): | ||||
|         # Just make sure it doesn't blow up | ||||
|         _Route53Record('foo.unit.tests.', 'A', 30).__repr__() | ||||
|  | ||||
|     def _get_test_plan(self, max_changes): | ||||
|  | ||||
|         provider = Route53Provider('test', 'abc', '123', max_changes) | ||||
| @@ -1332,3 +1326,71 @@ class TestRoute53Provider(TestCase): | ||||
|             'TTL': 30, | ||||
|             'Type': 'TXT', | ||||
|         })) | ||||
|  | ||||
|  | ||||
| class TestRoute53Records(TestCase): | ||||
|  | ||||
|     def test_route53_record(self): | ||||
|         existing = Zone('unit.tests.', []) | ||||
|         record_a = Record.new(existing, '', { | ||||
|             'geo': { | ||||
|                 'NA-US': ['2.2.2.2', '3.3.3.3'], | ||||
|                 'OC': ['4.4.4.4', '5.5.5.5'] | ||||
|             }, | ||||
|             'ttl': 99, | ||||
|             'type': 'A', | ||||
|             'values': ['9.9.9.9'] | ||||
|         }) | ||||
|         a = _Route53Record(None, record_a, False) | ||||
|         self.assertEquals(a, a) | ||||
|         b = _Route53Record(None, Record.new(existing, '', | ||||
|                                             {'ttl': 32, 'type': 'A', | ||||
|                                              'values': ['8.8.8.8', | ||||
|                                                         '1.1.1.1']}), | ||||
|                            False) | ||||
|         self.assertEquals(b, b) | ||||
|         c = _Route53Record(None, Record.new(existing, 'other', | ||||
|                                             {'ttl': 99, 'type': 'A', | ||||
|                                              'values': ['9.9.9.9']}), | ||||
|                            False) | ||||
|         self.assertEquals(c, c) | ||||
|         d = _Route53Record(None, Record.new(existing, '', | ||||
|                                             {'ttl': 42, 'type': 'CNAME', | ||||
|                                              'value': 'foo.bar.'}), | ||||
|                            False) | ||||
|         self.assertEquals(d, d) | ||||
|  | ||||
|         # Same fqdn & type is same record | ||||
|         self.assertEquals(a, b) | ||||
|         # Same name & different type is not the same | ||||
|         self.assertNotEquals(a, d) | ||||
|         # Different name & same type is not the same | ||||
|         self.assertNotEquals(a, c) | ||||
|  | ||||
|         # Same everything, different class is not the same | ||||
|         e = _Route53GeoDefault(None, record_a, False) | ||||
|         self.assertNotEquals(a, e) | ||||
|  | ||||
|         class DummyProvider(object): | ||||
|  | ||||
|             def get_health_check_id(self, *args, **kwargs): | ||||
|                 return None | ||||
|  | ||||
|         provider = DummyProvider() | ||||
|         f = _Route53GeoRecord(provider, record_a, 'NA-US', | ||||
|                               record_a.geo['NA-US'], False) | ||||
|         self.assertEquals(f, f) | ||||
|         g = _Route53GeoRecord(provider, record_a, 'OC', | ||||
|                               record_a.geo['OC'], False) | ||||
|         self.assertEquals(g, g) | ||||
|  | ||||
|         # Geo and non-geo are not the same, using Geo as primary to get it's | ||||
|         # __cmp__ | ||||
|         self.assertNotEquals(f, a) | ||||
|         # Same everything, different geo's is not the same | ||||
|         self.assertNotEquals(f, g) | ||||
|  | ||||
|         # Make sure it doesn't blow up | ||||
|         a.__repr__() | ||||
|         e.__repr__() | ||||
|         f.__repr__() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user