Use IPv4 only to avoid IP address collision (#7030)
authorAndrew Svetlov <andrew.svetlov@gmail.com>
Mon, 21 May 2018 12:06:26 +0000 (15:06 +0300)
committerGitHub <noreply@github.com>
Mon, 21 May 2018 12:06:26 +0000 (15:06 +0300)
Lib/test/test_asyncio/test_base_events.py

index a14c5569353974a487eaabb3e461c8f7df7db019..8566a9d5504f2b70fd3b99edc52c5cfb40675717 100644 (file)
@@ -1848,15 +1848,13 @@ class BaseLoopSockSendfileTests(test_utils.TestCase):
     def prepare(self):
         sock = self.make_socket()
         proto = self.MyProto(self.loop)
-        af = socket.AF_UNSPEC if support.IPV6_ENABLED else socket.AF_INET
         server = self.run_loop(self.loop.create_server(
-            lambda: proto, support.HOST, 0, family=af))
-        port = server.sockets[0].getsockname()[1]
+            lambda: proto, support.HOST, 0, family=socket.AF_INET))
+        addr = server.sockets[0].getsockname()
 
         for _ in range(10):
             try:
-                self.run_loop(self.loop.sock_connect(sock,
-                                                     (support.HOST, port)))
+                self.run_loop(self.loop.sock_connect(sock, addr))
             except OSError:
                 self.run_loop(asyncio.sleep(0.5))
                 continue
@@ -1864,7 +1862,7 @@ class BaseLoopSockSendfileTests(test_utils.TestCase):
                 break
         else:
             # One last try, so we get the exception
-            self.run_loop(self.loop.sock_connect(sock, (support.HOST, port)))
+            self.run_loop(self.loop.sock_connect(sock, addr))
 
         def cleanup():
             server.close()