]> granicus.if.org Git - python/commitdiff
Issue #14669: Fix pickling of connections and sockets on MacOSX
authorRichard Oudkerk <shibturn@gmail.com>
Thu, 16 Aug 2012 15:48:55 +0000 (16:48 +0100)
committerRichard Oudkerk <shibturn@gmail.com>
Thu, 16 Aug 2012 15:48:55 +0000 (16:48 +0100)
by sending/receiving an acknowledgment after file descriptor transfer.
TestPicklingConnection has been reenabled for MacOSX.

Lib/multiprocessing/reduction.py
Lib/test/test_multiprocessing.py
Misc/NEWS

index 84d2fe9ab21c25dd0c8ce8398d95e7f50952304a..656fa8ff6b074f8359df3095a3a3fba3b9b3e450 100644 (file)
@@ -120,16 +120,24 @@ if sys.platform == 'win32':
 
 else:
     # Unix
+
+    # On MacOSX we should acknowledge receipt of fds -- see Issue14669
+    ACKNOWLEDGE = sys.platform == 'darwin'
+
     def send_handle(conn, handle, destination_pid):
         with socket.fromfd(conn.fileno(), socket.AF_UNIX, socket.SOCK_STREAM) as s:
             s.sendmsg([b'x'], [(socket.SOL_SOCKET, socket.SCM_RIGHTS,
                                 struct.pack("@i", handle))])
+        if ACKNOWLEDGE and conn.recv_bytes() != b'ACK':
+            raise RuntimeError('did not receive acknowledgement of fd')
 
     def recv_handle(conn):
         size = struct.calcsize("@i")
         with socket.fromfd(conn.fileno(), socket.AF_UNIX, socket.SOCK_STREAM) as s:
             msg, ancdata, flags, addr = s.recvmsg(1, socket.CMSG_LEN(size))
             try:
+                if ACKNOWLEDGE:
+                    conn.send_bytes(b'ACK')
                 cmsg_level, cmsg_type, cmsg_data = ancdata[0]
                 if (cmsg_level == socket.SOL_SOCKET and
                     cmsg_type == socket.SCM_RIGHTS):
index 57252a7fb088b76006248e6da37a12b0d5fdb48b..b70783a19193d21c27165aca297ff0668975ae31 100644 (file)
@@ -2446,8 +2446,6 @@ class _TestPoll(unittest.TestCase):
 # Test of sending connection and socket objects between processes
 #
 
-# Intermittent fails on Mac OS X -- see Issue14669 and Issue12958
-@unittest.skipIf(sys.platform == "darwin", "fd passing unreliable on Mac OS X")
 @unittest.skipUnless(HAS_REDUCTION, "test needs multiprocessing.reduction")
 class _TestPicklingConnections(BaseTestCase):
 
index a3965c73002183875d9184fd21db4269013e03f8..55f99a704a2ad5e2dab59127c97101fc6cc20d95 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -16,6 +16,10 @@ Core and Builtins
 Library
 -------
 
+- Issue #14669: Fix pickling of connections and sockets on MacOSX
+  by sending/receiving an acknowledgment after file descriptor transfer.
+  TestPicklingConnection has been reenabled for MacOSX.
+
 - Issue #11062: Fix adding a message from file to Babyl mailbox.
 
 - Issue #15646: Prevent equivalent of a fork bomb when using