mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-05-25 14:52:28 +00:00
python-3.6.zip added from Github
README.cosmo contains the necessary links.
This commit is contained in:
parent
75fc601ff5
commit
0c4c56ff39
4219 changed files with 1968626 additions and 0 deletions
32
third_party/python/Lib/test/leakers/README.txt
vendored
Normal file
32
third_party/python/Lib/test/leakers/README.txt
vendored
Normal file
|
@ -0,0 +1,32 @@
|
|||
This directory contains test cases that are known to leak references.
|
||||
The idea is that you can import these modules while in the interpreter
|
||||
and call the leak function repeatedly. This will only be helpful if
|
||||
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
|
||||
[24275 refs]
|
||||
>>> leak()
|
||||
[28936 refs]
|
||||
>>> leak()
|
||||
[28938 refs]
|
||||
>>> leak()
|
||||
[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.
|
0
third_party/python/Lib/test/leakers/__init__.py
vendored
Normal file
0
third_party/python/Lib/test/leakers/__init__.py
vendored
Normal file
15
third_party/python/Lib/test/leakers/test_ctypes.py
vendored
Normal file
15
third_party/python/Lib/test/leakers/test_ctypes.py
vendored
Normal file
|
@ -0,0 +1,15 @@
|
|||
|
||||
# Taken from Lib/ctypes/test/test_keeprefs.py, PointerToStructure.test().
|
||||
|
||||
from ctypes import Structure, c_int, POINTER
|
||||
import gc
|
||||
|
||||
def leak_inner():
|
||||
class POINT(Structure):
|
||||
_fields_ = [("x", c_int)]
|
||||
class RECT(Structure):
|
||||
_fields_ = [("a", POINTER(POINT))]
|
||||
|
||||
def leak():
|
||||
leak_inner()
|
||||
gc.collect()
|
13
third_party/python/Lib/test/leakers/test_selftype.py
vendored
Normal file
13
third_party/python/Lib/test/leakers/test_selftype.py
vendored
Normal file
|
@ -0,0 +1,13 @@
|
|||
# Reference cycles involving only the ob_type field are rather uncommon
|
||||
# but possible. Inspired by SF bug 1469629.
|
||||
|
||||
import gc
|
||||
|
||||
def leak():
|
||||
class T(type):
|
||||
pass
|
||||
class U(type, metaclass=T):
|
||||
pass
|
||||
U.__class__ = U
|
||||
del U
|
||||
gc.collect(); gc.collect(); gc.collect()
|
Loading…
Add table
Add a link
Reference in a new issue