diff options
author | Aníbal Limón <anibal.limon@linux.intel.com> | 2017-05-26 15:37:34 -0500 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2017-05-30 10:15:22 +0100 |
commit | 87d3e5b70c52e5c7439afe4af5aa002522043e81 (patch) | |
tree | 17d60cf9ad4d321f108c91d256959c8ad14a5471 | |
parent | b4ae730ee1d6003ff005148f741270e2878de484 (diff) | |
download | openembedded-core-87d3e5b70c52e5c7439afe4af5aa002522043e81.tar.gz openembedded-core-87d3e5b70c52e5c7439afe4af5aa002522043e81.tar.bz2 openembedded-core-87d3e5b70c52e5c7439afe4af5aa002522043e81.zip |
oeqa/core/threaded: Add OEStreamLoggerThreaded class
The OEStreamLoggerThreaded overrides OEStreamLogger to redirect
the PyUnit output to a logger.
Instead of log every line when comes the OEStreamLoggerThreaded
will buffer the PyUnit output and write everything at end of every
suite execution to don't have mixed suite outputs.
[YOCTO #11450]
Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/lib/oeqa/core/threaded.py | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/meta/lib/oeqa/core/threaded.py b/meta/lib/oeqa/core/threaded.py index e6f214088c..73b7f2fa64 100644 --- a/meta/lib/oeqa/core/threaded.py +++ b/meta/lib/oeqa/core/threaded.py @@ -1,10 +1,13 @@ # Copyright (C) 2017 Intel Corporation # Released under the MIT license (see COPYING.MIT) +import threading import multiprocessing from unittest.suite import TestSuite + from oeqa.core.loader import OETestLoader +from oeqa.core.runner import OEStreamLogger class OETestLoaderThreaded(OETestLoader): def __init__(self, tc, module_paths, modules, tests, modules_required, @@ -89,3 +92,25 @@ class OETestLoaderThreaded(OETestLoader): return suites +class OEStreamLoggerThreaded(OEStreamLogger): + _lock = threading.Lock() + buffers = {} + + def write(self, msg): + tid = threading.get_ident() + + if not tid in self.buffers: + self.buffers[tid] = "" + + if msg: + self.buffers[tid] += msg + + def finish(self): + tid = threading.get_ident() + + self._lock.acquire() + self.logger.info('THREAD: %d' % tid) + self.logger.info('-' * 70) + for line in self.buffers[tid].split('\n'): + self.logger.info(line) + self._lock.release() |