From ee72091783bbd976dedbcecec946fcb2c9cf7a11 Mon Sep 17 00:00:00 2001 From: fijal Date: Thu, 1 Feb 2007 12:50:29 +0100 Subject: [PATCH] [svn r37721] Fix. !Tests needed! --HG-- branch : trunk --- py/test/rsession/executor.py | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/py/test/rsession/executor.py b/py/test/rsession/executor.py index b13606bfb..bdb493751 100644 --- a/py/test/rsession/executor.py +++ b/py/test/rsession/executor.py @@ -60,21 +60,19 @@ class ApigenExecutor(RunExecutor): self.tracer = tracer return super(ApigenExecutor, self).execute() - def wrap_underlaying(self, target): - def f(*args): - try: - self.tracer.start_tracing() - return target(*args) - finally: - self.tracer.end_tracing() - return f + def wrap_underlaying(self, target, *args): + try: + self.tracer.start_tracing() + return target(*args) + finally: + self.tracer.end_tracing() def run(self): """ We want to trace *only* function objects here. Unsure what to do with custom collectors at all """ - if hasattr(self.item, 'obj') and type(self.item.obj) is py.test.Function: - self.item.obj = self.wrap_underlaying(self.item.obj) + if hasattr(self.item, 'obj') and type(self.item) is py.test.Function: + self.item.execute = self.wrap_underlaying self.item.run() class BoxExecutor(RunExecutor):