mirror of https://github.com/ARMmbed/mbed-os.git
Correct Python 3 errors and lint warnings in build_release.py
### Description I think this file is still used, and it's about time we updated it for compatibility with python3. While I was in there, I fixed all of the linter warnings, so that it's easier to spot bad code. ### Pull request type [x] Fix [ ] Refactor [ ] Target update [ ] Functionality change [ ] Docs update [ ] Test update [ ] Breaking changepull/10257/head
parent
1549c5c425
commit
0bfbd09de3
|
@ -1,4 +1,3 @@
|
|||
#! /usr/bin/env python
|
||||
"""
|
||||
mbed SDK
|
||||
Copyright (c) 2011-2013 ARM Limited
|
||||
|
@ -21,82 +20,102 @@ from os.path import join, abspath, dirname, normpath
|
|||
from optparse import OptionParser
|
||||
import json
|
||||
from shutil import copy
|
||||
from past.builtins import basestring
|
||||
from past.builtins import str
|
||||
|
||||
# Be sure that the tools directory is in the search path
|
||||
ROOT = abspath(join(dirname(__file__), ".."))
|
||||
sys.path.insert(0, ROOT)
|
||||
|
||||
from tools.build_api import build_mbed_libs
|
||||
from tools.build_api import write_build_report
|
||||
from tools.build_api import get_mbed_official_release
|
||||
from tools.options import extract_profile
|
||||
from tools.targets import TARGET_MAP, TARGET_NAMES
|
||||
from tools.test_exporters import ReportExporter, ResultExporterType
|
||||
from tools.test_api import SingleTestRunner
|
||||
from tools.test_api import singletest_in_cli_mode
|
||||
from tools.paths import TEST_DIR, MBED_LIBRARIES
|
||||
from tools.tests import TEST_MAP
|
||||
from tools.notifier.term import TerminalNotifier
|
||||
from tools.build_api import build_mbed_libs # noqa: E402
|
||||
from tools.build_api import get_mbed_official_release # noqa: E402
|
||||
from tools.options import extract_profile # noqa: E402
|
||||
from tools.targets import TARGET_MAP, TARGET_NAMES # noqa: E402
|
||||
from tools.test_exporters import ReportExporter, ResultExporterType # noqa: E402, E501
|
||||
from tools.test_api import SingleTestRunner # noqa: E402
|
||||
from tools.paths import TEST_DIR, MBED_LIBRARIES # noqa: E402
|
||||
from tools.tests import TEST_MAP # noqa: E402
|
||||
from tools.notifier.term import TerminalNotifier # noqa: E402
|
||||
|
||||
OFFICIAL_MBED_LIBRARY_BUILD = get_mbed_official_release('2')
|
||||
|
||||
if __name__ == '__main__':
|
||||
parser = OptionParser()
|
||||
parser.add_option('-o', '--official', dest="official_only", default=False, action="store_true",
|
||||
help="Build using only the official toolchain for each target")
|
||||
parser.add_option("-j", "--jobs", type="int", dest="jobs",
|
||||
default=1, help="Number of concurrent jobs (default 1). Use 0 for auto based on host machine's number of CPUs")
|
||||
parser.add_option("-v", "--verbose", action="store_true", dest="verbose",
|
||||
default=False, help="Verbose diagnostic output")
|
||||
parser.add_option("-t", "--toolchains", dest="toolchains", help="Use toolchains names separated by comma")
|
||||
|
||||
parser.add_option(
|
||||
'-o', '--official',
|
||||
dest="official_only",
|
||||
default=False,
|
||||
action="store_true",
|
||||
help="Build using only the official toolchain for each target"
|
||||
)
|
||||
parser.add_option(
|
||||
"-j", "--jobs",
|
||||
type="int",
|
||||
dest="jobs",
|
||||
default=1,
|
||||
help="Number of concurrent jobs (default 1)."
|
||||
" Use 0 for auto based on host machine's number of CPUs"
|
||||
)
|
||||
parser.add_option(
|
||||
"-v", "--verbose",
|
||||
action="store_true",
|
||||
dest="verbose",
|
||||
default=False,
|
||||
help="Verbose diagnostic output"
|
||||
)
|
||||
parser.add_option(
|
||||
"-t", "--toolchains",
|
||||
dest="toolchains",
|
||||
help="Use toolchains names separated by comma"
|
||||
)
|
||||
parser.add_option("--profile", dest="profile", action="append", default=[])
|
||||
|
||||
parser.add_option("-p", "--platforms", dest="platforms", default="", help="Build only for the platform namesseparated by comma")
|
||||
|
||||
parser.add_option("-L", "--list-config", action="store_true", dest="list_config",
|
||||
default=False, help="List the platforms and toolchains in the release in JSON")
|
||||
|
||||
parser.add_option("", "--report-build", dest="report_build_file_name", help="Output the build results to an junit xml file")
|
||||
|
||||
parser.add_option("", "--build-tests", dest="build_tests", help="Build all tests in the given directories (relative to /libraries/tests)")
|
||||
|
||||
|
||||
parser.add_option(
|
||||
"-p", "--platforms",
|
||||
dest="platforms",
|
||||
default="",
|
||||
help="Build only for the platform namesseparated by comma"
|
||||
)
|
||||
parser.add_option(
|
||||
"-L", "--list-config",
|
||||
action="store_true",
|
||||
dest="list_config",
|
||||
default=False,
|
||||
help="List the platforms and toolchains in the release in JSON"
|
||||
)
|
||||
parser.add_option(
|
||||
"", "--report-build",
|
||||
dest="report_build_file_name",
|
||||
help="Output the build results to an junit xml file"
|
||||
)
|
||||
parser.add_option(
|
||||
"", "--build-tests",
|
||||
dest="build_tests",
|
||||
help="Build all tests in the given directories"
|
||||
" (relative to /libraries/tests)"
|
||||
)
|
||||
options, args = parser.parse_args()
|
||||
|
||||
|
||||
|
||||
if options.list_config:
|
||||
print json.dumps(OFFICIAL_MBED_LIBRARY_BUILD, indent=4)
|
||||
print(json.dumps(OFFICIAL_MBED_LIBRARY_BUILD, indent=4))
|
||||
sys.exit()
|
||||
|
||||
start = time()
|
||||
build_report = {}
|
||||
build_properties = {}
|
||||
|
||||
platforms = None
|
||||
if options.platforms != "":
|
||||
platforms = set(options.platforms.split(","))
|
||||
|
||||
status = True
|
||||
|
||||
if options.build_tests:
|
||||
# Get all paths
|
||||
directories = options.build_tests.split(',')
|
||||
for i in range(len(directories)):
|
||||
directories[i] = normpath(join(TEST_DIR, directories[i]))
|
||||
|
||||
test_names = []
|
||||
|
||||
for test_id in TEST_MAP.keys():
|
||||
for test_id in list(TEST_MAP.keys()):
|
||||
# Prevents tests with multiple source dirs from being checked
|
||||
if isinstance( TEST_MAP[test_id].source_dir, basestring):
|
||||
if isinstance(TEST_MAP[test_id].source_dir, str):
|
||||
test_path = normpath(TEST_MAP[test_id].source_dir)
|
||||
for directory in directories:
|
||||
if directory in test_path:
|
||||
test_names.append(test_id)
|
||||
|
||||
mut_counter = 1
|
||||
mut = {}
|
||||
test_spec = {
|
||||
|
@ -104,26 +123,34 @@ if __name__ == '__main__':
|
|||
}
|
||||
|
||||
if options.toolchains:
|
||||
print "Only building using the following toolchains: %s" % (options.toolchains)
|
||||
print("Only building using the following toolchains: {}".format(
|
||||
options.toolchains
|
||||
))
|
||||
|
||||
for target_name, toolchain_list in OFFICIAL_MBED_LIBRARY_BUILD:
|
||||
toolchains = None
|
||||
if platforms is not None and not target_name in platforms:
|
||||
print("Excluding %s from release" % target_name)
|
||||
if platforms is not None and target_name not in platforms:
|
||||
print(("Excluding %s from release" % target_name))
|
||||
continue
|
||||
|
||||
if target_name not in TARGET_NAMES:
|
||||
print "Target '%s' is not a valid target. Excluding from release"
|
||||
print("Target '{}' is not a valid target. Excluding".format(
|
||||
target_name
|
||||
))
|
||||
continue
|
||||
|
||||
if options.official_only:
|
||||
toolchains = (getattr(TARGET_MAP[target_name], 'default_toolchain', 'ARM'),)
|
||||
toolchains = (getattr(
|
||||
TARGET_MAP[target_name], 'default_toolchain', 'ARM'
|
||||
),)
|
||||
else:
|
||||
toolchains = toolchain_list
|
||||
|
||||
if options.toolchains:
|
||||
toolchainSet = set(toolchains)
|
||||
toolchains = toolchainSet.intersection(set((options.toolchains).split(',')))
|
||||
toolchains = toolchainSet.intersection(
|
||||
set((options.toolchains).split(','))
|
||||
)
|
||||
|
||||
mut[str(mut_counter)] = {
|
||||
"mcu": target_name
|
||||
|
@ -133,40 +160,57 @@ if __name__ == '__main__':
|
|||
|
||||
test_spec["targets"][target_name] = toolchains
|
||||
|
||||
single_test = SingleTestRunner(_muts=mut,
|
||||
_parser=parser,
|
||||
_opts=options,
|
||||
_opts_report_build_file_name=options.report_build_file_name,
|
||||
_test_spec=test_spec,
|
||||
_opts_test_by_names=",".join(test_names),
|
||||
_opts_verbose=options.verbose,
|
||||
_opts_only_build_tests=True,
|
||||
_opts_suppress_summary=True,
|
||||
_opts_jobs=options.jobs,
|
||||
_opts_include_non_automated=True,
|
||||
_opts_build_report=build_report,
|
||||
_opts_build_properties=build_properties)
|
||||
single_test = SingleTestRunner(
|
||||
_muts=mut,
|
||||
_parser=parser,
|
||||
_opts=options,
|
||||
_opts_report_build_file_name=options.report_build_file_name,
|
||||
_test_spec=test_spec,
|
||||
_opts_test_by_names=",".join(test_names),
|
||||
_opts_verbose=options.verbose,
|
||||
_opts_only_build_tests=True,
|
||||
_opts_suppress_summary=True,
|
||||
_opts_jobs=options.jobs,
|
||||
_opts_include_non_automated=True,
|
||||
_opts_build_report=build_report,
|
||||
_opts_build_properties=build_properties
|
||||
)
|
||||
# Runs test suite in CLI mode
|
||||
test_summary, shuffle_seed, test_summary_ext, test_suite_properties_ext, new_build_report, new_build_properties = single_test.execute()
|
||||
(
|
||||
test_summary,
|
||||
shuffle_seed,
|
||||
test_summary_ext,
|
||||
test_suite_properties_ext,
|
||||
new_build_report,
|
||||
new_build_properties
|
||||
) = single_test.execute()
|
||||
else:
|
||||
for target_name, toolchain_list in OFFICIAL_MBED_LIBRARY_BUILD:
|
||||
if platforms is not None and not target_name in platforms:
|
||||
print("Excluding %s from release" % target_name)
|
||||
if platforms is not None and target_name not in platforms:
|
||||
print(("Excluding %s from release" % target_name))
|
||||
continue
|
||||
|
||||
if target_name not in TARGET_NAMES:
|
||||
print "Target '%s' is not a valid target. Excluding from release"
|
||||
print("Target '{}' is not a valid target. Excluding".format(
|
||||
target_name
|
||||
))
|
||||
continue
|
||||
|
||||
if options.official_only:
|
||||
toolchains = (getattr(TARGET_MAP[target_name], 'default_toolchain', 'ARM'),)
|
||||
toolchains = (getattr(
|
||||
TARGET_MAP[target_name], 'default_toolchain', 'ARM'
|
||||
),)
|
||||
else:
|
||||
toolchains = toolchain_list
|
||||
|
||||
if options.toolchains:
|
||||
print "Only building using the following toolchains: %s" % (options.toolchains)
|
||||
print("Building using the following toolchains: {}".format(
|
||||
options.toolchains
|
||||
))
|
||||
toolchainSet = set(toolchains)
|
||||
toolchains = toolchainSet.intersection(set((options.toolchains).split(',')))
|
||||
toolchains = toolchainSet.intersection(
|
||||
set((options.toolchains).split(','))
|
||||
)
|
||||
|
||||
for toolchain in toolchains:
|
||||
built_mbed_lib = build_mbed_libs(
|
||||
|
@ -179,18 +223,28 @@ if __name__ == '__main__':
|
|||
build_profile=extract_profile(parser, options, toolchain),
|
||||
)
|
||||
|
||||
|
||||
# copy targets.json file as part of the release
|
||||
copy(join(dirname(abspath(__file__)), '..', 'targets', 'targets.json'), MBED_LIBRARIES)
|
||||
copy(
|
||||
join(dirname(abspath(__file__)), '..', 'targets', 'targets.json'),
|
||||
MBED_LIBRARIES
|
||||
)
|
||||
|
||||
# Write summary of the builds
|
||||
if options.report_build_file_name:
|
||||
file_report_exporter = ReportExporter(ResultExporterType.JUNIT, package="build")
|
||||
file_report_exporter.report_to_file(build_report, options.report_build_file_name, test_suite_properties=build_properties)
|
||||
file_report_exporter = ReportExporter(
|
||||
ResultExporterType.JUNIT, package="build"
|
||||
)
|
||||
file_report_exporter.report_to_file(
|
||||
build_report,
|
||||
options.report_build_file_name,
|
||||
test_suite_properties=build_properties
|
||||
)
|
||||
|
||||
print "\n\nCompleted in: (%.2f)s" % (time() - start)
|
||||
print("\n\nCompleted in: (%.2f)s" % (time() - start))
|
||||
|
||||
print_report_exporter = ReportExporter(ResultExporterType.PRINT, package="build")
|
||||
print_report_exporter = ReportExporter(
|
||||
ResultExporterType.PRINT, package="build"
|
||||
)
|
||||
status = status and print_report_exporter.report(build_report)
|
||||
|
||||
if not status:
|
||||
|
|
Loading…
Reference in New Issue