From 854141e06c04a35a85598752a91dd261fdf66c1c Mon Sep 17 00:00:00 2001 From: Jacob Walls Date: Sat, 1 Feb 2025 14:34:39 -0500 Subject: [PATCH] Fix bizarre failure --- pylint/checkers/utils.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/pylint/checkers/utils.py b/pylint/checkers/utils.py index be4c879fe3..79be96e725 100644 --- a/pylint/checkers/utils.py +++ b/pylint/checkers/utils.py @@ -2147,7 +2147,13 @@ def is_augmented_assign(node: nodes.Assign) -> tuple[bool, str]: binop.op in COMMUTATIVE_OPERATORS and _is_target_name_in_binop_side(target, binop.right) ): - inferred_left = safe_infer(binop.left) + if isinstance(binop.left, nodes.Const): + # This bizarrely became necessary after an unrelated call to igetattr(). + # Seems like a code smell uncovered in #10212. + # tuple(node.frame().igetattr(node.name)) + inferred_left = binop.left + else: + inferred_left = safe_infer(binop.left) if isinstance(inferred_left, nodes.Const) and isinstance( inferred_left.value, int ):