Commit fa995af9 authored by Jim Fulton's avatar Jim Fulton

Fixed the test for multiple undos in the same transaction to reflect

the fact that tpc_vote and tpc_finish can be called extra times.

Also added code to same test to undo the transaction that undid
multiple transaction to exercise bug found in FileStorage.
parent 434bd7fc
...@@ -150,6 +150,9 @@ class TransactionalUndoStorage: ...@@ -150,6 +150,9 @@ class TransactionalUndoStorage:
oids1 = self._storage.transactionalUndo(tid1, self._transaction) oids1 = self._storage.transactionalUndo(tid1, self._transaction)
self._storage.tpc_vote(self._transaction) self._storage.tpc_vote(self._transaction)
self._storage.tpc_finish(self._transaction) self._storage.tpc_finish(self._transaction)
# We get the finalization stuff called an extra time:
self._storage.tpc_vote(self._transaction)
self._storage.tpc_finish(self._transaction)
assert len(oids) == 2 assert len(oids) == 2
assert len(oids1) == 2 assert len(oids1) == 2
assert oid1 in oids and oid2 in oids assert oid1 in oids and oid2 in oids
...@@ -158,6 +161,20 @@ class TransactionalUndoStorage: ...@@ -158,6 +161,20 @@ class TransactionalUndoStorage:
data, revid2 = self._storage.load(oid2, '') data, revid2 = self._storage.load(oid2, '')
assert pickle.loads(data) == 50 assert pickle.loads(data) == 50
# Now try to undo the one we just did to undo, whew
info =self._storage.undoInfo()
tid = info[0]['id']
self._storage.tpc_begin(self._transaction)
oids = self._storage.transactionalUndo(tid, self._transaction)
self._storage.tpc_vote(self._transaction)
self._storage.tpc_finish(self._transaction)
assert len(oids) == 2
data, revid1 = self._storage.load(oid1, '')
assert pickle.loads(data) == 32
data, revid2 = self._storage.load(oid2, '')
assert pickle.loads(data) == 52
def checkTwoObjectUndoAgain(self): def checkTwoObjectUndoAgain(self):
p32, p33, p52, p53 = map(pickle.dumps, (32, 33, 52, 53)) p32, p33, p52, p53 = map(pickle.dumps, (32, 33, 52, 53))
# Like the above, but the first revision of the objects are stored in # Like the above, but the first revision of the objects are stored in
...@@ -213,6 +230,7 @@ class TransactionalUndoStorage: ...@@ -213,6 +230,7 @@ class TransactionalUndoStorage:
data, revid2 = self._storage.load(oid2, '') data, revid2 = self._storage.load(oid2, '')
assert pickle.loads(data) == 54 assert pickle.loads(data) == 54
def checkNotUndoable(self): def checkNotUndoable(self):
# Set things up so we've got a transaction that can't be undone # Set things up so we've got a transaction that can't be undone
oid = self._storage.new_oid() oid = self._storage.new_oid()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment