diff options
author | Nick Coghlan <ncoghlan@gmail.com> | 2008-12-30 01:18:48 (GMT) |
---|---|---|
committer | Nick Coghlan <ncoghlan@gmail.com> | 2008-12-30 01:18:48 (GMT) |
commit | 180e4007661f4480c3be50289748526c2647d28e (patch) | |
tree | 9c1da39d98c91ebb08054ddb19d608596b19b498 /Lib/test/test_hash.py | |
parent | c13acb18bc2db9d8824ba94b86d8e4c8909d6b6c (diff) | |
download | cpython-180e4007661f4480c3be50289748526c2647d28e.zip cpython-180e4007661f4480c3be50289748526c2647d28e.tar.gz cpython-180e4007661f4480c3be50289748526c2647d28e.tar.bz2 |
Issue #4701: implicitly call PyType_Ready from PyObject_Hash
Diffstat (limited to 'Lib/test/test_hash.py')
-rw-r--r-- | Lib/test/test_hash.py | 25 |
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__": |