xref: /openbmc/openbmc/poky/meta/lib/oeqa/utils/__init__.py (revision c124f4f2e04dca16a428a76c89677328bc7bf908)
1#
2# Copyright OpenEmbedded Contributors
3#
4# SPDX-License-Identifier: MIT
5#
6# Enable other layers to have modules in the same named directory
7from pkgutil import extend_path
8__path__ = extend_path(__path__, __name__)
9
10# Borrowed from CalledProcessError
11
12class CommandError(Exception):
13    def __init__(self, retcode, cmd, output = None):
14        self.retcode = retcode
15        self.cmd = cmd
16        self.output = output
17    def __str__(self):
18        return "Command '%s' returned non-zero exit status %d with output: %s" % (self.cmd, self.retcode, self.output)
19
20def avoid_paths_in_environ(paths):
21    """
22        Searches for every path in os.environ['PATH']
23        if found remove it.
24
25        Returns new PATH without avoided PATHs.
26    """
27    import os
28
29    new_path = ''
30    for p in os.environ['PATH'].split(':'):
31       avoid = False
32       for pa in paths:
33           if pa in p:
34              avoid = True
35              break
36       if avoid:
37           continue
38
39       new_path = new_path + p + ':'
40
41    new_path = new_path[:-1]
42    return new_path
43
44def make_logger_bitbake_compatible(logger):
45    import logging
46
47    """
48    We need to raise the log level of the info output so unittest
49    messages are visible on the console.
50    """
51    def _bitbake_log_info(msg, *args, **kwargs):
52        logger.log(logging.INFO + 1, msg, *args, **kwargs)
53
54    logger.info = _bitbake_log_info
55
56    return logger
57
58def load_test_components(logger, executor):
59    import sys
60    import os
61    import importlib
62
63    from oeqa.core.context import OETestContextExecutor
64
65    components = {}
66
67    for path in sys.path:
68        base_dir = os.path.join(path, 'oeqa')
69        if os.path.exists(base_dir) and os.path.isdir(base_dir):
70            for file in os.listdir(base_dir):
71                comp_name = file
72                comp_context = os.path.join(base_dir, file, 'context.py')
73                if os.path.exists(comp_context):
74                    comp_plugin = importlib.import_module('oeqa.%s.%s' % \
75                            (comp_name, 'context'))
76                    try:
77                        if not issubclass(comp_plugin._executor_class,
78                                OETestContextExecutor):
79                            raise TypeError("Component %s in %s, _executor_class "\
80                                "isn't derived from OETestContextExecutor."\
81                                % (comp_name, comp_context))
82
83                        if comp_plugin._executor_class._script_executor \
84                                != executor:
85                            continue
86
87                        components[comp_name] = comp_plugin._executor_class()
88                    except AttributeError:
89                        raise AttributeError("Component %s in %s don't have "\
90                                "_executor_class defined." % (comp_name, comp_context))
91
92    return components
93
94def get_json_result_dir(d):
95    json_result_dir = os.path.join(d.getVar("LOG_DIR"), 'oeqa')
96    custom_json_result_dir = d.getVar("OEQA_JSON_RESULT_DIR")
97    if custom_json_result_dir:
98        json_result_dir = custom_json_result_dir
99    return json_result_dir
100
101def get_artefact_dir(d):
102    custom_json_result_dir = d.getVar("OEQA_ARTEFACT_DIR")
103    if custom_json_result_dir:
104        return custom_json_result_dir
105    return os.path.join(d.getVar("LOG_DIR"), 'oeqa-artefacts')
106