From: Aníbal Limón Date: Wed, 9 Nov 2016 17:24:57 +0000 (-0600) Subject: oeqa/core/decorator: Add support for OETestDataDepends and skipIfDataVar X-Git-Tag: uninative-1.5~715 X-Git-Url: https://code.ossystems.io/gitweb?a=commitdiff_plain;h=7dc519d20e835ee7693c31903e164c4bc0e5e598;p=openembedded-core.git oeqa/core/decorator: Add support for OETestDataDepends and skipIfDataVar The OETestDataDepends decorator skips a test case if a variable isn't into test data (d). The skipIfDataVar decorator skips a test case if a variable has certain value. Signed-off-by: Aníbal Limón Signed-off-by: Mariano Lopez --- diff --git a/meta/lib/oeqa/core/decorator/data.py b/meta/lib/oeqa/core/decorator/data.py new file mode 100644 index 0000000000..73cca88d7b --- /dev/null +++ b/meta/lib/oeqa/core/decorator/data.py @@ -0,0 +1,36 @@ +# Copyright (C) 2016 Intel Corporation +# Released under the MIT license (see COPYING.MIT) + +from oeqa.core.exception import OEQAMissingVariable + +from . import OETestDecorator, registerDecorator + +@registerDecorator +class skipIfDataVar(OETestDecorator): + """ + Skip test based on value of a data store's variable. + + It will get the info of var from the data store and will + check it against value; if are equal it will skip the test + with msg as the reason. + """ + + attrs = ('var', 'value', 'msg') + + def setUpDecorator(self): + msg = 'Checking if %r value is %r to skip test' % (self.var, self.value) + self.logger.debug(msg) + if self.case.td.get(self.var) == self.value: + self.case.skipTest(self.msg) + +@registerDecorator +class OETestDataDepends(OETestDecorator): + attrs = ('td_depends',) + + def setUpDecorator(self): + for v in self.td_depends: + try: + value = self.case.td[v] + except KeyError: + raise OEQAMissingVariable("Test case need %s variable but"\ + " isn't into td" % v)