From 075bfc2365f429222f3c0bba9c778ae67b202000 Mon Sep 17 00:00:00 2001
From: Vincent Pelletier <vincent@nexedi.com>
Date: Tue, 28 Oct 2008 14:46:41 +0000
Subject: [PATCH] Add the possibility to log activity execution timing.

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@24365 20353a03-c40f-0410-a6d1-a30d3c3de9de
---
 product/CMFActivity/ActivityTool.py | 25 ++++++++++++++++++++++++-
 1 file changed, 24 insertions(+), 1 deletion(-)

diff --git a/product/CMFActivity/ActivityTool.py b/product/CMFActivity/ActivityTool.py
index 51d8b174b1..95e3b79079 100644
--- a/product/CMFActivity/ActivityTool.py
+++ b/product/CMFActivity/ActivityTool.py
@@ -56,6 +56,7 @@ from Products.MailHost.MailHost import MailHostError
 
 from zLOG import LOG, INFO, WARNING, ERROR
 from warnings import warn
+from time import time
 
 try:
   from Products.TimerService import getTimerService
@@ -93,6 +94,7 @@ import logging
 activity_logger = logging.getLogger('CMFActivity')
 # Some logging subchannels
 activity_tracking_logger = logging.getLogger('CMFActivity.Tracking')
+activity_timing_logger = logging.getLogger('CMFActivity.TimingLog')
 
 # Direct logging to "[instancehome]/log/CMFActivity.log", if this directory exists.
 # Otherwise, it will end up in root logging facility (ie, event.log).
@@ -132,6 +134,24 @@ def disableActivityCreationTrace():
   global activity_creation_trace
   activity_creation_trace = False
 
+activity_timing_log = False
+
+def enableActivityTimingLog():
+  global activity_timing_log
+  activity_timing_log = True
+
+def disableActivityTimingLog():
+  global activity_timing_log
+  activity_timing_log = False
+
+def activity_timing_method(method, args, kw):
+  begin = time()
+  try:
+    return method(*args, **kw)
+  finally:
+    end = time()
+    activity_timing_logger.info('%.02fs: %r(*%r, **%r)' % (end - begin, method, args, kw))
+
 # Here go ActivityBuffer instances
 # Structure:
 #  global_activity_buffer[activity_tool_path][thread_id] = ActivityBuffer
@@ -282,7 +302,10 @@ class Message:
             method = None
             self.setExecutionState(MESSAGE_NOT_EXECUTABLE, context=activity_tool)
           else:
-            result = method(*self.args, **self.kw)
+            if activity_timing_log:
+              result = activity_timing_method(method, self.args, self.kw)
+            else:
+              result = method(*self.args, **self.kw)
         finally:
           setSecurityManager(old_security_manager)
 
-- 
2.30.9