From 4710c53dcad1ebf3755f3efb9e80ac24bd72a9b2 Mon Sep 17 00:00:00 2001 From: darylm503 Date: Mon, 16 Apr 2012 22:12:42 +0000 Subject: AppPkg/Applications/Python: Add Python 2.7.2 sources since the release of Python 2.7.3 made them unavailable from the python.org web site. These files are a subset of the python-2.7.2.tgz distribution from python.org. Changed files from PyMod-2.7.2 have been copied into the corresponding directories of this tree, replacing the original files in the distribution. Signed-off-by: daryl.mcdaniel@intel.com git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13197 6f19259b-4bc3-4df7-8a09-765794883524 --- .../Python/Python-2.7.2/Lib/test/test_hash.py | 144 +++++++++++++++++++++ 1 file changed, 144 insertions(+) create mode 100644 AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_hash.py (limited to 'AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_hash.py') diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_hash.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_hash.py new file mode 100644 index 0000000000..4a12f14233 --- /dev/null +++ b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_hash.py @@ -0,0 +1,144 @@ +# test the invariant that +# iff a==b then hash(a)==hash(b) +# +# Also test that hash implementations are inherited as expected + +import unittest +from test import test_support +from collections import Hashable + + +class HashEqualityTestCase(unittest.TestCase): + + def same_hash(self, *objlist): + # Hash each object given and fail if + # the hash values are not all the same. + hashed = map(hash, objlist) + for h in hashed[1:]: + if h != hashed[0]: + self.fail("hashed values differ: %r" % (objlist,)) + + def test_numeric_literals(self): + self.same_hash(1, 1L, 1.0, 1.0+0.0j) + self.same_hash(0, 0L, 0.0, 0.0+0.0j) + self.same_hash(-1, -1L, -1.0, -1.0+0.0j) + self.same_hash(-2, -2L, -2.0, -2.0+0.0j) + + def test_coerced_integers(self): + self.same_hash(int(1), long(1), float(1), complex(1), + int('1'), float('1.0')) + self.same_hash(int(-2**31), long(-2**31), float(-2**31)) + self.same_hash(int(1-2**31), long(1-2**31), float(1-2**31)) + self.same_hash(int(2**31-1), long(2**31-1), float(2**31-1)) + # for 64-bit platforms + self.same_hash(int(2**31), long(2**31), float(2**31)) + self.same_hash(int(-2**63), long(-2**63), float(-2**63)) + self.same_hash(int(1-2**63), long(1-2**63)) + self.same_hash(int(2**63-1), long(2**63-1)) + self.same_hash(long(2**63), float(2**63)) + + def test_coerced_floats(self): + self.same_hash(long(1.23e300), float(1.23e300)) + self.same_hash(float(0.5), complex(0.5, 0.0)) + + +_default_hash = object.__hash__ +class DefaultHash(object): pass + +_FIXED_HASH_VALUE = 42 +class FixedHash(object): + def __hash__(self): + return _FIXED_HASH_VALUE + +class OnlyEquality(object): + def __eq__(self, other): + return self is other + # Trick to suppress Py3k warning in 2.x + __hash__ = None +del OnlyEquality.__hash__ + +class OnlyInequality(object): + def __ne__(self, other): + return self is not other + +class OnlyCmp(object): + def __cmp__(self, other): + return cmp(id(self), id(other)) + # Trick to suppress Py3k warning in 2.x + __hash__ = None +del OnlyCmp.__hash__ + +class InheritedHashWithEquality(FixedHash, OnlyEquality): pass +class InheritedHashWithInequality(FixedHash, OnlyInequality): pass +class InheritedHashWithCmp(FixedHash, OnlyCmp): pass + +class NoHash(object): + __hash__ = None + +class HashInheritanceTestCase(unittest.TestCase): + default_expected = [object(), + DefaultHash(), + OnlyEquality(), + OnlyInequality(), + OnlyCmp(), + ] + fixed_expected = [FixedHash(), + InheritedHashWithEquality(), + InheritedHashWithInequality(), + InheritedHashWithCmp(), + ] + error_expected = [NoHash()] + + def test_default_hash(self): + for obj in self.default_expected: + self.assertEqual(hash(obj), _default_hash(obj)) + + def test_fixed_hash(self): + for obj in self.fixed_expected: + self.assertEqual(hash(obj), _FIXED_HASH_VALUE) + + def test_error_hash(self): + for obj in self.error_expected: + self.assertRaises(TypeError, hash, obj) + + def test_hashable(self): + objects = (self.default_expected + + self.fixed_expected) + for obj in objects: + self.assertIsInstance(obj, Hashable) + + def test_not_hashable(self): + for obj in self.error_expected: + self.assertNotIsInstance(obj, Hashable) + + +# 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, + HashBuiltinsTestCase) + + +if __name__ == "__main__": + test_main() -- cgit v1.2.3