[Zope3-checkins] CVS: Zope3/lib/python/ZODB/tests - ConflictResolution.py:1.11

Jeremy Hylton jeremy@zope.com
Mon, 2 Dec 2002 14:17:02 -0500


Update of /cvs-repository/Zope3/lib/python/ZODB/tests
In directory cvs.zope.org:/tmp/cvs-serv25305/ZODB/tests

Modified Files:
	ConflictResolution.py 
Log Message:
Revise handling of bad classes during ConflictResolution.

Extend test suite to verify that classes are recognized as
unresolvable().  This, unfortunately, extends into the ZEO test suite,
because a ZEO client doesn't know enough to support the test.


=== Zope3/lib/python/ZODB/tests/ConflictResolution.py 1.10 => 1.11 ===
--- Zope3/lib/python/ZODB/tests/ConflictResolution.py:1.10	Thu Sep 19 15:13:50 2002
+++ Zope3/lib/python/ZODB/tests/ConflictResolution.py	Mon Dec  2 14:17:01 2002
@@ -15,6 +15,7 @@
 
 from ZODB.ZTransaction import Transaction
 from ZODB.POSException import ConflictError, UndoError
+from ZODB.ConflictResolution import ResolveObjectReader
 from Persistence import Persistent
 
 from ZODB.tests.StorageTestBase import zodb_unpickle, zodb_pickle
@@ -34,6 +35,9 @@
     def inc(self):
         self._value = self._value + 1
 
+class RPCounter(PCounter):
+    """Version of PCounter that supports conflict resolution."""
+
     def _p_resolveConflict(self, oldState, savedState, newState):
         savedDiff = savedState['_value'] - oldState['_value']
         newDiff = newState['_value'] - oldState['_value']
@@ -46,7 +50,6 @@
     # conflict, but did something wrong?
 
 class PCounter2(PCounter):
-
     def _p_resolveConflict(self, oldState, savedState, newState):
         raise ConflictError
 
@@ -61,7 +64,7 @@
 class ConflictResolvingStorage:
 
     def checkResolve(self):
-        obj = PCounter()
+        obj = RPCounter()
         obj.inc()
 
         oid = self._storage.new_oid()
@@ -80,7 +83,29 @@
         inst = zodb_unpickle(data)
         self.assertEqual(inst._value, 5)
 
-    def checkUnresolvable(self):
+    def unresolvable(self, klass):
+        self.assert_(ResolveObjectReader.unresolvable(PCounter))
+
+    def checkUnresolvable1(self):
+        obj = PCounter()
+        obj.inc()
+
+        oid = self._storage.new_oid()
+
+        revid1 = self._dostoreNP(oid, data=zodb_pickle(obj))
+
+        obj.inc()
+        obj.inc()
+        # The effect of committing two transactions with the same
+        # pickle is to commit two different transactions relative to
+        # revid1 that add two to _value.  
+        revid2 = self._dostoreNP(oid, revid=revid1, data=zodb_pickle(obj))
+        self.assertRaises(ConflictError,
+                          self._dostoreNP,
+                          oid, revid=revid1, data=zodb_pickle(obj))
+        self.unresolvable(PCounter)
+
+    def checkUnresolvable2(self):
         obj = PCounter2()
         obj.inc()
 
@@ -115,6 +140,7 @@
         self.assertRaises(AttributeError,
                           self._dostoreNP,
                           oid, revid=revid1, data=zodb_pickle(obj))
+        print ResolveObjectReader.bad_classes
 
     def checkBuggyResolve2(self):
         obj = PCounter4()
@@ -133,6 +159,7 @@
         self.assertRaises(TypeError,
                           self._dostoreNP,
                           oid, revid=revid1, data=zodb_pickle(obj))
+        print ResolveObjectReader.bad_classes
 
 class ConflictResolvingTransUndoStorage: