From 8740803d0696a0e97b72210a56f4fbd3135826ed Mon Sep 17 00:00:00 2001 From: Mariano Lopez Date: Fri, 2 Dec 2016 16:05:44 -0600 Subject: oeqa/core/decorator/data.py: Add skipIfNotFeature decorator This adds a new decorator to check if image under tests has certain DISTRO_FEATURE or IMAGE_FEATURE. [YOCTO #10234] Signed-off-by: Mariano Lopez --- meta/lib/oeqa/core/decorator/data.py | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'meta') diff --git a/meta/lib/oeqa/core/decorator/data.py b/meta/lib/oeqa/core/decorator/data.py index 73cca88d7b..fdeba9fe1d 100644 --- a/meta/lib/oeqa/core/decorator/data.py +++ b/meta/lib/oeqa/core/decorator/data.py @@ -5,6 +5,16 @@ from oeqa.core.exception import OEQAMissingVariable from . import OETestDecorator, registerDecorator +def has_feature(td, feature): + """ + Checks for feature in DISTRO_FEATURES or IMAGE_FEATURES. + """ + + if (feature in td.get('DISTRO_FEATURES', '') or + feature in td.get('IMAGE_FEATURES', '')): + return True + return False + @registerDecorator class skipIfDataVar(OETestDecorator): """ @@ -34,3 +44,21 @@ class OETestDataDepends(OETestDecorator): except KeyError: raise OEQAMissingVariable("Test case need %s variable but"\ " isn't into td" % v) + +@registerDecorator +class skipIfNotFeature(OETestDecorator): + """ + Skip test based on DISTRO_FEATURES. + + value must be in distro features or it will skip the test + with msg as the reason. + """ + + attrs = ('value', 'msg') + + def setUpDecorator(self): + msg = ('Checking if %s is in DISTRO_FEATURES ' + 'or IMAGE_FEATURES' % (self.value)) + self.logger.debug(msg) + if not has_feature(self.case.td, self.value): + self.case.skipTest(self.msg) -- cgit v1.2.3