]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-96385: Correctly raise error on `[*T, *V]` substitution (GH-96386)
authorNikita Sobolev <mail@sobolevn.me>
Tue, 30 Aug 2022 07:34:55 +0000 (10:34 +0300)
committerGitHub <noreply@github.com>
Tue, 30 Aug 2022 07:34:55 +0000 (10:34 +0300)
Lib/test/test_typing.py
Lib/typing.py
Misc/NEWS.d/next/Library/2022-08-29-15-28-39.gh-issue-96385.uLRTsf.rst [new file with mode: 0644]

index ca7bd8e083c45439318f8433771292b4d6a4c256..7eea01909ec83f35de17e95ac64751cda312ee1f 100644 (file)
@@ -596,6 +596,7 @@ class GenericAliasSubstitutionTests(BaseTestCase):
     def test_one_parameter(self):
         T = TypeVar('T')
         Ts = TypeVarTuple('Ts')
+        Ts2 = TypeVarTuple('Ts2')
 
         class C(Generic[T]): pass
 
@@ -621,6 +622,8 @@ class GenericAliasSubstitutionTests(BaseTestCase):
             # Should definitely raise TypeError: list only takes one argument.
             ('list[T, *tuple_type[int, ...]]',    '[int]',                   'list[int, *tuple_type[int, ...]]'),
             ('List[T, *tuple_type[int, ...]]',    '[int]',                   'TypeError'),
+            # Should raise, because more than one `TypeVarTuple` is not supported.
+            ('generic[*Ts, *Ts2]',                '[int]',                   'TypeError'),
         ]
 
         for alias_template, args_template, expected_template in tests:
index 43ef07e50cfefce6be549d44c1c7e3fc1a568cd8..596744ed1322057d5116cd04056440a0f94dec54 100644 (file)
@@ -1074,7 +1074,7 @@ class TypeVarTuple(_Final, _Immutable, _PickleUsingNameMixin, _root=True):
     def __typing_prepare_subst__(self, alias, args):
         params = alias.__parameters__
         typevartuple_index = params.index(self)
-        for param in enumerate(params[typevartuple_index + 1:]):
+        for param in params[typevartuple_index + 1:]:
             if isinstance(param, TypeVarTuple):
                 raise TypeError(f"More than one TypeVarTuple parameter in {alias}")
 
diff --git a/Misc/NEWS.d/next/Library/2022-08-29-15-28-39.gh-issue-96385.uLRTsf.rst b/Misc/NEWS.d/next/Library/2022-08-29-15-28-39.gh-issue-96385.uLRTsf.rst
new file mode 100644 (file)
index 0000000..5735482
--- /dev/null
@@ -0,0 +1,3 @@
+Fix ``TypeVarTuple.__typing_prepare_subst__``. ``TypeError`` was not raised
+when using more than one ``TypeVarTuple``, like ``[*T, *V]`` in type alias
+substitutions.