summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2010-08-23 17:40:33 (GMT)
committerBenjamin Peterson <benjamin@python.org>2010-08-23 17:40:33 (GMT)
commit9c2930e4bedcbb09d8a0cd484dec72c6246f6735 (patch)
tree1f515d00f8789d908edb2d2a5a5ee68aa0439fd0
parent7311729790172a6f85db0c31299f06feba217e87 (diff)
downloadcpython-9c2930e4bedcbb09d8a0cd484dec72c6246f6735.zip
cpython-9c2930e4bedcbb09d8a0cd484dec72c6246f6735.tar.gz
cpython-9c2930e4bedcbb09d8a0cd484dec72c6246f6735.tar.bz2
run total_ordering() tests, and fix the function (default comparisons shouldn't be considered)
-rw-r--r--Lib/functools.py5
-rw-r--r--Lib/test/test_functools.py3
2 files changed, 6 insertions, 2 deletions
diff --git a/Lib/functools.py b/Lib/functools.py
index bd1334b..7ce6bc2 100644
--- a/Lib/functools.py
+++ b/Lib/functools.py
@@ -65,6 +65,7 @@ def wraps(wrapped,
return partial(update_wrapper, wrapped=wrapped,
assigned=assigned, updated=updated)
+_object_defaults = {object.__lt__, object.__le__, object.__gt__, object.__ge__}
def total_ordering(cls):
"""Class decorator that fills in missing ordering methods"""
convert = {
@@ -81,7 +82,9 @@ def total_ordering(cls):
('__gt__', lambda self, other: not other >= self),
('__lt__', lambda self, other: not self >= other)]
}
- roots = set(dir(cls)) & set(convert)
+ roots = (set(dir(cls)) & set(convert))
+ # Remove default comparison operations defined on object.
+ roots -= {meth for meth in roots if getattr(cls, meth) in _object_defaults}
if not roots:
raise ValueError('must define at least one ordering operation: < > <= >=')
root = max(roots) # prefer __lt__ to __le__ to __gt__ to __ge__
diff --git a/Lib/test/test_functools.py b/Lib/test/test_functools.py
index 211ef18..41a98a2 100644
--- a/Lib/test/test_functools.py
+++ b/Lib/test/test_functools.py
@@ -481,7 +481,7 @@ class TestTotalOrdering(unittest.TestCase):
# new methods should not overwrite existing
@functools.total_ordering
class A(int):
- raise Exception()
+ pass
self.assert_(A(1) < A(2))
self.assert_(A(2) > A(1))
self.assert_(A(1) <= A(2))
@@ -564,6 +564,7 @@ def test_main(verbose=None):
TestPartialSubclass,
TestPythonPartial,
TestUpdateWrapper,
+ TestTotalOrdering,
TestWraps,
TestReduce,
TestLRU,