[Zope-Checkins] CVS: ZODB3/ZODB - Transaction.py:1.39.16.4

Jeremy Hylton jeremy@zope.com
Fri, 1 Nov 2002 17:07:34 -0500


Update of /cvs-repository/ZODB3/ZODB
In directory cvs.zope.org:/tmp/cvs-serv6569

Modified Files:
      Tag: ZODB3-deadlock-debug-branch
	Transaction.py 
Log Message:
Fix bug in self.log() call in _commit_errors().  

The bug prevented tpc_abort() from being called, which leads to
deadlock.


=== ZODB3/ZODB/Transaction.py 1.39.16.3 => 1.39.16.4 ===
--- ZODB3/ZODB/Transaction.py:1.39.16.3	Fri Nov  1 15:43:15 2002
+++ ZODB3/ZODB/Transaction.py	Fri Nov  1 17:07:34 2002
@@ -90,8 +90,6 @@
         entered two-phase commit yet, so no tpc_ messages are sent.
         '''
 
-        self.log("abort")
-
         if subtransaction and (self._non_st_objects is not None):
             raise POSException.TransactionError, (
                 """Attempted to abort a sub-transaction, but a participating
@@ -160,7 +158,6 @@
         '''
         if self._objects:
             self.abort(subtransaction, 0)
-        self.log("begin")
         if info:
             info=split(info,'\t')
             self.user=strip(info[0])
@@ -169,8 +166,6 @@
     def commit(self, subtransaction=None):
         'Finalize the transaction'
 
-        self.log("commit %s" % (subtransaction and "sub" or "top"))
-
         objects = self._objects
 
         subjars = []
@@ -252,7 +247,14 @@
                 # in case the cleanup process causes another
                 # exception.
                 t, v, tb = sys.exc_info()
-                self._commit_error(objects, ncommitted, jars, subjars)
+                try:
+                    self._commit_error(objects, ncommitted, jars, subjars)
+                except:
+                    LOG('ZODB', ERROR,
+                        "A storage error occured during transaction "
+                        "abort.  This shouldn't happen.",
+                        error=sys.exc_info())
+                    
                 raise t, v, tb
         finally:
             del objects[:] # clear registered
@@ -326,10 +328,8 @@
             # whether jar in subjars than to make a dict and do has_key.
             for jar in jars:
                 if jar in subjars:
-                    self.log("commit_sub %s" % jar, BLATHER)
                     jar.commit_sub(self)
                 else:
-                    self.log("tpc_begin %s" % jar, BLATHER)
                     jar.tpc_begin(self)
 
     def _commit_objects(self, objects):
@@ -371,8 +371,6 @@
             raise
 
     def _commit_error(self, objects, ncommitted, jars, subjars):
-        self.log("_commit_errors:\n\tn=%d objects=%r\t\njars=%r\n"
-                 "\tsubjars=%r\n" % (ncommitted, objects, jars, subjars))
         # First, we have to abort any uncommitted objects.  The abort
         # will mark the object for invalidation, so that it's last
         # committed state will be restored.
@@ -392,6 +390,7 @@
         for j in jars:
             try:
                 j.tpc_abort(self) # This should never fail
+                self.log("release %s" % j.sortKey(), BLATHER)
             except:
                 LOG('ZODB', ERROR,
                     "A storage error occured during object abort. This "