]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-102558: [Enum] fix AttributeError during member repr() (GH-102601)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Thu, 23 Mar 2023 20:56:38 +0000 (13:56 -0700)
committerGitHub <noreply@github.com>
Thu, 23 Mar 2023 20:56:38 +0000 (13:56 -0700)
(cherry picked from commit bd063756b34003c1bc7cacf5b1bd90a409180fb6)

Co-authored-by: Dong-hee Na <donghee.na@python.org>
Lib/enum.py
Lib/test/test_enum.py

index 5cff41713ae506e7ea5dbf10bdbc445943575ce9..ea55f7bbef8637804ac02911f9f4f9f7005187ec 100644 (file)
@@ -1187,6 +1187,8 @@ class Enum(metaclass=EnumType):
         return None
 
     def __repr__(self):
+        if not isinstance(self, Enum):
+            return repr(self)
         v_repr = self.__class__._value_repr_ or repr
         return "<%s.%s: %s>" % (self.__class__.__name__, self._name_, v_repr(self._value_))
 
index 72dfb9881779796be71ce287ce271dd5948298bf..2a305e415cd9e2d7bcf7ca5317a235a68375a6b2 100644 (file)
@@ -11,7 +11,7 @@ import typing
 import builtins as bltns
 from collections import OrderedDict
 from datetime import date
-from enum import Enum, IntEnum, StrEnum, EnumType, Flag, IntFlag, unique, auto
+from enum import Enum, EnumMeta, IntEnum, StrEnum, EnumType, Flag, IntFlag, unique, auto
 from enum import STRICT, CONFORM, EJECT, KEEP, _simple_enum, _test_simple_enum
 from enum import verify, UNIQUE, CONTINUOUS, NAMED_FLAGS, ReprEnum
 from enum import member, nonmember, _iter_bits_lsb
@@ -632,6 +632,13 @@ class _EnumTests:
             theother = auto()
         self.assertEqual(repr(MySubEnum.that), "My name is that.")
 
+    def test_multiple_superclasses_repr(self):
+        class _EnumSuperClass(metaclass=EnumMeta):
+            pass
+        class E(_EnumSuperClass, Enum):
+            A = 1
+        self.assertEqual(repr(E.A), "<E.A: 1>")
+
     def test_reversed_iteration_order(self):
         self.assertEqual(
                 list(reversed(self.MainEnum)),