From: Dong-hee Na Date: Wed, 21 Jun 2017 16:52:32 +0000 (+0900) Subject: bpo-30616: Functional API of enum allows to create empty enums. (#2304) X-Git-Tag: v3.7.0a1~553 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=dcc8ce44c74492670e6bfbde588a2acbf8f365e0;p=python bpo-30616: Functional API of enum allows to create empty enums. (#2304) * bpo-30616: Functional API of enum allows to create empty enums. * Update NEWS move addition to avoid conflict --- diff --git a/Lib/enum.py b/Lib/enum.py index 056400d04c..73dd613887 100644 --- a/Lib/enum.py +++ b/Lib/enum.py @@ -381,7 +381,7 @@ class EnumMeta(type): # special processing needed for names? if isinstance(names, str): names = names.replace(',', ' ').split() - if isinstance(names, (tuple, list)) and isinstance(names[0], str): + if isinstance(names, (tuple, list)) and names and isinstance(names[0], str): original_names, names = names, [] last_values = [] for count, name in enumerate(original_names): diff --git a/Lib/test/test_enum.py b/Lib/test/test_enum.py index a973081644..ea52de7a5f 100644 --- a/Lib/test/test_enum.py +++ b/Lib/test/test_enum.py @@ -2291,6 +2291,26 @@ class TestIntFlag(unittest.TestCase): self.assertIs(type(e), Perm) + def test_programatic_function_from_empty_list(self): + Perm = enum.IntFlag('Perm', []) + lst = list(Perm) + self.assertEqual(len(lst), len(Perm)) + self.assertEqual(len(Perm), 0, Perm) + Thing = enum.Enum('Thing', []) + lst = list(Thing) + self.assertEqual(len(lst), len(Thing)) + self.assertEqual(len(Thing), 0, Thing) + + + def test_programatic_function_from_empty_tuple(self): + Perm = enum.IntFlag('Perm', ()) + lst = list(Perm) + self.assertEqual(len(lst), len(Perm)) + self.assertEqual(len(Perm), 0, Perm) + Thing = enum.Enum('Thing', ()) + self.assertEqual(len(lst), len(Thing)) + self.assertEqual(len(Thing), 0, Thing) + def test_containment(self): Perm = self.Perm R, W, X = Perm diff --git a/Misc/NEWS b/Misc/NEWS index f8833aafd6..299d9c2784 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -385,6 +385,9 @@ Library correctly returns the ``127.0.0.1`` host, instead of treating ``@evil.com`` as the host in an authentification (``login@host``). +- bpo-30616: Functional API of enum allows to create empty enums. + Patched by Dong-hee Na + - bpo-30038: Fix race condition between signal delivery and wakeup file descriptor. Patch by Nathaniel Smith.