aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2016-12-21 12:32:56 +0200
committerSerhiy Storchaka <storchaka@gmail.com>2016-12-21 12:32:56 +0200
commit18f018ca12fccecaefc427927350538d5d37d51e (patch)
treed65b77f4f8b56451bc9cb857c8b381ca2b234355
parentfb2ae15c6704a072afeef4786749d9bb2ce7d68d (diff)
downloadcpython-18f018ca12fccecaefc427927350538d5d37d51e.tar.gz
cpython-18f018ca12fccecaefc427927350538d5d37d51e.zip
Issue #28871: Fixed a crash when deallocate deep ElementTree.
-rw-r--r--Lib/test/test_xml_etree_c.py10
-rw-r--r--Misc/NEWS2
-rw-r--r--Modules/_elementtree.c2
3 files changed, 14 insertions, 0 deletions
diff --git a/Lib/test/test_xml_etree_c.py b/Lib/test/test_xml_etree_c.py
index 96b446e32ea..bfced1225e0 100644
--- a/Lib/test/test_xml_etree_c.py
+++ b/Lib/test/test_xml_etree_c.py
@@ -11,6 +11,7 @@ cET_alias = import_fresh_module('xml.etree.cElementTree',
fresh=['_elementtree', 'xml.etree'])
+@unittest.skipUnless(cET, 'requires _elementtree')
class MiscTests(unittest.TestCase):
# Issue #8651.
@support.bigmemtest(size=support._2G + 100, memuse=1, dry_run=False)
@@ -54,6 +55,15 @@ class MiscTests(unittest.TestCase):
del element.attrib
self.assertEqual(element.attrib, {'A': 'B', 'C': 'D'})
+ def test_trashcan(self):
+ # If this test fails, it will most likely die via segfault.
+ e = root = cET.Element('root')
+ for i in range(200000):
+ e = cET.SubElement(e, 'x')
+ del e
+ del root
+ support.gc_collect()
+
@unittest.skipUnless(cET, 'requires _elementtree')
class TestAliasWorking(unittest.TestCase):
diff --git a/Misc/NEWS b/Misc/NEWS
index 1286d7b3511..74266cd1255 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -138,6 +138,8 @@ Core and Builtins
Library
-------
+- Issue #28871: Fixed a crash when deallocate deep ElementTree.
+
- Issue #19542: Fix bugs in WeakValueDictionary.setdefault() and
WeakValueDictionary.pop() when a GC collection happens in another
thread.
diff --git a/Modules/_elementtree.c b/Modules/_elementtree.c
index 1cdddaf0fbe..7d50dd07a96 100644
--- a/Modules/_elementtree.c
+++ b/Modules/_elementtree.c
@@ -652,6 +652,7 @@ static void
element_dealloc(ElementObject* self)
{
PyObject_GC_UnTrack(self);
+ Py_TRASHCAN_SAFE_BEGIN(self)
if (self->weakreflist != NULL)
PyObject_ClearWeakRefs((PyObject *) self);
@@ -662,6 +663,7 @@ element_dealloc(ElementObject* self)
RELEASE(sizeof(ElementObject), "destroy element");
Py_TYPE(self)->tp_free((PyObject *)self);
+ Py_TRASHCAN_SAFE_END(self)
}
/* -------------------------------------------------------------------- */