[Zope-Checkins] CVS: ZODB3/ZEO - ClientStorage.py:1.89
Jeremy Hylton
jeremy@zope.com
Tue, 4 Mar 2003 14:56:55 -0500
Update of /cvs-repository/ZODB3/ZEO
In directory cvs.zope.org:/tmp/cvs-serv24400/ZEO
Modified Files:
ClientStorage.py
Log Message:
Fix isReadOnly() to return True for a read-only fallback connection.
=== ZODB3/ZEO/ClientStorage.py 1.88 => 1.89 ===
--- ZODB3/ZEO/ClientStorage.py:1.88 Wed Jan 29 14:40:16 2003
+++ ZODB3/ZEO/ClientStorage.py Tue Mar 4 14:56:48 2003
@@ -210,8 +210,11 @@
self._connection = None
self._pending_server = None
self._ready = threading.Event()
-
+
+ # _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 = False
self._storage = storage
self._read_only_fallback = read_only_fallback
# _server_addr is used by sortKey()
@@ -365,6 +368,7 @@
"""
log2(INFO, "Testing connection %r" % conn)
# XXX Check the protocol version here?
+ self._conn_is_read_only = False
stub = self.StorageServerStubClass(conn)
try:
stub.register(str(self._storage), self._is_read_only)
@@ -374,6 +378,7 @@
raise
log2(INFO, "Got ReadOnlyError; trying again with read_only=1")
stub.register(str(self._storage), read_only=1)
+ self._conn_is_read_only = True
return 0
def notifyConnected(self, conn):
@@ -548,12 +553,14 @@
return self._info['supportsTransactionalUndo']
def isReadOnly(self):
- """Storage API: return whether we are in read-only mode.
-
- XXX In read-only fallback mode, this returns false, even if we
- are currently connected to a read-only server.
- """
- return self._is_read_only
+ """Storage API: return whether we are in read-only mode."""
+ if self._is_read_only:
+ 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
def _check_trans(self, trans):
"""Internal helper to check a transaction argument for sanity."""