mirror of https://github.com/python/cpython.git
Close #13022: _multiprocessing.recvfd() doesn't check that file descriptor was actually received
This commit is contained in:
parent
d0b10a6435
commit
4507e6456e
|
@ -1632,6 +1632,23 @@ def test_large_fd_transfer(self):
|
||||||
with open(test.support.TESTFN, "rb") as f:
|
with open(test.support.TESTFN, "rb") as f:
|
||||||
self.assertEqual(f.read(), b"bar")
|
self.assertEqual(f.read(), b"bar")
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def _send_data_without_fd(self, conn):
|
||||||
|
os.write(conn.fileno(), b"\0")
|
||||||
|
|
||||||
|
@unittest.skipIf(sys.platform == "win32", "doesn't make sense on Windows")
|
||||||
|
def test_missing_fd_transfer(self):
|
||||||
|
# Check that exception is raised when received data is not
|
||||||
|
# accompanied by a file descriptor in ancillary data.
|
||||||
|
if self.TYPE != 'processes':
|
||||||
|
self.skipTest("only makes sense with processes")
|
||||||
|
conn, child_conn = self.Pipe(duplex=True)
|
||||||
|
|
||||||
|
p = self.Process(target=self._send_data_without_fd, args=(child_conn,))
|
||||||
|
p.daemon = True
|
||||||
|
p.start()
|
||||||
|
self.assertRaises(RuntimeError, reduction.recv_handle, conn)
|
||||||
|
p.join()
|
||||||
|
|
||||||
class _TestListenerClient(BaseTestCase):
|
class _TestListenerClient(BaseTestCase):
|
||||||
|
|
||||||
|
|
|
@ -78,6 +78,9 @@ Tests
|
||||||
Extension Modules
|
Extension Modules
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #13022: Fix: _multiprocessing.recvfd() doesn't check that
|
||||||
|
file descriptor was actually received.
|
||||||
|
|
||||||
- Issue #12483: ctypes: Fix a crash when the destruction of a callback
|
- Issue #12483: ctypes: Fix a crash when the destruction of a callback
|
||||||
object triggers the garbage collector.
|
object triggers the garbage collector.
|
||||||
|
|
||||||
|
|
|
@ -177,6 +177,17 @@ multiprocessing_recvfd(PyObject *self, PyObject *args)
|
||||||
if (res < 0)
|
if (res < 0)
|
||||||
return PyErr_SetFromErrno(PyExc_OSError);
|
return PyErr_SetFromErrno(PyExc_OSError);
|
||||||
|
|
||||||
|
if (msg.msg_controllen < CMSG_LEN(sizeof(int)) ||
|
||||||
|
(cmsg = CMSG_FIRSTHDR(&msg)) == NULL ||
|
||||||
|
cmsg->cmsg_level != SOL_SOCKET ||
|
||||||
|
cmsg->cmsg_type != SCM_RIGHTS ||
|
||||||
|
cmsg->cmsg_len < CMSG_LEN(sizeof(int))) {
|
||||||
|
/* If at least one control message is present, there should be
|
||||||
|
no room for any further data in the buffer. */
|
||||||
|
PyErr_SetString(PyExc_RuntimeError, "No file descriptor received");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
fd = * (int *) CMSG_DATA(cmsg);
|
fd = * (int *) CMSG_DATA(cmsg);
|
||||||
return Py_BuildValue("i", fd);
|
return Py_BuildValue("i", fd);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue