[Zope-Checkins] CVS: StandaloneZODB/ZODB/tests - TransactionalUndoStorage.py:1.15
Barry Warsaw
barry@wooz.org
Thu, 28 Mar 2002 16:04:50 -0500
Update of /cvs-repository/StandaloneZODB/ZODB/tests
In directory cvs.zope.org:/tmp/cvs-serv1790
Modified Files:
TransactionalUndoStorage.py
Log Message:
checkTransactionalUndoAfterPack(): This is a test which should provoke
the underlying bug in transactionalUndo() on a standby storage. If
our hypothesis is correct, the bug is in FileStorage, and is caused by
encoding the file position in the `id' field of the undoLog
information. Note that Full just encodes the tid, but this is a
problem for FileStorage (we have a strategy for fixing this).
NOTE: checking this in on the trunk is mildly antisocial because it
introduces failures in the test suite. I'm doing it this way because
1) it really isn't worth a branch, even a short lived one; 2) Jeremy
may have time to look at it before tomorrow; 3) I don't trust my
machine not to lock up and make this mod unavailable. :(
Either way, this /will/ get fixed by tomorrow.
=== StandaloneZODB/ZODB/tests/TransactionalUndoStorage.py 1.14 => 1.15 ===
"""
+import time
import types
from ZODB import POSException
from ZODB.Transaction import Transaction
+from ZODB.referencesf import referencesf
from ZODB.tests.MinPO import MinPO
from ZODB.tests.StorageTestBase import zodb_pickle, zodb_unpickle
@@ -421,3 +423,29 @@
self._storage.transactionalUndo,
tid, t)
self._storage.tpc_abort(t)
+
+ def checkTransactionalUndoAfterPack(self):
+ eq = self.assertEqual
+ # Add a few object revisions
+ oid = self._storage.new_oid()
+ revid1 = self._dostore(oid, data=MinPO(51))
+ revid2 = self._dostore(oid, revid=revid1, data=MinPO(52))
+ revid3 = self._dostore(oid, revid=revid2, data=MinPO(53))
+ # Now get the undo log
+ info = self._storage.undoInfo()
+ tid = info[0]['id']
+ # Now pack just the initial revision of the object. We need the
+ # second revision otherwise we won't be able to undo the third
+ # revision!
+ self._storage.pack(revid1, referencesf)
+ # And now attempt to undo the last transaction
+ t = Transaction()
+ self._storage.tpc_begin(t)
+ oids = self._storage.transactionalUndo(tid, t)
+ self._storage.tpc_vote(t)
+ self._storage.tpc_finish(t)
+ eq(len(oids), 1)
+ eq(oids[0], oid)
+ data, revid = self._storage.load(oid, '')
+ # The object must now be at the second state
+ eq(zodb_unpickle(data), MinPO(52))