[Zope-Checkins] CVS: ZODB3/ZEO - ClientStorage.py:1.73.2.10

Barry Warsaw barry@wooz.org
Mon, 20 Jan 2003 16:02:19 -0500


Update of /cvs-repository/ZODB3/ZEO
In directory cvs.zope.org:/tmp/cvs-serv22477

Modified Files:
      Tag: ZODB3-3_1-branch
	ClientStorage.py 
Log Message:
tpc_abort(): Backported from the 3.2 trunk, this ignores any
ClientDisconnected exception that could be raised during the call to
the server's tpc_abort when we're not connected.


=== ZODB3/ZEO/ClientStorage.py 1.73.2.9 => 1.73.2.10 ===
--- ZODB3/ZEO/ClientStorage.py:1.73.2.9	Thu Dec 26 15:22:53 2002
+++ ZODB3/ZEO/ClientStorage.py	Mon Jan 20 16:02:17 2003
@@ -656,11 +656,18 @@
         if transaction is not self._transaction:
             return
         try:
-            self._server.tpc_abort(self._serial)
+            # XXX Are there any transactions that should prevent an
+            # abort from occurring?  It seems wrong to swallow them
+            # all, yet you want to be sure that other abort logic is
+            # executed regardless.
+            try:
+                self._server.tpc_abort(self._serial)
+            except ClientDisconnected:
+                log2(BLATHER, 'ClientDisconnected in tpc_abort() ignored')
+        finally:
             self._tbuf.clear()
             self._seriald.clear()
             del self._serials[:]
-        finally:
             self.end_transaction()
 
     def tpc_finish(self, transaction, f=None):