8000 gh-127840: pass flags and address from send_fds (GH-127841) · python/cpython@518c95b · GitHub
[go: up one dir, main page]

Skip to content

Commit 518c95b

Browse files
gh-127840: pass flags and address from send_fds (GH-127841)
socket: pass flags and address from send_fds Co-authored-by: Peter Bierma <zintensitydev@gmail.com>
1 parent b1b8962 commit 518c95b

File tree

3 files changed

+26
-1
lines changed

3 files changed

+26
-1
lines changed

Lib/socket.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -563,7 +563,7 @@ def send_fds(sock, buffers, fds, flags=0, address=None):
563563
import array
564564

565565
return sock.sendmsg(buffers, [(_socket.SOL_SOCKET,
566-
_socket.SCM_RIGHTS, array.array("i", fds))])
566+
_socket.SCM_RIGHTS, array.array("i", fds))], flags, address)
567567
__all__.append("send_fds")
568568

569569
if hasattr(_socket.socket, "recvmsg"):

Lib/test/test_socket.py

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7366,6 +7366,30 @@ def close_fds(fds):
73667366
data = os.read(rfd, 100)
73677367
self.assertEqual(data, str(index).encode())
73687368

7369+
def testSendAndRecvFdsByAddress(self):
7370+
rfd, wfd = os.pipe()
7371+
self.addCleanup(os.close, rfd)
7372+
self.addCleanup(os.close, wfd)
7373+
7374+
sock = socket.socket(socket.AF_UNIX, socket.SOCK_DGRAM)
7375+
address = socket_helper.create_unix_domain_name()
7376+
self.addCleanup(os_helper.unlink, address)
7377+
socket_helper.bind_unix_socket(sock, address)
7378+
7379+
socket.send_fds(sock, [MSG], [rfd], 0, address)
7380+
7381+
# request more data and file descriptors than expected
7382+
msg, (rfd2,), flags, addr = socket.recv_fds(sock, len(MSG) * 2, 2)
7383+
self.addCleanup(os.close, rfd2)
7384+
self.assertEqual(msg, MSG)
7385+
self.assertEqual(flags, 0)
7386+
self.assertEqual(addr, address)
7387+
7388+
# test that the file descriptor is connected
7389+
os.write(wfd, b'data')
7390+
data = os.read(rfd2, 100)
7391+
self.assertEqual(data, b'data')
7392+
73697393

73707394
class FreeThreadingTests(unittest.TestCase):
73717395

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Fix :func:`socket.send_fds` ignoring flags and address parameters.

0 commit comments

Comments
 (0)
0