]> git.ipfire.org Git - thirdparty/dnspython.git/commitdiff
more resolver override coverage
authorBob Halley <halley@dnspython.org>
Thu, 18 Jun 2020 14:22:31 +0000 (07:22 -0700)
committerBob Halley <halley@dnspython.org>
Thu, 18 Jun 2020 14:22:31 +0000 (07:22 -0700)
tests/test_resolver_override.py

index 06f1ac1c1219d67c646522bf1fd0c0ef8e1af4be..e20681e1a450441060be428da01eac5cde7f5ac7 100644 (file)
@@ -18,32 +18,111 @@ except socket.gaierror:
 
 @unittest.skipIf(not _network_available, "Internet not reachable")
 class OverrideSystemResolverTestCase(unittest.TestCase):
+
+    def setUp(self):
+        self.res = dns.resolver.Resolver()
+        self.res.nameservers = ['8.8.8.8']
+        self.res.cache = dns.resolver.LRUCache()
+        dns.resolver.override_system_resolver(self.res)
+
+    def tearDown(self):
+        dns.resolver.restore_system_resolver()
+        self.res = None
+
     def test_override(self):
-        res = dns.resolver.Resolver()
-        res.nameservers = ['8.8.8.8']
-        res.cache = dns.resolver.LRUCache()
-        dns.resolver.override_system_resolver(res)
         self.assertTrue(socket.getaddrinfo is
                         dns.resolver._getaddrinfo)
         socket.gethostbyname('www.dnspython.org')
-        answer = res.cache.get((dns.name.from_text('www.dnspython.org.'),
+        answer = self.res.cache.get((dns.name.from_text('www.dnspython.org.'),
                                 dns.rdatatype.A, dns.rdataclass.IN))
         self.assertTrue(answer is not None)
-        res.cache.flush()
+        self.res.cache.flush()
         socket.gethostbyname_ex('www.dnspython.org')
-        answer = res.cache.get((dns.name.from_text('www.dnspython.org.'),
+        answer = self.res.cache.get((dns.name.from_text('www.dnspython.org.'),
                                 dns.rdatatype.A, dns.rdataclass.IN))
         self.assertTrue(answer is not None)
-        res.cache.flush()
+        self.res.cache.flush()
         socket.getfqdn('8.8.8.8')
-        answer = res.cache.get((dns.name.from_text('8.8.8.8.in-addr.arpa.'),
-                                dns.rdatatype.PTR, dns.rdataclass.IN))
+        answer = self.res.cache.get(
+            (dns.name.from_text('8.8.8.8.in-addr.arpa.'),
+             dns.rdatatype.PTR, dns.rdataclass.IN))
         self.assertTrue(answer is not None)
-        res.cache.flush()
+        self.res.cache.flush()
         socket.gethostbyaddr('8.8.8.8')
-        answer = res.cache.get((dns.name.from_text('8.8.8.8.in-addr.arpa.'),
-                                dns.rdatatype.PTR, dns.rdataclass.IN))
+        answer = self.res.cache.get(
+            (dns.name.from_text('8.8.8.8.in-addr.arpa.'),
+             dns.rdatatype.PTR, dns.rdataclass.IN))
         self.assertTrue(answer is not None)
+        # restoring twice is harmless, so we restore now instead of
+        # waiting for tearDown so we can assert that it worked
         dns.resolver.restore_system_resolver()
         self.assertTrue(socket.getaddrinfo is
                         dns.resolver._original_getaddrinfo)
+
+    def equivalent_info(self, a, b):
+        if len(a) != len(b):
+            return False
+        for x in a:
+            if x not in b:
+                return False
+        return True
+
+    def equivalent(self, *args, **kwargs):
+        a = socket.getaddrinfo(*args, **kwargs)
+        b = dns.resolver._original_getaddrinfo(*args, **kwargs)
+        return self.equivalent_info(a, b)
+
+    def test_basic_getaddrinfo(self):
+        self.assertTrue(self.equivalent('dns.google', 53, socket.AF_INET,
+                                        socket.SOCK_DGRAM))
+        self.assertTrue(self.equivalent('dns.google', 53, socket.AF_INET6,
+                                        socket.SOCK_DGRAM))
+        self.assertTrue(self.equivalent('dns.google', None, socket.AF_UNSPEC,
+                                        socket.SOCK_DGRAM))
+        self.assertTrue(self.equivalent('8.8.8.8', 53, socket.AF_INET,
+                                        socket.SOCK_DGRAM))
+        self.assertTrue(self.equivalent('2001:4860:4860::8888', 53,
+                                        socket.AF_INET6, socket.SOCK_DGRAM))
+        self.assertTrue(self.equivalent('8.8.8.8', 53, socket.AF_INET,
+                                        socket.SOCK_DGRAM,
+                                        flags=socket.AI_NUMERICHOST))
+        self.assertTrue(self.equivalent('2001:4860:4860::8888', 53,
+                                        socket.AF_INET6, socket.SOCK_DGRAM,
+                                        flags=socket.AI_NUMERICHOST))
+
+    def test_getaddrinfo_nxdomain(self):
+        try:
+            socket.getaddrinfo('nxdomain.dnspython.org.', 53)
+            self.assertTrue(False) # should not happen!
+        except socket.gaierror as e:
+            self.assertEqual(e.errno, socket.EAI_NONAME)
+
+    def test_getaddrinfo_service(self):
+        a = socket.getaddrinfo('dns.google', 'domain')
+        b = socket.getaddrinfo('dns.google', 53)
+        self.assertTrue(self.equivalent_info(a, b))
+        try:
+            socket.getaddrinfo('dns.google', 'domain',
+                               flags=socket.AI_NUMERICSERV)
+            self.assertTrue(False) # should not happen!
+        except socket.gaierror as e:
+            self.assertEqual(e.errno, socket.EAI_NONAME)
+
+    def test_getfqdn(self):
+        b = socket.getfqdn('www.dnspython.org')
+        # we do this now because python's original getfqdn calls
+        # gethostbyaddr() and we don't want it to call us!
+        dns.resolver.restore_system_resolver()
+        a = dns.resolver._original_getfqdn('www.dnspython.org')
+        self.assertEqual(dns.name.from_text(a), dns.name.from_text(b))
+
+    def test_gethostbyaddr(self):
+        a = dns.resolver._original_gethostbyaddr('8.8.8.8')
+        b = socket.gethostbyaddr('8.8.8.8')
+        # We only test elements 0 and 2 as we don't set aliases currently!
+        self.assertEqual(a[0], b[0])
+        self.assertEqual(a[2], b[2])
+        a = dns.resolver._original_gethostbyaddr('2001:4860:4860::8888')
+        b = socket.gethostbyaddr('2001:4860:4860::8888')
+        self.assertEqual(a[0], b[0])
+        self.assertEqual(a[2], b[2])