https://github.com/python/cpython/commit/8e2aab7ad5e1c8b3360c1e1b80ddadc0845eaa3e
commit: 8e2aab7ad5e1c8b3360c1e1b80ddadc0845eaa3e
branch: main
author: Sam Gross <[email protected]>
committer: pablogsal <[email protected]>
date: 2024-03-13T13:27:36Z
summary:
gh-116604: Fix test_gc on free-threaded build (#116662)
The free-threaded GC only does full collections, so it uses a threshold that
is a maximum of a fixed value (default 2000) and proportional to the number of
live objects. If there were many live objects after the previous collection,
then the threshold may be larger than 10,000 causing
`test_indirect_calls_with_gc_disabled` to fail.
This manually sets the threshold to `(1000, 0, 0)` for the test. The `0`
disables the proportional scaling.
files:
M Lib/test/support/__init__.py
M Lib/test/test_gc.py
diff --git a/Lib/test/support/__init__.py b/Lib/test/support/__init__.py
index af43446c26120e..ce693e51aab31c 100644
--- a/Lib/test/support/__init__.py
+++ b/Lib/test/support/__init__.py
@@ -797,6 +797,16 @@ def disable_gc():
if have_gc:
gc.enable()
[email protected]
+def gc_threshold(*args):
+ import gc
+ old_threshold = gc.get_threshold()
+ gc.set_threshold(*args)
+ try:
+ yield
+ finally:
+ gc.set_threshold(*old_threshold)
+
def python_is_optimized():
"""Find if Python was built with optimizations."""
diff --git a/Lib/test/test_gc.py b/Lib/test/test_gc.py
index 2aea025fcc140a..f1a7afac0bcd19 100644
--- a/Lib/test/test_gc.py
+++ b/Lib/test/test_gc.py
@@ -5,7 +5,7 @@
from test.support.import_helper import import_module
from test.support.os_helper import temp_dir, TESTFN, unlink
from test.support.script_helper import assert_python_ok, make_script
-from test.support import threading_helper
+from test.support import threading_helper, gc_threshold
import gc
import sys
@@ -1330,6 +1330,7 @@ def callback(ignored):
# with an empty __dict__.
self.assertEqual(x, None)
+ @gc_threshold(1000, 0, 0)
def test_bug1055820d(self):
# Corresponds to temp2d.py in the bug report. This is very much like
# test_bug1055820c, but uses a __del__ method instead of a weakref
@@ -1397,6 +1398,7 @@ def __del__(self):
# empty __dict__.
self.assertEqual(x, None)
+ @gc_threshold(1000, 0, 0)
def test_indirect_calls_with_gc_disabled(self):
junk = []
i = 0
_______________________________________________
Python-checkins mailing list -- [email protected]
To unsubscribe send an email to [email protected]
https://mail.python.org/mailman3/lists/python-checkins.python.org/
Member address: [email protected]