From: Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> Date: Sat, 4 May 2024 15:26:30 +0000 (+0200) Subject: [3.12] gh-118569: Add a test for dynamic PEP695 classes (GH-118570) (#118574) X-Git-Tag: v3.12.4~142 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=53e8bdd1e6434a06ac67ae0dd250d1abf7d2dc4c;p=thirdparty%2FPython%2Fcpython.git [3.12] gh-118569: Add a test for dynamic PEP695 classes (GH-118570) (#118574) gh-118569: Add a test for dynamic PEP695 classes (GH-118570) (cherry picked from commit 5f547585fa56c94c5d836b5313a7200f4937ebc4) Co-authored-by: Nikita Sobolev --- diff --git a/Lib/test/test_type_params.py b/Lib/test/test_type_params.py index 25ee188731f3..38416315173b 100644 --- a/Lib/test/test_type_params.py +++ b/Lib/test/test_type_params.py @@ -708,6 +708,31 @@ class TypeParamsClassScopeTest(unittest.TestCase): self.assertIn(int, C.D.__bases__) self.assertIs(C.D.x, str) + +class DynamicClassTest(unittest.TestCase): + def _set_type_params(self, ns, params): + ns['__type_params__'] = params + + def test_types_new_class_with_callback(self): + T = TypeVar('T', infer_variance=True) + Klass = types.new_class('Klass', (Generic[T],), {}, + lambda ns: self._set_type_params(ns, (T,))) + + self.assertEqual(Klass.__bases__, (Generic,)) + self.assertEqual(Klass.__orig_bases__, (Generic[T],)) + self.assertEqual(Klass.__type_params__, (T,)) + self.assertEqual(Klass.__parameters__, (T,)) + + def test_types_new_class_no_callback(self): + T = TypeVar('T', infer_variance=True) + Klass = types.new_class('Klass', (Generic[T],), {}) + + self.assertEqual(Klass.__bases__, (Generic,)) + self.assertEqual(Klass.__orig_bases__, (Generic[T],)) + self.assertEqual(Klass.__type_params__, ()) # must be explicitly set + self.assertEqual(Klass.__parameters__, (T,)) + + class TypeParamsManglingTest(unittest.TestCase): def test_mangling(self): class Foo[__T]: