Browse Source

[2967] slightly better way of overriding the default mock SOA rdata

Paul Selkirk 11 years ago
parent
commit
f623694374
1 changed files with 32 additions and 37 deletions
  1. 32 37
      src/bin/zonemgr/tests/zonemgr_test.py

+ 32 - 37
src/bin/zonemgr/tests/zonemgr_test.py

@@ -37,9 +37,6 @@ LOWERBOUND_RETRY = 5
 REFRESH_JITTER = 0.10
 RELOAD_JITTER = 0.75
 
-rdata_net = 'a.example.net. root.example.net. 2009073106 7200 3600 2419200 21600'
-rdata_org = 'a.example.org. root.example.org. 2009073112 7200 3600 2419200 21600'
-
 class ZonemgrTestException(Exception):
     pass
 
@@ -61,21 +58,19 @@ class FakeCCSession(isc.config.ConfigData, MockModuleCCSession):
 class MockDataSourceClient():
     '''A simple mock data source client.'''
     def find_zone(self, zone_name):
-        '''Mock version of find_zone().'''
+        '''Mock version of DataSourceClient.find_zone().'''
         return (isc.datasrc.DataSourceClient.SUCCESS, self)
 
     def find(self, name, rrtype, options=ZoneFinder.FIND_DEFAULT):
-        '''Mock ZoneFinder.find().
-
-        It returns the predefined SOA RRset to queries for SOA of the common
-        test zone name.  It also emulates some unusual cases for special
-        zone names.
-
-        '''
+        '''Mock version of ZoneFinder.find().'''
         if name == Name('example.net'):
-            rdata = Rdata(RRType.SOA, RRClass.IN, rdata_net)
+            rdata = Rdata(RRType.SOA, RRClass.IN,
+                          'a.example.net. root.example.net. 2009073106 ' +
+                          '7200 3600 2419200 21600')
         elif name == 'example.org.':
-            rdata = Rdata(RRType.SOA, RRClass.IN, rdata_org)
+            rdata = Rdata(RRType.SOA, RRClass.IN,
+                          'a.example.org. root.example.org. 2009073112 ' +
+                          '7200 3600 2419200 21600')
         else:
             return (ZoneFinder.NXDOMAIN, None, 0)
         rrset = RRset(name, RRClass.IN, RRType.SOA, RRTTL(3600))
@@ -83,21 +78,18 @@ class MockDataSourceClient():
         return (ZoneFinder.SUCCESS, rrset, 0)
 
 class MockDataSrcClientsMgr():
+    '''A simple mock data source client manager.'''
     def __init__(self):
-        # Default faked result of get_client_list, customizable by tests
-        self.found_datasrc_client_list = self
-
-        # Default faked result of find(), customizable by tests
-        self.found_datasrc_client = MockDataSourceClient()
+        self.datasrc_client = MockDataSourceClient()
 
     def get_client_list(self, rrclass):
-        return self.found_datasrc_client_list
+        return self
 
     def find(self, zone_name, want_exact_match, want_finder):
         """Pretending find method on the object returned by get_client_list"""
-        if issubclass(type(self.found_datasrc_client), Exception):
-            raise self.found_datasrc_client
-        return self.found_datasrc_client, None, None
+        if issubclass(type(self.datasrc_client), Exception):
+            raise self.datasrc_client
+        return self.datasrc_client, None, None
 
 class MyZonemgrRefresh(ZonemgrRefresh):
     def __init__(self):
@@ -229,14 +221,15 @@ class TestZonemgrRefresh(unittest.TestCase):
         self.assertRaises(KeyError, self.zone_refresh._get_zone_soa_rdata, ZONE_NAME_CLASS2_IN)
 
     def test_zonemgr_reload_zone(self):
-        global rdata_net
         soa_rdata = 'a.example.net. root.example.net. 2009073106 1800 900 2419200 21600'
-        # We need to restore this not to harm other tests
-        old_rdata_net = rdata_net
-        rdata_net = soa_rdata
+        def find(name, rrtype, options=ZoneFinder.FIND_DEFAULT):
+            rdata = Rdata(RRType.SOA, RRClass.IN, soa_rdata)
+            rrset = RRset(name, RRClass.IN, RRType.SOA, RRTTL(3600))
+            rrset.add_rdata(rdata)
+            return (ZoneFinder.SUCCESS, rrset, 0)
+        self.zone_refresh._datasrc_clients_mgr.datasrc_client.find = find
         self.zone_refresh.zonemgr_reload_zone(ZONE_NAME_CLASS1_IN)
         self.assertEqual(soa_rdata, self.zone_refresh._zonemgr_refresh_info[ZONE_NAME_CLASS1_IN]["zone_soa_rdata"])
-        rdata_net = old_rdata_net
 
     def test_get_zone_notifier_master(self):
         notify_master = "192.168.1.1"
@@ -308,12 +301,13 @@ class TestZonemgrRefresh(unittest.TestCase):
         self.assertRaises(ZonemgrTestException, self.zone_refresh._send_command, "Unknown", "Notify", None)
 
     def test_zonemgr_add_zone(self):
-        global rdata_net
         soa_rdata = 'a.example.net. root.example.net. 2009073106 1800 900 2419200 21600'
-        # This needs to be restored. The following test actually failed if we left
-        # this unclean
-        old_rdata_net = rdata_net
-        rdata_net = soa_rdata
+        def find(name, rrtype, options=ZoneFinder.FIND_DEFAULT):
+            rdata = Rdata(RRType.SOA, RRClass.IN, soa_rdata)
+            rrset = RRset(name, RRClass.IN, RRType.SOA, RRTTL(3600))
+            rrset.add_rdata(rdata)
+            return (ZoneFinder.SUCCESS, rrset, 0)
+        self.zone_refresh._datasrc_clients_mgr.datasrc_client.find = find
         time1 = time.time()
         self.zone_refresh._zonemgr_refresh_info = {}
         self.zone_refresh.zonemgr_add_zone(ZONE_NAME_CLASS1_IN)
@@ -327,7 +321,6 @@ class TestZonemgrRefresh(unittest.TestCase):
         zone_timeout = self.zone_refresh._zonemgr_refresh_info[ZONE_NAME_CLASS1_IN]["next_refresh_time"]
         self.assertTrue((time1 + 900 * (1 - self.zone_refresh._reload_jitter)) <= zone_timeout)
         self.assertTrue(zone_timeout <= time2 + 900)
-        rdata_net = old_rdata_net
 
         old_get_zone_soa = self.zone_refresh._get_zone_soa
         def get_zone_soa2(zone_name_class):
@@ -356,10 +349,13 @@ class TestZonemgrRefresh(unittest.TestCase):
                 ZONE_NAME_CLASS3_IN, "127.0.0.1"))
 
     def test_zone_refresh_success(self):
-        global rdata_net
         soa_rdata = 'a.example.net. root.example.net. 2009073106 1800 900 2419200 21600'
-        old_rdata_net = rdata_net
-        rdata_net = soa_rdata
+        def find(name, rrtype, options=ZoneFinder.FIND_DEFAULT):
+            rdata = Rdata(RRType.SOA, RRClass.IN, soa_rdata)
+            rrset = RRset(name, RRClass.IN, RRType.SOA, RRTTL(3600))
+            rrset.add_rdata(rdata)
+            return (ZoneFinder.SUCCESS, rrset, 0)
+        self.zone_refresh._datasrc_clients_mgr.datasrc_client.find = find
         time1 = time.time()
         self.zone_refresh._zonemgr_refresh_info[ZONE_NAME_CLASS1_IN]["zone_state"] = ZONE_REFRESHING
         self.zone_refresh.zone_refresh_success(ZONE_NAME_CLASS1_IN)
@@ -375,7 +371,6 @@ class TestZonemgrRefresh(unittest.TestCase):
         self.assertTrue(last_refresh_time <= time2)
         self.assertRaises(ZonemgrException, self.zone_refresh.zone_refresh_success, ("example.test.", "CH"))
         self.assertRaises(ZonemgrException, self.zone_refresh.zone_refresh_success, ZONE_NAME_CLASS3_IN)
-        rdata_net = old_rdata_net
 
     def test_zone_refresh_fail(self):
         soa_rdata = 'a.example.net. root.example.net. 2009073105 7200 3600 2419200 21600'