[Zodb-checkins] SVN: ZODB/branches/3.8/src/ZEO/ClientStorage.py The order of operations seemed odd. If we get a new connection, we

Jim Fulton jim at zope.com
Tue Jul 8 17:50:53 EDT 2008


Log message for revision 88126:
  The order of operations seemed odd.  If we get a new connection, we
  should close the old connection, and mark ourselves dissconnected --
  or so it seems. :)  I'm chasing connection-invalidation bugs and this
  rearrangement makes the logic seem a bit simpler to me and sets the
  stage for a later fix for the invalidation problems.
  

Changed:
  U   ZODB/branches/3.8/src/ZEO/ClientStorage.py

-=-
Modified: ZODB/branches/3.8/src/ZEO/ClientStorage.py
===================================================================
--- ZODB/branches/3.8/src/ZEO/ClientStorage.py	2008-07-08 21:37:59 UTC (rev 88125)
+++ ZODB/branches/3.8/src/ZEO/ClientStorage.py	2008-07-08 21:50:53 UTC (rev 88126)
@@ -488,23 +488,25 @@
             # this method before it was stopped.
             return
 
-        # invalidate our db cache
-        if self._db is not None:
-            self._db.invalidateCache()
 
         if self._connection is not None:
+            # If we are upgrading from a read-only fallback connection,
+            # we must close the old connection to prevent it from being
+            # used while the cache is verified against the new connection.
+            self._connection.close()
+            self._connection = None
+            self._ready.clear()
             reconnect = 1
         else:
             reconnect = 0
+
         self.set_server_addr(conn.get_addr())
-
-        # If we are upgrading from a read-only fallback connection,
-        # we must close the old connection to prevent it from being
-        # used while the cache is verified against the new connection.
-        if self._connection is not None:
-            self._connection.close()
         self._connection = conn
 
+        # invalidate our db cache
+        if self._db is not None:
+            self._db.invalidateCache()
+
         if reconnect:
             log2("Reconnected to storage: %s" % self._server_addr)
         else:



More information about the Zodb-checkins mailing list