summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEli Bendersky <eliben@gmail.com>2012-03-31 10:55:38 (GMT)
committerEli Bendersky <eliben@gmail.com>2012-03-31 10:55:38 (GMT)
commita5e822045cd38e8c5c38d43ad933533f7a5d9b2b (patch)
tree2ac22900597f49a44d4687a314926bde0a4c22ba
parentc6897854f8634e66fcb390d2301f57437bbdf774 (diff)
downloadcpython-a5e822045cd38e8c5c38d43ad933533f7a5d9b2b.zip
cpython-a5e822045cd38e8c5c38d43ad933533f7a5d9b2b.tar.gz
cpython-a5e822045cd38e8c5c38d43ad933533f7a5d9b2b.tar.bz2
Fix the tests of GC collection in ET.Element according to Benjamin's recommendations
-rw-r--r--Lib/test/test_xml_etree.py44
1 files changed, 21 insertions, 23 deletions
diff --git a/Lib/test/test_xml_etree.py b/Lib/test/test_xml_etree.py
index 00eafe1..bd2a826 100644
--- a/Lib/test/test_xml_etree.py
+++ b/Lib/test/test_xml_etree.py
@@ -14,14 +14,14 @@
# Don't re-import "xml.etree.ElementTree" module in the docstring,
# except if the test is specific to the Python implementation.
-import gc
import html
import io
import sys
import unittest
+import weakref
from test import support
-from test.support import findfile, import_fresh_module
+from test.support import findfile, import_fresh_module, gc_collect
pyET = import_fresh_module('xml.etree.ElementTree', blocked=['_elementtree'])
@@ -1848,28 +1848,26 @@ class BasicElementTest(unittest.TestCase):
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 = []
+ class Dummy:
+ pass
+
+ # Test the shortest cycle: d->element->d
+ d = Dummy()
+ d.dummyref = ET.Element('joe', attr=d)
+ wref = weakref.ref(d)
+ del d
+ gc_collect()
+ self.assertIsNone(wref())
+
+ # A longer cycle: d->e->e2->d
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])
+ d = Dummy()
+ d.dummyref = e
+ wref = weakref.ref(d)
+ e2 = ET.SubElement(e, 'foo', attr=d)
+ del d, e, e2
+ gc_collect()
+ self.assertIsNone(wref())
class ElementTreeTest(unittest.TestCase):