[Zope-Checkins] CVS: Packages/ZODB - Connection.py:1.98.4.9
Tim Peters
tim.one at comcast.net
Tue Aug 31 18:52:04 EDT 2004
Update of /cvs-repository/Packages/ZODB
In directory cvs.zope.org:/tmp/cvs-serv6620/lib/python/ZODB
Modified Files:
Tag: Zope-2_7-branch
Connection.py
Log Message:
_handle_independent(): Failed to record that a ReadConflictError was
raised for an object with a _p_independent() method that returned
false.
=== Packages/ZODB/Connection.py 1.98.4.8 => 1.98.4.9 ===
--- Packages/ZODB/Connection.py:1.98.4.8 Tue Aug 31 18:07:21 2004
+++ Packages/ZODB/Connection.py Tue Aug 31 18:51:34 2004
@@ -97,6 +97,15 @@
self._inv_lock = threading.Lock()
self._invalidated = d = {}
self._invalid = d.has_key
+
+ # We intend to prevent committing a transaction in which
+ # ReadConflictError occurs. _conflicts is the set of oids that
+ # experienced ReadConflictError. Any time we raise ReadConflictError,
+ # the oid should be added to this set, and we should be sure that the
+ # object is registered with the transaction. Because it's registered,
+ # Transaction.commit() will call Connection.commit() for it, and the
+ # latter will raise ReadConflictError again (because the oid is in
+ # _conflicts).
self._conflicts = {}
# We want to raise ConnectionStateError if an attempt to close is
@@ -650,6 +659,7 @@
self._inv_lock.release()
else:
self.getTransaction().register(obj)
+ self._conflicts[obj._p_oid] = 1
raise ReadConflictError(object=obj)
def _ignore_conflict(self, oid):
More information about the Zope-Checkins
mailing list