
By default python logging module uses stderr as default stream for output but is unix-like to use stdout instead, so change it. (From OE-Core rev: 986452c410a958e339f31f8c05461c18a1a15eb5) Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2.6 KiB
Executable File
#!/usr/bin/env python3
Copyright (c) 2013-2017 Intel Corporation
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
DESCRIPTION
This script runs tests defined in meta/lib/oeqa/selftest/
It's purpose is to automate the testing of different bitbake tools.
To use it you just need to source your build environment setup script and
add the meta-selftest layer to your BBLAYERS.
Call the script as: "oe-selftest -a" to run all the tests in meta/lib/oeqa/selftest/
Call the script as: "oe-selftest -r .." to run just a single test
E.g: "oe-selftest -r bblayers.BitbakeLayers" will run just the BitbakeLayers class from meta/lib/oeqa/selftest/bblayers.py
import os import sys import argparse import logging
scripts_path = os.path.dirname(os.path.realpath(file)) lib_path = scripts_path + '/lib' sys.path = sys.path + [lib_path] import argparse_oe import scriptutils import scriptpath scriptpath.add_oe_lib_path() scriptpath.add_bitbake_lib_path()
from oeqa.utils import load_test_components from oeqa.core.exception import OEQAPreRun
logger = scriptutils.logger_create('oe-selftest', stream=sys.stdout)
def main(): description = "Script that runs unit tests against bitbake and other Yocto related tools. The goal is to validate tools functionality and metadata integrity. Refer to https://wiki.yoctoproject.org/wiki/Oe-selftest for more information." parser = argparse_oe.ArgumentParser(description=description)
comp_name, comp = load_test_components(logger, 'oe-selftest').popitem()
comp.register_commands(logger, parser)
try:
args = parser.parse_args()
results = args.func(logger, args)
ret = 0 if results.wasSuccessful() else 1
except SystemExit as err:
if err.code != 0:
raise err
ret = err.code
except OEQAPreRun as pr:
ret = 1
return ret
if name == 'main': try: ret = main() except Exception: ret = 1 import traceback traceback.print_exc() sys.exit(ret)