[Zodb-checkins] SVN: ZODB/trunk/src/ZEO/tests/InvalidationTests.py Fixed spurious scary intermittent test failure.
Jim Fulton
jim at zope.com
Fri Sep 5 13:57:44 EDT 2008
Log message for revision 90882:
Fixed spurious scary intermittent test failure.
Changed:
U ZODB/trunk/src/ZEO/tests/InvalidationTests.py
-=-
Modified: ZODB/trunk/src/ZEO/tests/InvalidationTests.py
===================================================================
--- ZODB/trunk/src/ZEO/tests/InvalidationTests.py 2008-09-05 17:56:56 UTC (rev 90881)
+++ ZODB/trunk/src/ZEO/tests/InvalidationTests.py 2008-09-05 17:57:43 UTC (rev 90882)
@@ -143,24 +143,25 @@
self.commitdict = commitdict
def _testrun(self):
- cn = self.db.open()
+ tm = transaction.TransactionManager()
+ cn = self.db.open(transaction_manager=tm)
while not self.stop.isSet():
try:
tree = cn.root()["tree"]
break
except (ConflictError, KeyError):
- transaction.abort()
+ tm.abort()
key = self.startnum
while not self.stop.isSet():
try:
tree[key] = self.threadnum
- transaction.get().note("add key %s" % key)
- transaction.commit()
+ tm.get().note("add key %s" % key)
+ tm.commit()
self.commitdict[self] = 1
if self.sleep:
time.sleep(self.sleep)
except (ReadConflictError, ConflictError), msg:
- transaction.abort()
+ tm.abort()
else:
self.added_keys.append(key)
key += self.step
@@ -269,16 +270,23 @@
def _check_threads(self, tree, *threads):
# Make sure the thread's view of the world is consistent with
# the actual database state.
+
expected_keys = []
- errormsgs = []
- err = errormsgs.append
for t in threads:
if not t.added_keys:
err("thread %d didn't add any keys" % t.threadnum)
expected_keys.extend(t.added_keys)
expected_keys.sort()
- actual_keys = list(tree.keys())
- if expected_keys != actual_keys:
+
+ for i in range(100):
+ tree._p_jar.sync()
+ actual_keys = list(tree.keys())
+ if expected_keys == actual_keys:
+ break
+ time.sleep(.1)
+ else:
+ errormsgs = []
+ err = errormsgs.append
err("expected keys != actual keys")
for k in expected_keys:
if k not in actual_keys:
@@ -286,8 +294,7 @@
for k in actual_keys:
if k not in expected_keys:
err("key %s in tree but not expected" % k)
- if errormsgs:
- display(tree)
+
self.fail('\n'.join(errormsgs))
def go(self, stop, commitdict, *threads):
@@ -419,10 +426,9 @@
self.go(stop, cd, t1, t2, t3)
while db1.lastTransaction() != db2.lastTransaction():
- db1._storage.sync()
- db2._storage.sync()
+ time.sleep(.1)
-
+ time.sleep(.1)
cn = db1.open()
tree = cn.root()["tree"]
self._check_tree(cn, tree)
More information about the Zodb-checkins
mailing list