summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEthan Furman <ethan@stoneleaf.us>2016-04-14 06:52:09 (GMT)
committerEthan Furman <ethan@stoneleaf.us>2016-04-14 06:52:09 (GMT)
commit5de67b106ac980d9fe2bbe2a40cac8265b069c55 (patch)
treea42ade70413e57ad7095cf4e15f527ec0d81ef33
parentb9869dfe353b116f3b8e208339c034a2ee5bc869 (diff)
downloadcpython-5de67b106ac980d9fe2bbe2a40cac8265b069c55.zip
cpython-5de67b106ac980d9fe2bbe2a40cac8265b069c55.tar.gz
cpython-5de67b106ac980d9fe2bbe2a40cac8265b069c55.tar.bz2
Issue26748: Enum classes should evaluate as True
-rw-r--r--Lib/enum.py6
-rw-r--r--Lib/test/test_enum.py13
2 files changed, 19 insertions, 0 deletions
diff --git a/Lib/enum.py b/Lib/enum.py
index 3cd3df8..7cb9d45 100644
--- a/Lib/enum.py
+++ b/Lib/enum.py
@@ -193,6 +193,12 @@ class EnumMeta(type):
enum_class.__new__ = Enum.__new__
return enum_class
+ def __bool__(self):
+ """
+ classes/types should always be True.
+ """
+ return True
+
def __call__(cls, value, names=None, *, module=None, qualname=None, type=None):
"""Either returns an existing member, or creates a new enum class.
diff --git a/Lib/test/test_enum.py b/Lib/test/test_enum.py
index 5db4040..9433638 100644
--- a/Lib/test/test_enum.py
+++ b/Lib/test/test_enum.py
@@ -257,6 +257,19 @@ class TestEnum(unittest.TestCase):
with self.assertRaises(AttributeError):
del Season.SPRING.name
+ def test_bool_of_class(self):
+ class Empty(Enum):
+ pass
+ self.assertTrue(bool(Empty))
+
+ def test_bool_of_member(self):
+ class Count(Enum):
+ zero = 0
+ one = 1
+ two = 2
+ for member in Count:
+ self.assertTrue(bool(member))
+
def test_invalid_names(self):
with self.assertRaises(ValueError):
class Wrong(Enum):