main.py 4.5 KB
Newer Older
S
Simon Glass 已提交
1
#!/usr/bin/env python3
2
# SPDX-License-Identifier: GPL-2.0+
3 4 5 6 7 8 9 10 11

# Copyright (c) 2016 Google, Inc
# Written by Simon Glass <sjg@chromium.org>
#
# Creates binary images from input files controlled by a description
#

"""See README for more information"""

12
from distutils.sysconfig import get_python_lib
13
import glob
14
import os
15
import site
16 17 18 19
import sys
import traceback
import unittest

20 21
# Bring in the patman and dtoc libraries (but don't override the first path
# in PYTHONPATH)
22
our_path = os.path.dirname(os.path.realpath(__file__))
S
Simon Glass 已提交
23 24 25
sys.path.insert(2, os.path.join(our_path, '..'))

from patman import test_util
26

27
# Bring in the libfdt module
28 29
sys.path.insert(2, 'scripts/dtc/pylibfdt')
sys.path.insert(2, os.path.join(our_path,
30
                '../../build-sandbox_spl/scripts/dtc/pylibfdt'))
31

32 33 34 35 36 37
# When running under python-coverage on Ubuntu 16.04, the dist-packages
# directories are dropped from the python path. Add them in so that we can find
# the elffile module. We could use site.getsitepackages() here but unfortunately
# that is not available in a virtualenv.
sys.path.append(get_python_lib())

S
Simon Glass 已提交
38 39
from binman import cmdline
from binman import control
S
Simon Glass 已提交
40
from patman import test_util
41

S
Simon Glass 已提交
42
def RunTests(debug, verbosity, processes, test_preserve_dirs, args, toolpath):
43 44 45 46
    """Run the functional tests and any embedded doctests

    Args:
        debug: True to enable debugging, which shows a full stack trace on error
47
        verbosity: Verbosity level to use
48 49 50 51 52 53
        test_preserve_dirs: True to preserve the input directory used by tests
            so that it can be examined afterwards (only useful for debugging
            tests). If a single test is selected (in args[0]) it also preserves
            the output directory for this test. Both directories are displayed
            on the command line.
        processes: Number of processes to use to run tests (None=same as #CPUs)
54
        args: List of positional args provided to binman. This can hold a test
55
            name to execute (as in 'binman test testSections', for example)
S
Simon Glass 已提交
56
        toolpath: List of paths to use for tools
57
    """
S
Simon Glass 已提交
58 59 60 61 62 63 64
    from binman import cbfs_util_test
    from binman import elf_test
    from binman import entry_test
    from binman import fdt_test
    from binman import ftest
    from binman import image_test
    from binman import test
65 66 67
    import doctest

    result = unittest.TestResult()
68
    test_name = args and args[0] or None
69 70 71

    # Run the entry tests first ,since these need to be the first to import the
    # 'entry' module.
72 73 74 75 76
    test_util.RunTestSuites(
        result, debug, verbosity, test_preserve_dirs, processes, test_name,
        toolpath,
        [entry_test.TestEntry, ftest.TestFunctional, fdt_test.TestFdt,
         elf_test.TestElf, image_test.TestImage, cbfs_util_test.TestCbfs])
77

78
    return test_util.ReportResult('binman', test_name, result)
79

80 81 82 83 84 85 86 87 88 89 90
def GetEntryModules(include_testing=True):
    """Get a set of entry class implementations

    Returns:
        Set of paths to entry class filenames
    """
    glob_list = glob.glob(os.path.join(our_path, 'etype/*.py'))
    return set([os.path.splitext(os.path.basename(item))[0]
                for item in glob_list
                if include_testing or '_testing' not in item])

91 92
def RunTestCoverage():
    """Run the tests and check that we get 100% coverage"""
93
    glob_list = GetEntryModules(False)
T
Tom Rini 已提交
94 95
    all_set = set([os.path.splitext(os.path.basename(item))[0]
                   for item in glob_list if '_testing' not in item])
S
Simon Glass 已提交
96 97
    test_util.RunTestCoverage('tools/binman/binman', None,
            ['*test*', '*main.py', 'tools/patman/*', 'tools/dtoc/*'],
98
            args.build_dir, all_set)
99

100
def RunBinman(args):
101 102 103
    """Main entry point to binman once arguments are parsed

    Args:
104
        args: Command line arguments Namespace object
105 106 107
    """
    ret_code = 0

108
    if not args.debug:
109 110
        sys.tracebacklimit = 0

111 112 113 114 115 116 117
    if args.cmd == 'test':
        if args.test_coverage:
            RunTestCoverage()
        else:
            ret_code = RunTests(args.debug, args.verbosity, args.processes,
                                args.test_preserve_dirs, args.tests,
                                args.toolpath)
118

119
    elif args.cmd == 'entry-docs':
120
        control.WriteEntryDocs(GetEntryModules())
121 122 123

    else:
        try:
124
            ret_code = control.Binman(args)
125
        except Exception as e:
126
            print('binman: %s' % e)
127
            if args.debug:
128
                print()
129 130 131 132 133 134
                traceback.print_exc()
            ret_code = 1
    return ret_code


if __name__ == "__main__":
135 136 137
    args = cmdline.ParseArgs(sys.argv[1:])

    ret_code = RunBinman(args)
138
    sys.exit(ret_code)