Skip to content

Commit

Permalink
Fix a regression in 2.15.7 for unsubscriptable-object.
Browse files Browse the repository at this point in the history
- Raise an `InferenceError` when there is a `SyntaxError` due to an invalid `TypeVar` name.

Closes pylint-dev#2305
Closes pylint-dev/pylint#9069
  • Loading branch information
mbyrnepr2 committed Sep 25, 2023
1 parent bf31af2 commit d255072
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 1 deletion.
10 changes: 10 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
Expand Up @@ -223,6 +223,16 @@ Release date: TBA
Closes pylint-dev/pylint#9015


What's New in astroid 2.15.8?
=============================
Release date: TBA

* Fix a regression in 2.15.7 for ``unsubscriptable-object``.

Closes #2305
Closes pylint-dev/pylint#9069


What's New in astroid 2.15.7?
=============================
Release date: 2023-09-23
Expand Down
6 changes: 5 additions & 1 deletion astroid/brain/brain_typing.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
from astroid.builder import AstroidBuilder, _extract_single_node
from astroid.const import PY39_PLUS, PY312_PLUS
from astroid.exceptions import (
AstroidSyntaxError,
AttributeInferenceError,
InferenceError,
UseInferenceDefault,
Expand Down Expand Up @@ -134,7 +135,10 @@ def infer_typing_typevar_or_newtype(node, context_itton=None):
raise UseInferenceDefault

typename = node.args[0].as_string().strip("'")
node = extract_node(TYPING_TYPE_TEMPLATE.format(typename))
try:
node = extract_node(TYPING_TYPE_TEMPLATE.format(typename))
except AstroidSyntaxError as exc:
raise InferenceError from exc
return node.infer(context=context_itton)


Expand Down
25 changes: 25 additions & 0 deletions tests/brain/test_typing.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Licensed under the LGPL: https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html
# For details: https://github.com/pylint-dev/astroid/blob/main/LICENSE
# Copyright (c) https://github.com/pylint-dev/astroid/blob/main/CONTRIBUTORS.txt

import pytest

from astroid import builder, nodes
from astroid.exceptions import InferenceError


def test_infer_typevar() -> None:
"""
Regression test for: https://github.com/pylint-dev/pylint/issues/8802
Test that an inferred `typing.TypeVar()` call produces a `nodes.ClassDef`
node.
"""
assign_node = builder.extract_node(
"""
from typing import TypeVar
TypeVar('My.Type')
"""
)
with pytest.raises(InferenceError):
assign_node.inferred()

0 comments on commit d255072

Please sign in to comment.