summaryrefslogtreecommitdiff
path: root/sys/lib/python/test/test_hash.py
diff options
context:
space:
mode:
authorcinap_lenrek <cinap_lenrek@localhost>2011-05-03 11:25:13 +0000
committercinap_lenrek <cinap_lenrek@localhost>2011-05-03 11:25:13 +0000
commit458120dd40db6b4df55a4e96b650e16798ef06a0 (patch)
tree8f82685be24fef97e715c6f5ca4c68d34d5074ee /sys/lib/python/test/test_hash.py
parent3a742c699f6806c1145aea5149bf15de15a0afd7 (diff)
add hg and python
Diffstat (limited to 'sys/lib/python/test/test_hash.py')
-rw-r--r--sys/lib/python/test/test_hash.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/sys/lib/python/test/test_hash.py b/sys/lib/python/test/test_hash.py
new file mode 100644
index 000000000..3d6c9d1b6
--- /dev/null
+++ b/sys/lib/python/test/test_hash.py
@@ -0,0 +1,36 @@
+# test the invariant that
+# iff a==b then hash(a)==hash(b)
+#
+
+import unittest
+from test import test_support
+
+
+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)
+
+ def test_coerced_integers(self):
+ self.same_hash(int(1), long(1), float(1), complex(1),
+ int('1'), float('1.0'))
+
+ 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))
+
+
+def test_main():
+ test_support.run_unittest(HashEqualityTestCase)
+
+
+if __name__ == "__main__":
+ test_main()