mirror of
https://github.com/python/cpython.git
synced 2025-08-03 00:23:06 +00:00
[3.10] bpo-44342: [Enum] improve test, add andrei kulakov to ACKS (GH-26726)
* [3.10] [Enum] improve test, add andrei kulakov to ACKS (GH-26726).
(cherry picked from commit cb2014f207
)
Co-authored-by: Ethan Furman <ethan@stoneleaf.us>
This commit is contained in:
parent
0f99324f61
commit
41c2a4a727
4 changed files with 28 additions and 4 deletions
|
@ -576,7 +576,7 @@ Data Types
|
||||||
... NEON = 31
|
... NEON = 31
|
||||||
Traceback (most recent call last):
|
Traceback (most recent call last):
|
||||||
...
|
...
|
||||||
ValueError: invalid Flag 'Color': 'WHITE' is missing a named flag for value 8; 'NEON' is missing named flags for values 8, 16
|
ValueError: invalid Flag 'Color': aliases WHITE and NEON are missing combined values of 0x18 [use enum.show_flag_values(value) for details]
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
|
|
|
@ -1637,7 +1637,7 @@ class verify:
|
||||||
else:
|
else:
|
||||||
value = 'combined values of 0x%x' % missing_value
|
value = 'combined values of 0x%x' % missing_value
|
||||||
raise ValueError(
|
raise ValueError(
|
||||||
'invalid Flag %r: %s %s [use `enum.show_flag_values(value)` for details]'
|
'invalid Flag %r: %s %s [use enum.show_flag_values(value) for details]'
|
||||||
% (cls_name, alias, value)
|
% (cls_name, alias, value)
|
||||||
)
|
)
|
||||||
return enumeration
|
return enumeration
|
||||||
|
|
|
@ -660,12 +660,35 @@ class TestEnum(unittest.TestCase):
|
||||||
self.assertEqual(repr(MyEnum.A), '<MyEnum.A: 0x1>')
|
self.assertEqual(repr(MyEnum.A), '<MyEnum.A: 0x1>')
|
||||||
#
|
#
|
||||||
class SillyInt(HexInt):
|
class SillyInt(HexInt):
|
||||||
|
__qualname__ = 'SillyInt'
|
||||||
pass
|
pass
|
||||||
class MyOtherEnum(SillyInt, enum.Enum):
|
class MyOtherEnum(SillyInt, enum.Enum):
|
||||||
|
__qualname__ = 'MyOtherEnum'
|
||||||
D = 4
|
D = 4
|
||||||
E = 5
|
E = 5
|
||||||
F = 6
|
F = 6
|
||||||
self.assertIs(MyOtherEnum._member_type_, SillyInt)
|
self.assertIs(MyOtherEnum._member_type_, SillyInt)
|
||||||
|
globals()['SillyInt'] = SillyInt
|
||||||
|
globals()['MyOtherEnum'] = MyOtherEnum
|
||||||
|
test_pickle_dump_load(self.assertIs, MyOtherEnum.E)
|
||||||
|
test_pickle_dump_load(self.assertIs, MyOtherEnum)
|
||||||
|
#
|
||||||
|
# This did not work in 3.9, but does now with pickling by name
|
||||||
|
class UnBrokenInt(int):
|
||||||
|
__qualname__ = 'UnBrokenInt'
|
||||||
|
def __new__(cls, value):
|
||||||
|
return int.__new__(cls, value)
|
||||||
|
class MyUnBrokenEnum(UnBrokenInt, Enum):
|
||||||
|
__qualname__ = 'MyUnBrokenEnum'
|
||||||
|
G = 7
|
||||||
|
H = 8
|
||||||
|
I = 9
|
||||||
|
self.assertIs(MyUnBrokenEnum._member_type_, UnBrokenInt)
|
||||||
|
self.assertIs(MyUnBrokenEnum(7), MyUnBrokenEnum.G)
|
||||||
|
globals()['UnBrokenInt'] = UnBrokenInt
|
||||||
|
globals()['MyUnBrokenEnum'] = MyUnBrokenEnum
|
||||||
|
test_pickle_dump_load(self.assertIs, MyUnBrokenEnum.I)
|
||||||
|
test_pickle_dump_load(self.assertIs, MyUnBrokenEnum)
|
||||||
|
|
||||||
def test_too_many_data_types(self):
|
def test_too_many_data_types(self):
|
||||||
with self.assertRaisesRegex(TypeError, 'too many data types'):
|
with self.assertRaisesRegex(TypeError, 'too many data types'):
|
||||||
|
@ -3591,7 +3614,7 @@ class TestVerify(unittest.TestCase):
|
||||||
self.assertEqual(Bizarre.d.value, 6)
|
self.assertEqual(Bizarre.d.value, 6)
|
||||||
with self.assertRaisesRegex(
|
with self.assertRaisesRegex(
|
||||||
ValueError,
|
ValueError,
|
||||||
"invalid Flag 'Bizarre': aliases b and d are missing combined values of 0x3 .use `enum.show_flag_values.value.` for details.",
|
"invalid Flag 'Bizarre': aliases b and d are missing combined values of 0x3 .use enum.show_flag_values.value. for details.",
|
||||||
):
|
):
|
||||||
@verify(NAMED_FLAGS)
|
@verify(NAMED_FLAGS)
|
||||||
class Bizarre(Flag):
|
class Bizarre(Flag):
|
||||||
|
@ -3610,7 +3633,7 @@ class TestVerify(unittest.TestCase):
|
||||||
self.assertEqual(Bizarre.d.value, 6)
|
self.assertEqual(Bizarre.d.value, 6)
|
||||||
with self.assertRaisesRegex(
|
with self.assertRaisesRegex(
|
||||||
ValueError,
|
ValueError,
|
||||||
"invalid Flag 'Bizarre': alias d is missing value 0x2 .use `enum.show_flag_values.value.` for details.",
|
"invalid Flag 'Bizarre': alias d is missing value 0x2 .use enum.show_flag_values.value. for details.",
|
||||||
):
|
):
|
||||||
@verify(NAMED_FLAGS)
|
@verify(NAMED_FLAGS)
|
||||||
class Bizarre(IntFlag):
|
class Bizarre(IntFlag):
|
||||||
|
|
|
@ -970,6 +970,7 @@ Andrew Kuchling
|
||||||
Jakub Kuczys
|
Jakub Kuczys
|
||||||
Dave Kuhlman
|
Dave Kuhlman
|
||||||
Jon Kuhn
|
Jon Kuhn
|
||||||
|
Andrei Kulakov
|
||||||
Ilya Kulakov
|
Ilya Kulakov
|
||||||
Upendra Kumar
|
Upendra Kumar
|
||||||
Toshio Kuratomi
|
Toshio Kuratomi
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue