summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorNick Coghlan <ncoghlan@gmail.com>2008-12-30 01:18:48 (GMT)
committerNick Coghlan <ncoghlan@gmail.com>2008-12-30 01:18:48 (GMT)
commit180e4007661f4480c3be50289748526c2647d28e (patch)
tree9c1da39d98c91ebb08054ddb19d608596b19b498 /Lib
parentc13acb18bc2db9d8824ba94b86d8e4c8909d6b6c (diff)
downloadcpython-180e4007661f4480c3be50289748526c2647d28e.zip
cpython-180e4007661f4480c3be50289748526c2647d28e.tar.gz
cpython-180e4007661f4480c3be50289748526c2647d28e.tar.bz2
Issue #4701: implicitly call PyType_Ready from PyObject_Hash
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_hash.py25
1 files changed, 24 insertions, 1 deletions
diff --git a/Lib/test/test_hash.py b/Lib/test/test_hash.py
index 47c66d1..7ce40b9 100644
--- a/Lib/test/test_hash.py
+++ b/Lib/test/test_hash.py
@@ -111,9 +111,32 @@ class HashInheritanceTestCase(unittest.TestCase):
self.assertFalse(isinstance(obj, Hashable), repr(obj))
+# Issue #4701: Check that some builtin types are correctly hashable
+# (This test only used to fail in Python 3.0, but has been included
+# in 2.x along with the lazy call to PyType_Ready in PyObject_Hash)
+class DefaultIterSeq(object):
+ seq = range(10)
+ def __len__(self):
+ return len(self.seq)
+ def __getitem__(self, index):
+ return self.seq[index]
+
+class HashBuiltinsTestCase(unittest.TestCase):
+ hashes_to_check = [xrange(10),
+ enumerate(xrange(10)),
+ iter(DefaultIterSeq()),
+ iter(lambda: 0, 0),
+ ]
+
+ def test_hashes(self):
+ _default_hash = object.__hash__
+ for obj in self.hashes_to_check:
+ self.assertEqual(hash(obj), _default_hash(obj))
+
def test_main():
test_support.run_unittest(HashEqualityTestCase,
- HashInheritanceTestCase)
+ HashInheritanceTestCase,
+ HashBuiltinsTestCase)
if __name__ == "__main__":