[Zope-Checkins] CVS: Zope2 - TransactionalUndoStorage.py:1.2

Jim Fulton jim@digicool.com
Tue, 10 Apr 2001 19:09:23 -0400 (EDT)


Update of /cvs-repository/Zope2/lib/python/ZODB/tests
In directory korak:/tmp/cvs-serv10152

Modified Files:
	TransactionalUndoStorage.py 
Log Message:
Changed to use undoInfo.



--- Updated File TransactionalUndoStorage.py in package Zope2/lib/python/ZODB --
--- TransactionalUndoStorage.py	2001/04/10 20:45:58	1.1
+++ TransactionalUndoStorage.py	2001/04/10 23:09:21	1.2
@@ -1,17 +1,22 @@
 
 import BasicStorage, pickle
 from ZODB import POSException
+ZERO = '\0'*8
 
-class UndoStorage(BasicStorage.BasicStorage):
+class TransactionalUndoStorage(BasicStorage.BasicStorage):
 
     def checkSimpleTransactionalUndo(self):
         oid = self._storage.new_oid()
         revid = self._dostore(oid, data=23)
         revid = self._dostore(oid, revid=revid, data=24)
         revid = self._dostore(oid, revid=revid, data=25)
+
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         # Now start an undo transaction
+        self._transaction.note('undo1')
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -19,8 +24,11 @@
         data, revid = self._storage.load(oid, '')
         assert pickle.loads(data) == 24
         # Do another one
+        info =self._storage.undoInfo()
+        tid = info[2]['id']
+        self._transaction.note('undo2')
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -28,26 +36,24 @@
         data, revid = self._storage.load(oid, '')
         assert pickle.loads(data) == 23
         # Try to undo the first record
+        info =self._storage.undoInfo()
+        tid = info[4]['id']
+        self._transaction.note('undo3')
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
+
         assert len(oids) == 1
         assert oids[0] == oid
         # This should fail since we've undone the object's creation
         self.assertRaises(KeyError,
                           self._storage.load, oid, '')
-        # But it's really a more specific type of error
-        import Full
-        self.assertRaises(Full.ObjectDoesNotExist,
-                          self._storage.load, oid, '')
         # And now let's try to redo the object's creation
-        try:
-            self._storage.load(oid, '')
-        except Full.ObjectDoesNotExist, e:
-            revid = e.revid
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -83,8 +89,10 @@
         data, revid2 = self._storage.load(oid2, '')
         assert pickle.loads(data) == 52
         # Now attempt to undo the transaction containing two objects
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid1, 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
@@ -94,7 +102,7 @@
         data, revid2 = self._storage.load(oid2, '')
         assert pickle.loads(data) == 51
 
-    def checkTwoObjectUndoAgain(self):
+    def _checkTwoObjectUndoAgain(self):
         p32, p33, p52, p53 = map(pickle.dumps, (32, 33, 52, 53))
         # Like the above, but the first revision of the objects are stored in
         # different transactions.
@@ -111,8 +119,10 @@
         self._storage.tpc_finish(self._transaction)
         assert revid1 == revid2
         # Now attempt to undo the transaction containing two objects
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid1, 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
@@ -134,8 +144,10 @@
         revid1 = self._dostore(oid1, revid=revid1, data=34)
         revid2 = self._dostore(oid2, revid=revid2, data=54)
         # Now attempt to undo the transaction containing two objects
+        info =self._storage.undoInfo()
+        tid = info[1]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid1, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -152,10 +164,12 @@
         revid_b = self._dostore(oid, revid=revid_a, data=52)
         revid_c = self._dostore(oid, revid=revid_b, data=53)
         # Start the undo
+        info =self._storage.undoInfo()
+        tid = info[1]['id']
         self._storage.tpc_begin(self._transaction)
         self.assertRaises(POSException.UndoError,
                           self._storage.transactionalUndo,
-                          revid_b, self._transaction)
+                          tid, self._transaction)
         self._storage.tpc_abort(self._transaction)
         # Now have more fun: object1 and object2 are in the same transaction,
         # which we'll try to undo to, but one of them has since modified in
@@ -165,6 +179,7 @@
         oid2 = self._storage.new_oid()
         revid2 = ZERO
         p81, p82, p91, p92 = map(pickle.dumps, (81, 82, 91, 92))
+
         self._storage.tpc_begin(self._transaction)
         revid1 = self._storage.store(oid1, revid1, p81, '', self._transaction)
         revid2 = self._storage.store(oid2, revid2, p91, '', self._transaction)
@@ -180,11 +195,10 @@
         # Now modify oid2
         revid2 = self._dostore(oid2, revid=revid2, data=p92)
         assert revid1 <> revid2 and revid2 <> revid_22
+        info =self._storage.undoInfo()
+        tid = info[1]['id']
         self._storage.tpc_begin(self._transaction)
         self.assertRaises(POSException.UndoError,
-                          self._storage.transactionalUndo,
-                          revid1, self._transaction)
-        self.assertRaises(POSException.UndoError,
                           self._storage.transactionalUndo,
-                          revid_22, self._transaction)
+                          tid, self._transaction)
         self._storage.tpc_abort(self._transaction)



--- Updated File TransactionalUndoStorage.py in package Zope2 --
--- TransactionalUndoStorage.py	2001/04/10 20:45:58	1.1
+++ TransactionalUndoStorage.py	2001/04/10 23:09:21	1.2
@@ -1,17 +1,22 @@
 
 import BasicStorage, pickle
 from ZODB import POSException
+ZERO = '\0'*8
 
-class UndoStorage(BasicStorage.BasicStorage):
+class TransactionalUndoStorage(BasicStorage.BasicStorage):
 
     def checkSimpleTransactionalUndo(self):
         oid = self._storage.new_oid()
         revid = self._dostore(oid, data=23)
         revid = self._dostore(oid, revid=revid, data=24)
         revid = self._dostore(oid, revid=revid, data=25)
+
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         # Now start an undo transaction
+        self._transaction.note('undo1')
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -19,8 +24,11 @@
         data, revid = self._storage.load(oid, '')
         assert pickle.loads(data) == 24
         # Do another one
+        info =self._storage.undoInfo()
+        tid = info[2]['id']
+        self._transaction.note('undo2')
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -28,26 +36,24 @@
         data, revid = self._storage.load(oid, '')
         assert pickle.loads(data) == 23
         # Try to undo the first record
+        info =self._storage.undoInfo()
+        tid = info[4]['id']
+        self._transaction.note('undo3')
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
+
         assert len(oids) == 1
         assert oids[0] == oid
         # This should fail since we've undone the object's creation
         self.assertRaises(KeyError,
                           self._storage.load, oid, '')
-        # But it's really a more specific type of error
-        import Full
-        self.assertRaises(Full.ObjectDoesNotExist,
-                          self._storage.load, oid, '')
         # And now let's try to redo the object's creation
-        try:
-            self._storage.load(oid, '')
-        except Full.ObjectDoesNotExist, e:
-            revid = e.revid
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -83,8 +89,10 @@
         data, revid2 = self._storage.load(oid2, '')
         assert pickle.loads(data) == 52
         # Now attempt to undo the transaction containing two objects
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid1, 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
@@ -94,7 +102,7 @@
         data, revid2 = self._storage.load(oid2, '')
         assert pickle.loads(data) == 51
 
-    def checkTwoObjectUndoAgain(self):
+    def _checkTwoObjectUndoAgain(self):
         p32, p33, p52, p53 = map(pickle.dumps, (32, 33, 52, 53))
         # Like the above, but the first revision of the objects are stored in
         # different transactions.
@@ -111,8 +119,10 @@
         self._storage.tpc_finish(self._transaction)
         assert revid1 == revid2
         # Now attempt to undo the transaction containing two objects
+        info =self._storage.undoInfo()
+        tid = info[0]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid1, 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
@@ -134,8 +144,10 @@
         revid1 = self._dostore(oid1, revid=revid1, data=34)
         revid2 = self._dostore(oid2, revid=revid2, data=54)
         # Now attempt to undo the transaction containing two objects
+        info =self._storage.undoInfo()
+        tid = info[1]['id']
         self._storage.tpc_begin(self._transaction)
-        oids = self._storage.transactionalUndo(revid1, self._transaction)
+        oids = self._storage.transactionalUndo(tid, self._transaction)
         self._storage.tpc_vote(self._transaction)
         self._storage.tpc_finish(self._transaction)
         assert len(oids) == 1
@@ -152,10 +164,12 @@
         revid_b = self._dostore(oid, revid=revid_a, data=52)
         revid_c = self._dostore(oid, revid=revid_b, data=53)
         # Start the undo
+        info =self._storage.undoInfo()
+        tid = info[1]['id']
         self._storage.tpc_begin(self._transaction)
         self.assertRaises(POSException.UndoError,
                           self._storage.transactionalUndo,
-                          revid_b, self._transaction)
+                          tid, self._transaction)
         self._storage.tpc_abort(self._transaction)
         # Now have more fun: object1 and object2 are in the same transaction,
         # which we'll try to undo to, but one of them has since modified in
@@ -165,6 +179,7 @@
         oid2 = self._storage.new_oid()
         revid2 = ZERO
         p81, p82, p91, p92 = map(pickle.dumps, (81, 82, 91, 92))
+
         self._storage.tpc_begin(self._transaction)
         revid1 = self._storage.store(oid1, revid1, p81, '', self._transaction)
         revid2 = self._storage.store(oid2, revid2, p91, '', self._transaction)
@@ -180,11 +195,10 @@
         # Now modify oid2
         revid2 = self._dostore(oid2, revid=revid2, data=p92)
         assert revid1 <> revid2 and revid2 <> revid_22
+        info =self._storage.undoInfo()
+        tid = info[1]['id']
         self._storage.tpc_begin(self._transaction)
         self.assertRaises(POSException.UndoError,
-                          self._storage.transactionalUndo,
-                          revid1, self._transaction)
-        self.assertRaises(POSException.UndoError,
                           self._storage.transactionalUndo,
-                          revid_22, self._transaction)
+                          tid, self._transaction)
         self._storage.tpc_abort(self._transaction)