summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeal Norwitz <nnorwitz@gmail.com>2006-04-14 05:35:39 (GMT)
committerNeal Norwitz <nnorwitz@gmail.com>2006-04-14 05:35:39 (GMT)
commit03f3be50af5bb56e27ffad28a31b21c060630273 (patch)
treed302d83dd7534e07df33c03d0d2ff566165746d3
parent615461603c3d81a80285299fc3a0dc47d2858864 (diff)
downloadcpython-03f3be50af5bb56e27ffad28a31b21c060630273.zip
cpython-03f3be50af5bb56e27ffad28a31b21c060630273.tar.gz
cpython-03f3be50af5bb56e27ffad28a31b21c060630273.tar.bz2
Update notes to address cyclic garbage and what should happen when a test is fixed.
-rw-r--r--Lib/test/leakers/README.txt13
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/leakers/README.txt b/Lib/test/leakers/README.txt
index 69ee35a..beeee0e 100644
--- a/Lib/test/leakers/README.txt
+++ b/Lib/test/leakers/README.txt
@@ -5,6 +5,15 @@ the interpreter was built in debug mode. If the total ref count
doesn't increase, the bug has been fixed and the file should be removed
from the repository.
+Note: be careful to check for cyclic garbage. Sometimes it may be helpful
+to define the leak function like:
+
+def leak():
+ def inner_leak():
+ # this is the function that leaks, but also creates cycles
+ inner_leak()
+ gc.collect() ; gc.collect() ; gc.collect()
+
Here's an example interpreter session for test_gestalt which still leaks:
>>> from test.leakers.test_gestalt import leak
@@ -17,3 +26,7 @@ Here's an example interpreter session for test_gestalt which still leaks:
[28940 refs]
>>>
+Once the leak is fixed, the test case should be moved into an appropriate
+test (even if it was originally from the test suite). This ensures the
+regression doesn't happen again. And if it does, it should be easier
+to track down.