Test spec paths are now relative to tool execution directory

This commit also normalizes the paths produced by the the test spec to
Unix style paths to increase portability of the file.
pull/2076/head
Brian Daniels 2016-06-30 09:29:04 -05:00
parent 07958da38b
commit b7186bb604
1 changed files with 15 additions and 2 deletions

View File

@ -2008,6 +2008,15 @@ def print_tests(tests, format="list", sort=True):
print "Unknown format '%s'" % format print "Unknown format '%s'" % format
sys.exit(1) sys.exit(1)
def norm_relative_path(path, start):
"""This function will create a normalized, relative path. It mimics the
python os.path.relpath function, but also normalizes a Windows-syle path
that use backslashes to a Unix style path that uses forward slashes."""
path = os.path.normpath(path)
path = os.path.relpath(path, start)
path = path.replace("\\", "/")
return path
def build_tests(tests, base_source_paths, build_path, target, toolchain_name, def build_tests(tests, base_source_paths, build_path, target, toolchain_name,
options=None, clean=False, notify=None, verbose=False, jobs=1, options=None, clean=False, notify=None, verbose=False, jobs=1,
macros=None, silent=False, report=None, properties=None, macros=None, silent=False, report=None, properties=None,
@ -2018,10 +2027,14 @@ def build_tests(tests, base_source_paths, build_path, target, toolchain_name,
Returns a tuple of the build result (True or False) followed by the test Returns a tuple of the build result (True or False) followed by the test
build data structure""" build data structure"""
execution_directory = "."
base_path = norm_relative_path(build_path, execution_directory)
test_build = { test_build = {
"platform": target.name, "platform": target.name,
"toolchain": toolchain_name, "toolchain": toolchain_name,
"base_path": build_path, "base_path": base_path,
"baud_rate": 9600, "baud_rate": 9600,
"binary_type": "bootable", "binary_type": "bootable",
"tests": {} "tests": {}
@ -2060,7 +2073,7 @@ def build_tests(tests, base_source_paths, build_path, target, toolchain_name,
# Normalize the path # Normalize the path
if bin_file: if bin_file:
bin_file = os.path.normpath(bin_file) bin_file = norm_relative_path(bin_file, execution_directory)
test_build['tests'][test_name] = { test_build['tests'][test_name] = {
"binaries": [ "binaries": [