[Zodb-checkins] CVS: ZODB/src/ZODB/tests - PackableStorage.py:1.35
Tim Peters
tim.one at comcast.net
Fri Mar 12 21:49:23 EST 2004
Update of /cvs-repository/ZODB/src/ZODB/tests
In directory cvs.zope.org:/tmp/cvs-serv9728/src/ZODB/tests
Modified Files:
PackableStorage.py
Log Message:
New (but disabled for now) test checkPackLotsWhileWriting reliably dies
with
CorruptedError: ... transaction with checkpoint flag set
on my box when doing the ZEO flavor of FileStorage. This is like the
other pack-while-writing tests, but uses only 1 client thread that does
twice as much, and packs repeatedly for so long as that thread runs. I
usually see it fail before the fourth pack attempt.
=== ZODB/src/ZODB/tests/PackableStorage.py 1.34 => 1.35 ===
--- ZODB/src/ZODB/tests/PackableStorage.py:1.34 Fri Mar 12 14:41:50 2004
+++ ZODB/src/ZODB/tests/PackableStorage.py Fri Mar 12 21:49:22 2004
@@ -248,17 +248,66 @@
if not hasattr(self._storage, "iterator"):
return
- iter = self._storage.iterator()
- for txn in iter:
+ it = self._storage.iterator()
+ for txn in it:
for data in txn:
pass
- iter.close()
+ it.close()
def checkPackWhileWriting(self):
self._PackWhileWriting(pack_now=False)
def checkPackNowWhileWriting(self):
self._PackWhileWriting(pack_now=True)
+
+ # XXX Disabled because it always fails now.
+ def XXXcheckPackLotsWhileWriting(self):
+ # This is like the other pack-while-writing tests, except it packs
+ # repeatedly until the client thread is done. At the time it was
+ # introduced, it reliably provoked
+ # CorruptedError: ... transaction with checkpoint flag set
+ # in the ZEO flavor of the FileStorage tests.
+
+ db = DB(self._storage)
+ conn = db.open()
+ root = conn.root()
+
+ choices = range(10)
+ for i in choices:
+ root[i] = MinPO(i)
+ get_transaction().commit()
+
+ snooze()
+ packt = time.time()
+
+ for dummy in choices:
+ for i in choices:
+ root[i].value = MinPO(i)
+ get_transaction().commit()
+
+ NUM_LOOP_TRIP = 100
+ timer = ElapsedTimer(time.time())
+ threads = [ClientThread(db, choices, NUM_LOOP_TRIP, timer, i)
+ for i in range(1)]
+ for t in threads:
+ t.start()
+
+ while True in [t.isAlive() for t in threads]:
+ db.pack(packt)
+ snooze()
+ packt = time.time()
+
+ for t in threads:
+ t.join()
+
+ # Iterate over the storage to make sure it's sane.
+ if not hasattr(self._storage, "iterator"):
+ return
+ it = self._storage.iterator()
+ for txn in it:
+ for data in txn:
+ pass
+ it.close()
class PackableUndoStorage(PackableStorageBase):
More information about the Zodb-checkins
mailing list