summaryrefslogtreecommitdiff
path: root/Lib
diff options
context:
space:
mode:
authorTim Peters <tim.peters@gmail.com>2001-05-29 21:14:32 +0000
committerTim Peters <tim.peters@gmail.com>2001-05-29 21:14:32 +0000
commit0e1a1f6d2d02be8c70af2357edc1692f615dbbbf (patch)
tree4598288eaf48adddfef64273c66e24050d5cc161 /Lib
parent2955c11f30f8f7b381e8650dc1cb15e3ecd32698 (diff)
downloadcpython-0e1a1f6d2d02be8c70af2357edc1692f615dbbbf.tar.gz
BadDictKey test: The output file expected "raising error" to be printed
exactly once. But the test code can't know that, as the number of times __cmp__ is called depends on internal details of the dict implementation. This is especially nasty because the __hash__ method returns the address of the class object, so the hash codes seen by the dict can vary across runs, causing the dict to use a different probe order across runs. I just happened to see this test fail about 1 run in 7 today, but only under a release build and when passing -O to Python. So, changed the test to be predictable across runs.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_operations.py11
1 files changed, 10 insertions, 1 deletions
diff --git a/Lib/test/test_operations.py b/Lib/test/test_operations.py
index 3a9a37934c..b599c9da9e 100644
--- a/Lib/test/test_operations.py
+++ b/Lib/test/test_operations.py
@@ -11,12 +11,21 @@ print '3.1 Dictionary lookups succeed even if __cmp__() raises an exception'
# http://sourceforge.net/bugs/?func=detailbug&bug_id=112558&group_id=5470
class BadDictKey:
+ already_printed_raising_error = 0
+
def __hash__(self):
return hash(self.__class__)
def __cmp__(self, other):
if isinstance(other, self.__class__):
- print "raising error"
+ if not BadDictKey.already_printed_raising_error:
+ # How many times __cmp__ gets called depends on the hash
+ # code and the internals of the dict implementation; we
+ # know it will be called at least once, but that's it.
+ # already_printed_raising_error makes sure the expected-
+ # output file prints the msg at most once.
+ BadDictKey.already_printed_raising_error = 1
+ print "raising error"
raise RuntimeError, "gotcha"
return other