summaryrefslogtreecommitdiff
path: root/Lib/test/test_functools.py
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2021-08-06 13:11:44 -0700
committerGitHub <noreply@github.com>2021-08-06 15:11:44 -0500
commit66dd1a0e645f26b074547dccc92448169cb32410 (patch)
treee3e48cd6f37ec7cf3661402aefb648bfca1da3fb /Lib/test/test_functools.py
parent1e9c9ca570ffe92dc6a60825c2f9c91865129b8f (diff)
downloadcpython-git-66dd1a0e645f26b074547dccc92448169cb32410.tar.gz
bpo-44605: Teach @total_ordering() to work with metaclasses (GH-27633) (GH-27640)
Diffstat (limited to 'Lib/test/test_functools.py')
-rw-r--r--Lib/test/test_functools.py28
1 files changed, 28 insertions, 0 deletions
diff --git a/Lib/test/test_functools.py b/Lib/test/test_functools.py
index 78a8a5fcc0..fbf5578872 100644
--- a/Lib/test/test_functools.py
+++ b/Lib/test/test_functools.py
@@ -1163,6 +1163,34 @@ class TestTotalOrdering(unittest.TestCase):
method_copy = pickle.loads(pickle.dumps(method, proto))
self.assertIs(method_copy, method)
+
+ def test_total_ordering_for_metaclasses_issue_44605(self):
+
+ @functools.total_ordering
+ class SortableMeta(type):
+ def __new__(cls, name, bases, ns):
+ return super().__new__(cls, name, bases, ns)
+
+ def __lt__(self, other):
+ if not isinstance(other, SortableMeta):
+ pass
+ return self.__name__ < other.__name__
+
+ def __eq__(self, other):
+ if not isinstance(other, SortableMeta):
+ pass
+ return self.__name__ == other.__name__
+
+ class B(metaclass=SortableMeta):
+ pass
+
+ class A(metaclass=SortableMeta):
+ pass
+
+ self.assertTrue(A < B)
+ self.assertFalse(A > B)
+
+
@functools.total_ordering
class Orderable_LT:
def __init__(self, value):