Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 04ec8ce

Browse files
committed
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.
1 parent 69a06dd commit 04ec8ce

3 files changed

Lines changed: 12 additions & 2 deletions

File tree

Lib/multiprocessing/reduction.py

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -120,16 +120,24 @@ def rebuild_pipe_connection(dh, readable, writable):
120120

121121
else:
122122
# Unix
123+
124+
# On MacOSX we should acknowledge receipt of fds -- see Issue14669
125+
ACKNOWLEDGE = sys.platform == 'darwin'
126+
123127
def send_handle(conn, handle, destination_pid):
124128
with socket.fromfd(conn.fileno(), socket.AF_UNIX, socket.SOCK_STREAM) as s:
125129
s.sendmsg([b'x'], [(socket.SOL_SOCKET, socket.SCM_RIGHTS,
126130
struct.pack("@i", handle))])
131+
if ACKNOWLEDGE and conn.recv_bytes() != b'ACK':
132+
raise RuntimeError('did not receive acknowledgement of fd')
127133

128134
def recv_handle(conn):
129135
size = struct.calcsize("@i")
130136
with socket.fromfd(conn.fileno(), socket.AF_UNIX, socket.SOCK_STREAM) as s:
131137
msg, ancdata, flags, addr = s.recvmsg(1, socket.CMSG_LEN(size))
132138
try:
139+
if ACKNOWLEDGE:
140+
conn.send_bytes(b'ACK')
133141
cmsg_level, cmsg_type, cmsg_data = ancdata[0]
134142
if (cmsg_level == socket.SOL_SOCKET and
135143
cmsg_type == socket.SCM_RIGHTS):

Lib/test/test_multiprocessing.py

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2446,8 +2446,6 @@ def test_dont_merge(self):
24462446
# Test of sending connection and socket objects between processes
24472447
#
24482448

2449-
# Intermittent fails on Mac OS X -- see Issue14669 and Issue12958
2450-
@unittest.skipIf(sys.platform == "darwin", "fd passing unreliable on Mac OS X")
24512449
@unittest.skipUnless(HAS_REDUCTION, "test needs multiprocessing.reduction")
24522450
class _TestPicklingConnections(BaseTestCase):
24532451

Misc/NEWS

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,10 @@ Core and Builtins
1616
Library
1717
-------
1818

19+
- Issue #14669: Fix pickling of connections and sockets on MacOSX
20+
by sending/receiving an acknowledgment after file descriptor transfer.
21+
TestPicklingConnection has been reenabled for MacOSX.
22+
1923
- Issue #11062: Fix adding a message from file to Babyl mailbox.
2024

2125
- Issue #15646: Prevent equivalent of a fork bomb when using

0 commit comments

Comments
 (0)