mirror of
https://github.com/python/cpython.git
synced 2025-09-27 10:50:04 +00:00
Issue #13070: Fix a crash when a TextIOWrapper caught in a reference cycle
would be finalized after the reference to its underlying BufferedRWPair's writer got cleared by the GC.
This commit is contained in:
parent
1b7da519b0
commit
42c28cdd1d
3 changed files with 24 additions and 0 deletions
|
@ -2414,6 +2414,21 @@ class CTextIOWrapperTest(TextIOWrapperTest):
|
||||||
with self.open(support.TESTFN, "rb") as f:
|
with self.open(support.TESTFN, "rb") as f:
|
||||||
self.assertEqual(f.read(), b"456def")
|
self.assertEqual(f.read(), b"456def")
|
||||||
|
|
||||||
|
def test_rwpair_cleared_before_textio(self):
|
||||||
|
# Issue 13070: TextIOWrapper's finalization would crash when called
|
||||||
|
# after the reference to the underlying BufferedRWPair's writer got
|
||||||
|
# cleared by the GC.
|
||||||
|
for i in range(1000):
|
||||||
|
b1 = self.BufferedRWPair(self.MockRawIO(), self.MockRawIO())
|
||||||
|
t1 = self.TextIOWrapper(b1, encoding="ascii")
|
||||||
|
b2 = self.BufferedRWPair(self.MockRawIO(), self.MockRawIO())
|
||||||
|
t2 = self.TextIOWrapper(b2, encoding="ascii")
|
||||||
|
# circular references
|
||||||
|
t1.buddy = t2
|
||||||
|
t2.buddy = t1
|
||||||
|
support.gc_collect()
|
||||||
|
|
||||||
|
|
||||||
class PyTextIOWrapperTest(TextIOWrapperTest):
|
class PyTextIOWrapperTest(TextIOWrapperTest):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
|
@ -98,6 +98,10 @@ Tests
|
||||||
Extension Modules
|
Extension Modules
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #13070: Fix a crash when a TextIOWrapper caught in a reference cycle
|
||||||
|
would be finalized after the reference to its underlying BufferedRWPair's
|
||||||
|
writer got cleared by the GC.
|
||||||
|
|
||||||
- Issue #12881: ctypes: Fix segfault with large structure field names.
|
- Issue #12881: ctypes: Fix segfault with large structure field names.
|
||||||
|
|
||||||
- Issue #13058: ossaudiodev: fix a file descriptor leak on error. Patch by
|
- Issue #13058: ossaudiodev: fix a file descriptor leak on error. Patch by
|
||||||
|
|
|
@ -2212,6 +2212,11 @@ bufferedrwpair_isatty(rwpair *self, PyObject *args)
|
||||||
static PyObject *
|
static PyObject *
|
||||||
bufferedrwpair_closed_get(rwpair *self, void *context)
|
bufferedrwpair_closed_get(rwpair *self, void *context)
|
||||||
{
|
{
|
||||||
|
if (self->writer == NULL) {
|
||||||
|
PyErr_SetString(PyExc_RuntimeError,
|
||||||
|
"the BufferedRWPair object is being garbage-collected");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return PyObject_GetAttr((PyObject *) self->writer, _PyIO_str_closed);
|
return PyObject_GetAttr((PyObject *) self->writer, _PyIO_str_closed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue