summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_xml_etree.py
diff options
context:
space:
mode:
Diffstat (limited to 'Lib/test/test_xml_etree.py')
-rw-r--r--Lib/test/test_xml_etree.py27
1 files changed, 26 insertions, 1 deletions
diff --git a/Lib/test/test_xml_etree.py b/Lib/test/test_xml_etree.py
index 8a1ea0f..00eafe1 100644
--- a/Lib/test/test_xml_etree.py
+++ b/Lib/test/test_xml_etree.py
@@ -14,9 +14,10 @@
# Don't re-import "xml.etree.ElementTree" module in the docstring,
# except if the test is specific to the Python implementation.
-import sys
+import gc
import html
import io
+import sys
import unittest
from test import support
@@ -1846,6 +1847,30 @@ class BasicElementTest(unittest.TestCase):
self.assertRaises(TypeError, e.extend, [ET.Element('bar'), 'foo'])
self.assertRaises(TypeError, e.insert, 0, 'foo')
+ def test_cyclic_gc(self):
+ class ShowGC:
+ def __init__(self, flaglist):
+ self.flaglist = flaglist
+ def __del__(self):
+ self.flaglist.append(1)
+
+ # Test the shortest cycle: lst->element->lst
+ fl = []
+ lst = [ShowGC(fl)]
+ lst.append(ET.Element('joe', attr=lst))
+ del lst
+ gc.collect()
+ self.assertEqual(fl, [1])
+
+ # A longer cycle: lst->e->e2->lst
+ fl = []
+ e = ET.Element('joe')
+ lst = [ShowGC(fl), e]
+ e2 = ET.SubElement(e, 'foo', attr=lst)
+ del lst, e, e2
+ gc.collect()
+ self.assertEqual(fl, [1])
+
class ElementTreeTest(unittest.TestCase):
def test_istype(self):