[Python-checkins] cpython: Close #20682: Fix UNIX sockets tests of test_asyncio on Mac OS X Tiger

victor.stinner python-checkins at python.org
Wed Feb 19 18:10:49 CET 2014


http://hg.python.org/cpython/rev/e6016fffc894
changeset: 89282:e6016fffc894
user: Victor Stinner <victor.stinner at gmail.com>
date: Wed Feb 19 18:10:32 2014 +0100
summary:
 Close #20682: Fix UNIX sockets tests of test_asyncio on Mac OS X Tiger
On Mac OS X Tiger (and older), getsockname() returns a zero-length address for
UNIX socket, and so 'sockname' extra info is None.
files:
 Lib/test/test_asyncio/test_events.py | 32 +++++++++++++--
 1 files changed, 27 insertions(+), 5 deletions(-)
diff --git a/Lib/test/test_asyncio/test_events.py b/Lib/test/test_asyncio/test_events.py
--- a/Lib/test/test_asyncio/test_events.py
+++ b/Lib/test/test_asyncio/test_events.py
@@ -4,6 +4,7 @@
 import gc
 import io
 import os
+import platform
 import signal
 import socket
 try:
@@ -40,6 +41,15 @@
 raise FileNotFoundError(filename)
 
 
+def osx_tiger():
+ """Return True if the platform is Mac OS 10.4 or older."""
+ if sys.platform != 'darwin':
+ return False
+ version = platform.mac_ver()[0]
+ version = tuple(map(int, version.split('.')))
+ return version < (10, 5)
+
+
 ONLYCERT = data_file('ssl_cert.pem')
 ONLYKEY = data_file('ssl_key.pem')
 SIGNED_CERTFILE = data_file('keycert3.pem')
@@ -499,10 +509,12 @@
 self.loop.run_forever()
 self.assertEqual(caught, 1)
 
- def _basetest_create_connection(self, connection_fut):
+ def _basetest_create_connection(self, connection_fut, check_sockname):
 tr, pr = self.loop.run_until_complete(connection_fut)
 self.assertIsInstance(tr, asyncio.Transport)
 self.assertIsInstance(pr, asyncio.Protocol)
+ if check_sockname:
+ self.assertIsNotNone(tr.get_extra_info('sockname'))
 self.loop.run_until_complete(pr.done)
 self.assertGreater(pr.nbytes, 0)
 tr.close()
@@ -515,10 +527,14 @@
 
 @unittest.skipUnless(hasattr(socket, 'AF_UNIX'), 'No UNIX Sockets')
 def test_create_unix_connection(self):
+ # Issue #20682: On Mac OS X Tiger, getsockname() returns a
+ # zero-length address for UNIX socket.
+ check_sockname = not osx_tiger()
+
 with test_utils.run_test_unix_server() as httpd:
 conn_fut = self.loop.create_unix_connection(
 lambda: MyProto(loop=self.loop), httpd.address)
- self._basetest_create_connection(conn_fut)
+ self._basetest_create_connection(conn_fut, check_sockname)
 
 def test_create_connection_sock(self):
 with test_utils.run_test_server() as httpd:
@@ -548,12 +564,14 @@
 self.assertGreater(pr.nbytes, 0)
 tr.close()
 
- def _basetest_create_ssl_connection(self, connection_fut):
+ def _basetest_create_ssl_connection(self, connection_fut,
+ check_sockname=True):
 tr, pr = self.loop.run_until_complete(connection_fut)
 self.assertIsInstance(tr, asyncio.Transport)
 self.assertIsInstance(pr, asyncio.Protocol)
 self.assertTrue('ssl' in tr.__class__.__name__.lower())
- self.assertIsNotNone(tr.get_extra_info('sockname'))
+ if check_sockname:
+ self.assertIsNotNone(tr.get_extra_info('sockname'))
 self.loop.run_until_complete(pr.done)
 self.assertGreater(pr.nbytes, 0)
 tr.close()
@@ -571,6 +589,10 @@
 @unittest.skipIf(ssl is None, 'No ssl module')
 @unittest.skipUnless(hasattr(socket, 'AF_UNIX'), 'No UNIX Sockets')
 def test_create_ssl_unix_connection(self):
+ # Issue #20682: On Mac OS X Tiger, getsockname() returns a
+ # zero-length address for UNIX socket.
+ check_sockname = not osx_tiger()
+
 with test_utils.run_test_unix_server(use_ssl=True) as httpd:
 conn_fut = self.loop.create_unix_connection(
 lambda: MyProto(loop=self.loop),
@@ -578,7 +600,7 @@
 ssl=test_utils.dummy_ssl_context(),
 server_hostname='127.0.0.1')
 
- self._basetest_create_ssl_connection(conn_fut)
+ self._basetest_create_ssl_connection(conn_fut, check_sockname)
 
 def test_create_connection_local_addr(self):
 with test_utils.run_test_server() as httpd:
-- 
Repository URL: http://hg.python.org/cpython


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /