[Zope-Checkins] CVS: Zope3/src/ZODB/tests - testmvcc.py:1.5

Jeremy Hylton jeremy at zope.com
Fri Mar 12 00:10:09 EST 2004


Update of /cvs-repository/Zope3/src/ZODB/tests
In directory cvs.zope.org:/tmp/cvs-serv22981

Modified Files:
	testmvcc.py 
Log Message:
Fix the invalidation-during-load test to execute the branch of interest.


=== Zope3/src/ZODB/tests/testmvcc.py 1.4 => 1.5 ===
--- Zope3/src/ZODB/tests/testmvcc.py:1.4	Thu Mar 11 22:12:55 2004
+++ Zope3/src/ZODB/tests/testmvcc.py	Fri Mar 12 00:10:08 2004
@@ -256,7 +256,10 @@
 ...            self.db.invalidate(tid, {oid:1})
 ...            self.count += 1
 
-Now we'll repeat all the setup that was done earlier.
+We can execute this test with a single connection, because we're
+synthesizing the invalidation that is normally generated by the second
+connection.  We need to create two revisions so that there is a
+non-current revision to load.
 
 >>> ts = TestStorage()
 >>> db = DB(ts)
@@ -266,6 +269,8 @@
 >>> r1["a"] = MinPO(0)
 >>> r1["b"] = MinPO(0)
 >>> cn1.getTransaction().commit()
+>>> r1["b"].value = 1
+>>> cn1.getTransaction().commit()
 >>> cn1.cacheMinimize()
 
 >>> oid = r1["b"]._p_oid
@@ -280,18 +285,12 @@
 >>> r1["b"]._p_state
 -1
 >>> r1["b"]._p_activate()
-Traceback (most recent call last):
-  ...
-ReadConflictError: database read conflict error (oid 0000000000000002, class ZODB.tests.MinPO.MinPO)
 >>> oid in cn1._invalidated
 True
 >>> ts.count
 1
 
 _p_independent() still has the desired effect.
-
-We still get a non-current version if the invalidation occurs while we
-are loading the current revision.  Can that happen without ZEO?
 
 Error cases:
 - storage doesn't have an earlier revision




More information about the Zope-Checkins mailing list