[gnome-continuous-yocto/gnomeostree-3.28-rocko: 6279/8267] oeqa/core/loader: Use full and small module name on filtering
- From: Emmanuele Bassi <ebassi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-continuous-yocto/gnomeostree-3.28-rocko: 6279/8267] oeqa/core/loader: Use full and small module name on filtering
- Date: Sun, 17 Dec 2017 04:37:19 +0000 (UTC)
commit 77a358e41ec1271e6a240aa002ae2daf9e7c3da5
Author: Aníbal Limón <anibal limon linux intel com>
Date: Mon Jun 12 16:41:18 2017 -0500
oeqa/core/loader: Use full and small module name on filtering
The small module name was added to support run a whole suite that
has more that 3 levels in the test case name, but this broke the
behaviour for use a full test case name.
[YOCTO #11632]
(From OE-Core rev: 9ab20ceb5801bee8dd8b218b3928720da5e1d403)
Signed-off-by: Aníbal Limón <anibal limon linux intel com>
Signed-off-by: Richard Purdie <richard purdie linuxfoundation org>
meta/lib/oeqa/core/loader.py | 28 +++++++++++++++++++---------
1 files changed, 19 insertions(+), 9 deletions(-)
---
diff --git a/meta/lib/oeqa/core/loader.py b/meta/lib/oeqa/core/loader.py
index d110881..229f094 100644
--- a/meta/lib/oeqa/core/loader.py
+++ b/meta/lib/oeqa/core/loader.py
@@ -167,21 +167,28 @@ class OETestLoader(unittest.TestLoader):
# XXX; If the module has more than one namespace only use
# the first to support run the whole module specifying the
# <module_name>.[test_class].[test_name]
- module_name = case.__module__.split('.')[0]
+ module_name_small = case.__module__.split('.')[0]
+ module_name = case.__module__
class_name = case.__class__.__name__
test_name = case._testMethodName
if self.modules:
- if not module_name in self.modules:
- return True
+ module = None
+ try:
+ module = self.modules[module_name_small]
+ except KeyError:
+ try:
+ module = self.modules[module_name]
+ except KeyError:
+ return True
- if self.modules[module_name]:
- if not class_name in self.modules[module_name]:
+ if module:
+ if not class_name in module:
return True
- if self.modules[module_name][class_name]:
- if test_name not in self.modules[module_name][class_name]:
+ if module[class_name]:
+ if test_name not in module[class_name]:
return True
# Decorator filters
@@ -291,7 +298,8 @@ class OETestLoader(unittest.TestLoader):
# XXX; If the module has more than one namespace only use
# the first to support run the whole module specifying the
# <module_name>.[test_class].[test_name]
- module_name = module.__name__.split('.')[0]
+ module_name_small = module.__name__.split('.')[0]
+ module_name = module.__name__
# Normal test modules are loaded if no modules were specified,
# if module is in the specified module list or if 'all' is in
@@ -300,11 +308,13 @@ class OETestLoader(unittest.TestLoader):
load_module = True if not module_name.startswith('_') \
and (not self.modules \
or module_name in self.modules \
+ or module_name_small in self.modules \
or 'all' in self.modules) \
else False
load_underscore = True if module_name.startswith('_') \
- and module_name in self.modules \
+ and (module_name in self.modules or \
+ module_name_small in self.modules) \
else False
return (load_module, load_underscore)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]