]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Merged revisions 84604 via svnmerge from
authorAntoine Pitrou <solipsis@pitrou.net>
Tue, 7 Sep 2010 21:46:05 +0000 (21:46 +0000)
committerAntoine Pitrou <solipsis@pitrou.net>
Tue, 7 Sep 2010 21:46:05 +0000 (21:46 +0000)
svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r84604 | antoine.pitrou | 2010-09-07 23:43:31 +0200 (mar., 07 sept. 2010) | 3 lines

  Also catch some gaierrors
........

Lib/test/test_support.py

index 32ff970f7dc0521c6c450a5eab2e2006bf1e0e75..744b9d5927c8b9c40574555070209ce194c78bbb 100644 (file)
@@ -760,16 +760,25 @@ def transient_internet(resource_name, timeout=30.0, errnos=()):
         ('ENETUNREACH', 101),
         ('ETIMEDOUT', 110),
     ]
+    default_gai_errnos = [
+        ('EAI_NONAME', -2),
+        ('EAI_NODATA', -5),
+    ]
 
     denied = ResourceDenied("Resource '%s' is not available" % resource_name)
     captured_errnos = errnos
+    gai_errnos = []
     if not captured_errnos:
         captured_errnos = [getattr(errno, name, num)
                            for (name, num) in default_errnos]
+        gai_errnos = [getattr(socket, name, num)
+                      for (name, num) in default_gai_errnos]
 
     def filter_error(err):
+        n = getattr(err, 'errno', None)
         if (isinstance(err, socket.timeout) or
-            getattr(err, 'errno', None) in captured_errnos):
+            (isinstance(err, socket.gaierror) and n in gai_errnos) or
+            n in captured_errnos):
             if not verbose:
                 sys.stderr.write(denied.args[0] + "\n")
             raise denied