xref: /openbmc/u-boot/tools/buildman/buildman.py (revision dd84058d24ff54d6b32818ffe44aeb4bba2cfae6)
1#!/usr/bin/env python
2#
3# Copyright (c) 2012 The Chromium OS Authors.
4#
5# SPDX-License-Identifier:	GPL-2.0+
6#
7
8"""See README for more information"""
9
10import multiprocessing
11from optparse import OptionParser
12import os
13import re
14import sys
15import unittest
16
17# Bring in the patman libraries
18our_path = os.path.dirname(os.path.realpath(__file__))
19sys.path.append(os.path.join(our_path, '../patman'))
20
21# Our modules
22import board
23import builder
24import checkpatch
25import command
26import control
27import doctest
28import gitutil
29import patchstream
30import terminal
31import toolchain
32
33def RunTests():
34    import test
35    import doctest
36
37    result = unittest.TestResult()
38    for module in ['toolchain']:
39        suite = doctest.DocTestSuite(module)
40        suite.run(result)
41
42    # TODO: Surely we can just 'print' result?
43    print result
44    for test, err in result.errors:
45        print err
46    for test, err in result.failures:
47        print err
48
49    sys.argv = [sys.argv[0]]
50    suite = unittest.TestLoader().loadTestsFromTestCase(test.TestBuild)
51    result = unittest.TestResult()
52    suite.run(result)
53
54    # TODO: Surely we can just 'print' result?
55    print result
56    for test, err in result.errors:
57        print err
58    for test, err in result.failures:
59        print err
60
61
62parser = OptionParser()
63parser.add_option('-b', '--branch', type='string',
64       help='Branch name to build')
65parser.add_option('-B', '--bloat', dest='show_bloat',
66       action='store_true', default=False,
67       help='Show changes in function code size for each board')
68parser.add_option('-c', '--count', dest='count', type='int',
69       default=-1, help='Run build on the top n commits')
70parser.add_option('-C', '--force-reconfig', dest='force_reconfig',
71       action='store_true', default=False,
72       help='Reconfigure for every commit (disable incremental build)')
73parser.add_option('-e', '--show_errors', action='store_true',
74       default=False, help='Show errors and warnings')
75parser.add_option('-f', '--force-build', dest='force_build',
76       action='store_true', default=False,
77       help='Force build of boards even if already built')
78parser.add_option('-F', '--force-build-failures', dest='force_build_failures',
79       action='store_true', default=False,
80       help='Force build of previously-failed build')
81parser.add_option('-d', '--detail', dest='show_detail',
82       action='store_true', default=False,
83       help='Show detailed information for each board in summary')
84parser.add_option('-g', '--git', type='string',
85       help='Git repo containing branch to build', default='.')
86parser.add_option('-H', '--full-help', action='store_true', dest='full_help',
87       default=False, help='Display the README file')
88parser.add_option('-i', '--in-tree', dest='in_tree',
89       action='store_true', default=False,
90       help='Build in the source tree instead of a separate directory')
91parser.add_option('-j', '--jobs', dest='jobs', type='int',
92       default=None, help='Number of jobs to run at once (passed to make)')
93parser.add_option('-k', '--keep-outputs', action='store_true',
94       default=False, help='Keep all build output files (e.g. binaries)')
95parser.add_option('--list-tool-chains', action='store_true', default=False,
96       help='List available tool chains')
97parser.add_option('-n', '--dry-run', action='store_true', dest='dry_run',
98       default=False, help="Do a try run (describe actions, but no nothing)")
99parser.add_option('-Q', '--quick', action='store_true',
100       default=False, help='Do a rough build, with limited warning resolution')
101parser.add_option('-s', '--summary', action='store_true',
102       default=False, help='Show a build summary')
103parser.add_option('-S', '--show-sizes', action='store_true',
104       default=False, help='Show image size variation in summary')
105parser.add_option('--step', type='int',
106       default=1, help='Only build every n commits (0=just first and last)')
107parser.add_option('-t', '--test', action='store_true', dest='test',
108                  default=False, help='run tests')
109parser.add_option('-T', '--threads', type='int',
110       default=None, help='Number of builder threads to use')
111parser.add_option('-u', '--show_unknown', action='store_true',
112       default=False, help='Show boards with unknown build result')
113parser.add_option('-o', '--output-dir', type='string',
114       dest='output_dir', default='..',
115       help='Directory where all builds happen and buildman has its workspace (default is ../)')
116
117parser.usage = """buildman -b <branch> [options]
118
119Build U-Boot for all commits in a branch. Use -n to do a dry run"""
120
121(options, args) = parser.parse_args()
122
123# Run our meagre tests
124if options.test:
125    RunTests()
126elif options.full_help:
127    pager = os.getenv('PAGER')
128    if not pager:
129        pager = 'more'
130    fname = os.path.join(os.path.dirname(sys.argv[0]), 'README')
131    command.Run(pager, fname)
132
133# Build selected commits for selected boards
134else:
135    control.DoBuildman(options, args)
136