[Zodb-checkins] SVN: ZODB/trunk/src/ZEO/ClientStorage.py In ClientStorage, There was a flag to record whether a connection is
Jim Fulton
jim at zope.com
Fri Aug 29 08:29:57 EDT 2008
Log message for revision 90580:
In ClientStorage, There was a flag to record whether a connection is
read_only. It was set when a connection was tested, before the
connection was attached t the storage. This made me wonder if the
flag and connection could get out of sync. Because of details of the
complex connection dance, it appears that the flag will have a usable
value, almost by accident. Ironically, if the storage was opened
read-only, this flag was set to true. This all seemed very fragile,
and probably a bug magnet. I refactored this so the flag is on the
connection, rather than the storage. I also arranged that if the
storage is opened read-only, the flag is True.
Changed:
U ZODB/trunk/src/ZEO/ClientStorage.py
-=-
Modified: ZODB/trunk/src/ZEO/ClientStorage.py
===================================================================
--- ZODB/trunk/src/ZEO/ClientStorage.py 2008-08-29 12:29:54 UTC (rev 90579)
+++ ZODB/trunk/src/ZEO/ClientStorage.py 2008-08-29 12:29:56 UTC (rev 90580)
@@ -254,8 +254,6 @@
# _is_read_only stores the constructor argument
self._is_read_only = read_only
- # _conn_is_read_only stores the status of the current connection
- self._conn_is_read_only = 0
self._storage = storage
self._read_only_fallback = read_only_fallback
self._username = username
@@ -457,7 +455,7 @@
"""
log2("Testing connection %r" % conn)
# TODO: Should we check the protocol version here?
- self._conn_is_read_only = 0
+ conn._is_read_only = self._is_read_only
stub = self.StorageServerStubClass(conn)
auth = stub.getAuthProtocol()
@@ -479,7 +477,7 @@
raise
log2("Got ReadOnlyError; trying again with read_only=1")
stub.register(str(self._storage), read_only=1)
- self._conn_is_read_only = 1
+ conn._is_read_only = True
return 0
def notifyConnected(self, conn):
@@ -680,12 +678,16 @@
def isReadOnly(self):
"""Storage API: return whether we are in read-only mode."""
if self._is_read_only:
- return 1
+ return True
else:
# If the client is configured for a read-write connection
- # but has a read-only fallback connection, _conn_is_read_only
- # will be True.
- return self._conn_is_read_only
+ # but has a read-only fallback connection, conn._is_read_only
+ # will be True. If self._connection is None, we'll behave as
+ # read_only
+ try:
+ return self._connection._is_read_only
+ except AttributeError:
+ return True
def _check_trans(self, trans):
"""Internal helper to check a transaction argument for sanity."""
More information about the Zodb-checkins
mailing list