[Zodb-checkins] CVS: Zope3/lib/python/ZEO/zrpc - client.py:1.8 connection.py:1.9 log.py:1.4 marshal.py:1.4 server.py:1.7 smac.py:1.3

Tim Peters tim.one@comcast.net
Thu, 19 Dec 2002 15:33:01 -0500


Update of /cvs-repository/Zope3/lib/python/ZEO/zrpc
In directory cvs.zope.org:/tmp/cvs-serv26955/lib/python/ZEO/zrpc

Modified Files:
	client.py connection.py log.py marshal.py server.py smac.py 
Log Message:
Enough interconnected logging edits so that the ZEO tests pass again.


=== Zope3/lib/python/ZEO/zrpc/client.py 1.7 => 1.8 ===
--- Zope3/lib/python/ZEO/zrpc/client.py:1.7	Thu Dec  5 13:25:37 2002
+++ Zope3/lib/python/ZEO/zrpc/client.py	Thu Dec 19 15:33:00 2002
@@ -20,11 +20,10 @@
 import types
 
 import ThreadedAsync
-import zLOG
 
 from ZODB.POSException import ReadOnlyError
 
-from ZEO.zrpc.log import log
+from ZEO.zrpc import log
 from ZEO.zrpc.trigger import trigger
 from ZEO.zrpc.connection import ManagedConnection
 
@@ -93,12 +92,11 @@
         finally:
             self.cond.release()
         if t is not None:
-            log("CM.close(): stopping and joining thread")
+            log.info("CM.close(): stopping and joining thread")
             t.stop()
             t.join(30)
             if t.isAlive():
-                log("CM.close(): self.thread.join() timed out",
-                    level=zLOG.WARNING)
+                log.error("CM.close(): self.thread.join() timed out")
         if conn is not None:
             # This will call close_conn() below which clears self.connection
             conn.close()
@@ -119,9 +117,9 @@
 
         # XXX need each connection started with async==0 to have a
         # callback
-        log("CM.set_async(%s)" % repr(map))
+        log.info("CM.set_async(%s)" % repr(map))
         if not self.closed and self.trigger is None:
-            log("CM.set_async(): first call")
+            log.info("CM.set_async(): first call")
             self.trigger = trigger()
             self.thr_async = 1 # XXX needs to be set on the Connection
 
@@ -168,7 +166,7 @@
                 return
             t = self.thread
             if t is None:
-                log("CM.connect(): starting ConnectThread")
+                log.info("CM.connect(): starting ConnectThread")
                 self.thread = t = ConnectThread(self, self.client,
                                                 self.addrlist,
                                                 self.tmin, self.tmax)
@@ -178,7 +176,7 @@
                 while self.connection is None:
                     self.cond.wait(30)
                     if self.connection is None:
-                        log("CM.connect(sync=1): still waiting...")
+                        log.info("CM.connect(sync=1): still waiting...")
         finally:
             self.cond.release()
         if sync:
@@ -186,7 +184,7 @@
 
     def connect_done(self, conn, preferred):
         # Called by ConnectWrapper.notify_client() after notifying the client
-        log("CM.connect_done(preferred=%s)" % preferred)
+        log.info("CM.connect_done(preferred=%s)", preferred)
         self.cond.acquire()
         try:
             self.connection = conn
@@ -202,9 +200,9 @@
         try:
             if conn is not self.connection:
                 # Closing a non-current connection
-                log("CM.close_conn() non-current", level=zLOG.BLATHER)
+                log.info("CM.close_conn() non-current")
                 return
-            log("CM.close_conn()")
+            log.info("CM.close_conn()")
             self.connection = None
         finally:
             self.cond.release()
@@ -295,7 +293,7 @@
                 break
             time.sleep(delay)
             delay = min(delay*2, self.tmax)
-        log("CT: exiting thread: %s" % self.getName())
+        log.info("CT: exiting thread: %s", self.getName())
 
     def try_connecting(self, timeout):
         """Try connecting to all self.addrlist addresses.
@@ -306,7 +304,7 @@
 
         If no connection is found within timeout seconds, return 0.
         """
-        log("CT: attempting to connect on %d sockets" % len(self.addrlist))
+        log.info("CT: attempting to connect on %d sockets", len(self.addrlist))
         deadline = time.time() + timeout
         wrappers = self._create_wrappers()
         for wrap in wrappers.keys():
@@ -365,14 +363,14 @@
                 break
             try:
                 r, w, x = select.select([], connecting, connecting, 1.0)
-                log("CT: select() %d, %d, %d" % tuple(map(len, (r,w,x))))
+                log.info("CT: select() %d, %d, %d" % tuple(map(len, (r,w,x))))
             except select.error, msg:
-                log("CT: select failed; msg=%s" % str(msg),
-                    level=zLOG.WARNING) # XXX Is this the right level?
+                # XXX Is error the right level?
+                log.error("CT: select failed; msg=%s", msg)
                 continue
             # Exceptable wrappers are in trouble; close these suckers
             for wrap in x:
-                log("CT: closing troubled socket %s" % str(wrap.addr))
+                log.info("CT: closing troubled socket %s", str(wrap.addr))
                 del wrappers[wrap]
                 wrap.close()
             # Writable sockets are connected
@@ -402,7 +400,7 @@
                     return -1
             assert wrap.state == "closed"
             del wrappers[wrap]
-        
+
 
 class ConnectWrapper:
     """An object that handles the connection procedure for one socket.
@@ -427,12 +425,11 @@
         self.sock = None
         self.conn = None
         self.preferred = 0
-        log("CW: attempt to connect to %s" % repr(addr))
+        log.info("CW: attempt to connect to %s", repr(addr))
         try:
             self.sock = socket.socket(domain, socket.SOCK_STREAM)
         except socket.error, err:
-            log("CW: can't create socket, domain=%s: %s" % (domain, err),
-                level=zLOG.ERROR)
+            log.error("CW: can't create socket, domain=%s: %s", domain, err)
             self.close()
             return
         self.sock.setblocking(0)
@@ -444,19 +441,17 @@
             try:
                 err = self.sock.connect_ex(self.addr)
             except socket.error, msg:
-                log("CW: connect_ex(%r) failed: %s" % (self.addr, msg),
-                    level=zLOG.ERROR)
+                log.error("CW: connect_ex(%r) failed: %s", self.addr, msg)
                 self.close()
                 return
-            log("CW: connect_ex(%s) returned %s" %
-                (self.addr, errno.errorcode.get(err) or str(err)))
+            log.info("CW: connect_ex(%s) returned %s", self.addr,
+                     errno.errorcode.get(err) or str(err))
             if err in _CONNECT_IN_PROGRESS:
                 self.state = "connecting"
                 return
             if err not in _CONNECT_OK:
-                log("CW: error connecting to %s: %s" %
-                    (self.addr, errno.errorcode.get(err) or str(err)),
-                    level=zLOG.WARNING)
+                log.error("CW: error connecting to %s: %s", self.addr,
+                          errno.errorcode.get(err) or str(err))
                 self.close()
                 return
             self.state = "connected"
@@ -476,12 +471,13 @@
             self.preferred = self.client.testConnection(self.conn)
             self.state = "tested"
         except ReadOnlyError:
-            log("CW: ReadOnlyError in testConnection (%s)" % repr(self.addr))
+            log.info("CW: ReadOnlyError in testConnection (%s)",
+                      repr(self.addr))
             self.close()
             return
         except:
-            log("CW: error in testConnection (%s)" % repr(self.addr),
-                level=zLOG.ERROR, error=sys.exc_info())
+            log.error("CW: error in testConnection (%s)", repr(self.addr),
+                      exc_info=True)
             self.close()
             return
         if self.preferred:
@@ -499,8 +495,8 @@
         try:
             self.client.notifyConnected(self.conn)
         except:
-            log("CW: error in notifyConnected (%s)" % repr(self.addr),
-                level=zLOG.ERROR, error=sys.exc_info())
+            log.error("CW: error in notifyConnected (%s)", repr(self.addr),
+                      exc_info=True)
             self.close()
             return
         self.state = "notified"


=== Zope3/lib/python/ZEO/zrpc/connection.py 1.8 => 1.9 ===
--- Zope3/lib/python/ZEO/zrpc/connection.py:1.8	Thu Dec 19 12:43:19 2002
+++ Zope3/lib/python/ZEO/zrpc/connection.py	Thu Dec 19 15:33:00 2002
@@ -17,14 +17,14 @@
 import sys
 import threading
 import types
+import logging
 
 import ThreadedAsync
 from ZEO.zrpc import smac
 from ZEO.zrpc.error import ZRPCError, DisconnectedError
-from ZEO.zrpc.log import log, short_repr
+from ZEO.zrpc import log
 from ZEO.zrpc.marshal import Marshaller
 from ZEO.zrpc.trigger import trigger
-import zLOG
 from ZODB import POSException
 
 REPLY = ".reply" # message name used for replies
@@ -47,7 +47,7 @@
         self.send_reply(self.msgid, obj)
 
     def error(self, exc_info):
-        log("Error raised in delayed method", zLOG.ERROR, error=exc_info)
+        log.error("Error raised in delayed method", exc_info=True)
         self.return_error(self.msgid, 0, *exc_info[:2])
 
 class MTDelay(Delay):
@@ -151,9 +151,6 @@
 
     __str__ = __repr__ # Defeat asyncore's dreaded __getattr__
 
-    def log(self, message, level=zLOG.BLATHER, error=None):
-        zLOG.LOG(self.log_label, level, message, error=error)
-
     def close(self):
         if self.closed:
             return
@@ -189,8 +186,9 @@
         if message == self.protocol_version:
             self.message_input = self._message_input
         else:
-            self.log("recv_handshake: bad handshake %s" % short_repr(message),
-                     level=zLOG.ERROR)
+            log.error("%s: recv_handshake: bad handshake %s",
+                      self.log_label,
+                      log.short_repr(message))
         # otherwise do something else...
 
     def message_input(self, message):
@@ -202,9 +200,9 @@
         msgid, flags, name, args = self.marshal.decode(message)
 
         if __debug__:
-            self.log("recv msg: %s, %s, %s, %s" % (msgid, flags, name,
-                                                   short_repr(args)),
-                     level=zLOG.TRACE)
+            log.debug("%s: recv msg: %s, %s, %s, %s",
+                      self.log_label, msgid, flags, name,
+                      log.short_repr(args))
         if name == REPLY:
             self.handle_reply(msgid, flags, args)
         else:
@@ -212,8 +210,8 @@
 
     def handle_reply(self, msgid, flags, args):
         if __debug__:
-            self.log("recv reply: %s, %s, %s"
-                     % (msgid, flags, short_repr(args)), level=zLOG.DEBUG)
+            log.debug("%s: recv reply: %s, %s, %s",
+                      self.log_label, msgid, flags, log.short_repr(args))
         self.replies_cond.acquire()
         try:
             self.replies[msgid] = flags, args
@@ -226,8 +224,8 @@
             msg = "Invalid method name: %s on %s" % (name, repr(self.obj))
             raise ZRPCError(msg)
         if __debug__:
-            self.log("calling %s%s" % (name, short_repr(args)),
-                     level=zLOG.BLATHER)
+            log.info("%s: calling %s%s", self.log_label, name,
+                     log.short_repr(args))
 
         meth = getattr(self.obj, name)
         try:
@@ -236,18 +234,19 @@
             raise
         except Exception, msg:
             error = sys.exc_info()
-            self.log("%s() raised exception: %s" % (name, msg), zLOG.INFO,
-                     error=error)
+            log.info("%s: %s() raised exception: %s", self.log_label,
+                     name, msg, exc_info=True)
             error = error[:2]
             return self.return_error(msgid, flags, *error)
 
         if flags & ASYNC:
             if ret is not None:
                 raise ZRPCError("async method %s returned value %s" %
-                                (name, short_repr(ret)))
+                                (name, log.short_repr(ret)))
         else:
             if __debug__:
-                self.log("%s returns %s" % (name, short_repr(ret)), zLOG.DEBUG)
+                log.debug("%s: %s returns %s", self.log_label, name,
+                          log.short_repr(ret))
             if isinstance(ret, Delay):
                 ret.set_sender(msgid, self.send_reply, self.return_error)
             else:
@@ -260,7 +259,7 @@
         self.close()
 
     def log_error(self, msg="No error message supplied"):
-        self.log(msg, zLOG.ERROR, error=sys.exc_info())
+        log.error("%s: %s", self.log_label, msg, exc_info=True)
 
     def check_method(self, name):
         # XXX Is this sufficient "security" for now?
@@ -273,7 +272,7 @@
             msg = self.marshal.encode(msgid, 0, REPLY, ret)
         except self.marshal.errors:
             try:
-                r = short_repr(ret)
+                r = log.short_repr(ret)
             except:
                 r = "<unreprable>"
             err = ZRPCError("Couldn't pickle return %.100s" % r)
@@ -292,7 +291,7 @@
             msg = self.marshal.encode(msgid, 0, REPLY, (err_type, err_value))
         except self.marshal.errors:
             try:
-                r = short_repr(err_value)
+                r = log.short_repr(err_value)
             except:
                 r = "<unreprable>"
             err = ZRPCError("Couldn't pickle error %.100s" % r)
@@ -312,8 +311,8 @@
         finally:
             self.msgid_lock.release()
         if __debug__:
-            self.log("send msg: %d, %d, %s, ..." % (msgid, flags, method),
-                     zLOG.TRACE)
+            log.debug("%s: send msg: %d, %d, %s, ...", self.log_label,
+                      msgid, flags, method)
         buf = self.marshal.encode(msgid, flags, method, args)
         self.message_output(buf)
         return msgid
@@ -368,8 +367,8 @@
     def wait(self, msgid):
         """Invoke asyncore mainloop and wait for reply."""
         if __debug__:
-            self.log("wait(%d), async=%d" % (msgid, self.is_async()),
-                     level=zLOG.TRACE)
+            log.debug("%s: wait(%d), async=%d", self.log_label, msgid,
+                      self.is_async())
         if self.is_async():
             self._pull_trigger()
 
@@ -386,8 +385,8 @@
                 if reply is not None:
                     del self.replies[msgid]
                     if __debug__:
-                        self.log("wait(%d): reply=%s" %
-                                 (msgid, short_repr(reply)), level=zLOG.DEBUG)
+                        log.debug("%s: wait(%d): reply=%s", self.log_label,
+                                  msgid, log.short_repr(reply))
                     return reply
                 if self.is_async():
                     self.replies_cond.wait(10.0)
@@ -396,14 +395,15 @@
                     try:
                         try:
                             if __debug__:
-                                self.log("wait(%d): asyncore.poll(%s)" %
-                                         (msgid, delay), level=zLOG.TRACE)
+                                log.debug("%s: wait(%d): asyncore.poll(%s)",
+                                          self.log_label, msgid, delay)
                             asyncore.poll(delay, self._map)
                             if delay < 1.0:
                                 delay += delay
                         except select.error, err:
-                            self.log("Closing.  asyncore.poll() raised %s."
-                                     % err, level=zLOG.BLATHER)
+                            log.info("%s: Closing.  "
+                                     "asyncore.poll() raised %s.",
+                                     self.log_label, err)
                             self.close()
                     finally:
                         self.replies_cond.acquire()
@@ -413,7 +413,7 @@
     def poll(self):
         """Invoke asyncore mainloop to get pending message out."""
         if __debug__:
-            self.log("poll(), async=%d" % self.is_async(), level=zLOG.TRACE)
+            log.debug("poll(), async=%d", self.is_async())
         if self.is_async():
             self._pull_trigger()
         else:
@@ -422,7 +422,8 @@
     def pending(self):
         """Invoke mainloop until any pending messages are handled."""
         if __debug__:
-            self.log("pending(), async=%d" % self.is_async(), level=zLOG.TRACE)
+            log.debug("%s: pending(), async=%d", self.log_label,
+                      self.is_async())
         if self.is_async():
             return
         # Inline the asyncore poll() function to know whether any input


=== Zope3/lib/python/ZEO/zrpc/log.py 1.3 => 1.4 ===
--- Zope3/lib/python/ZEO/zrpc/log.py:1.3	Fri Nov 22 16:24:53 2002
+++ Zope3/lib/python/ZEO/zrpc/log.py	Thu Dec 19 15:33:00 2002
@@ -13,22 +13,44 @@
 ##############################################################################
 import os
 import types
-import zLOG
 import threading
+import logging
 
 LOG_THREAD_ID = 0 # Set this to 1 during heavy debugging
 
 _label = "zrpc:%s" % os.getpid()
 
-def new_label():
-    global _label
-    _label = "zrpc:%s" % os.getpid()
+# The code duplication here is for speed (save a layer of function call).
 
-def log(message, level=zLOG.BLATHER, label=None, error=None):
-    label = label or _label
+def critical(msg, *args, **kw):
+    label = _label
     if LOG_THREAD_ID:
         label = "%s:%s" % (label, threading.currentThread().getName())
-    zLOG.LOG(label, level, message, error=error)
+    logging.critical("%s: "+msg, label, *args, **kw)
+
+def error(msg, *args, **kw):
+    label = _label
+    if LOG_THREAD_ID:
+        label = "%s:%s" % (label, threading.currentThread().getName())
+    logging.error("%s: "+msg, label, *args, **kw)
+
+def warn(msg, *args, **kw):
+    label = _label
+    if LOG_THREAD_ID:
+        label = "%s:%s" % (label, threading.currentThread().getName())
+    logging.warn("%s: "+msg, label, *args, **kw)
+
+def info(msg, *args, **kw):
+    label = _label
+    if LOG_THREAD_ID:
+        label = "%s:%s" % (label, threading.currentThread().getName())
+    logging.info("%s: "+msg, label, *args, **kw)
+
+def debug(msg, *args, **kw):
+    label = _label
+    if LOG_THREAD_ID:
+        label = "%s:%s" % (label, threading.currentThread().getName())
+    logging.debug("%s: "+msg, label, *args, **kw)
 
 REPR_LIMIT = 40
 


=== Zope3/lib/python/ZEO/zrpc/marshal.py 1.3 => 1.4 ===
--- Zope3/lib/python/ZEO/zrpc/marshal.py:1.3	Fri Nov 22 16:24:53 2002
+++ Zope3/lib/python/ZEO/zrpc/marshal.py	Thu Dec 19 15:33:00 2002
@@ -15,10 +15,8 @@
 from cStringIO import StringIO
 import types
 
-import zLOG
-
 from ZEO.zrpc.error import ZRPCError
-from ZEO.zrpc.log import log, short_repr
+from ZEO.zrpc import log
 
 class Marshaller:
     """Marshal requests and replies to second across network"""
@@ -38,7 +36,7 @@
         try:
             return unpickler.load() # msgid, flags, name, args
         except:
-            log("can't decode message: %s" % short_repr(msg), level=zLOG.ERROR)
+            log.error("can't decode message: %s", log.short_repr(msg))
             raise
 
 _globals = globals()


=== Zope3/lib/python/ZEO/zrpc/server.py 1.6 => 1.7 ===
--- Zope3/lib/python/ZEO/zrpc/server.py:1.6	Mon Dec 16 16:18:02 2002
+++ Zope3/lib/python/ZEO/zrpc/server.py	Thu Dec 19 15:33:00 2002
@@ -16,8 +16,7 @@
 import types
 
 from ZEO.zrpc.connection import Connection, Delay
-from ZEO.zrpc.log import log
-import zLOG
+from ZEO.zrpc import log
 import ThreadedAsync
 
 # Export the main asyncore loop
@@ -44,7 +43,7 @@
         else:
             self.create_socket(socket.AF_UNIX, socket.SOCK_STREAM)
         self.set_reuse_addr()
-        log("listening on %s" % str(self.addr), zLOG.INFO)
+        log.info("listening on %s", str(self.addr))
         self.bind(self.addr)
         self.listen(5)
 
@@ -58,8 +57,8 @@
         try:
             sock, addr = self.accept()
         except socket.error, msg:
-            log("accepted failed: %s" % msg)
+            log.info("accepted failed: %s", msg)
             return
         c = self.factory(sock, addr)
-        log("connect from %s: %s" % (repr(addr), c))
+        log.info("connect from %s: %s", repr(addr), c)
         self.clients.append(c)


=== Zope3/lib/python/ZEO/zrpc/smac.py 1.2 => 1.3 ===
--- Zope3/lib/python/ZEO/zrpc/smac.py:1.2	Thu Dec 12 11:58:14 2002
+++ Zope3/lib/python/ZEO/zrpc/smac.py	Thu Dec 19 15:33:00 2002
@@ -15,13 +15,11 @@
 
 import asyncore, struct
 import threading
-from ZEO.Exceptions import Disconnected
-import zLOG
+import socket, errno
 from types import StringType
 
-from ZEO.zrpc.log import log, short_repr
-
-import socket, errno
+from ZEO.Exceptions import Disconnected
+from ZEO.zrpc import log
 
 # Use the dictionary to make sure we get the minimum number of errno
 # entries.   We expect that EWOULDBLOCK == EAGAIN on most systems --
@@ -204,9 +202,8 @@
     def message_output(self, message):
         if __debug__:
             if self._debug:
-                log('message_output %d bytes: %s' %
-                    (len(message), short_repr(message)),
-                    level=zLOG.TRACE)
+                log.debug('message_output %d bytes: %s',
+                          len(message), log.short_repr(message))
 
         if self.__closed:
             raise Disconnected("Action is temporarily unavailable")