autotest: integrate features.json generation to build_binaries.py

we have to run the extract_features.py that corresponds to the branch being built.  We may say a feature is presnet when it isn't or vice-versa if we don't.
This commit is contained in:
Peter Barker 2022-07-29 13:42:02 +10:00 committed by Andrew Tridgell
parent 10038a64be
commit b19035b9a7
2 changed files with 39 additions and 60 deletions

View File

@ -35,16 +35,27 @@ else:
running_python3 = True running_python3 = True
def topdir():
'''return path to ardupilot checkout directory. This is to cope with
running on developer's machines (where autotest is typically
invoked from the root directory), and on the autotest server where
it is invoked in the checkout's parent directory.
'''
for path in [
os.path.join(os.path.dirname(os.path.abspath(__file__)), "..", ".."),
"",
]:
if os.path.exists(os.path.join(path, "libraries", "AP_HAL_ChibiOS")):
return path
raise Exception("Unable to find ardupilot checkout dir")
def is_chibios_build(board): def is_chibios_build(board):
'''see if a board is using HAL_ChibiOS''' '''see if a board is using HAL_ChibiOS'''
# cope with both running from Tools/scripts or running from cwd # cope with both running from Tools/scripts or running from cwd
hwdef_dir = os.path.join(os.path.dirname(os.path.abspath(__file__)), "..", "..", "libraries", "AP_HAL_ChibiOS", "hwdef") hwdef_dir = os.path.join(topdir(), "libraries", "AP_HAL_ChibiOS", "hwdef")
if os.path.exists(os.path.join(hwdef_dir, board, "hwdef.dat")):
return True return os.path.exists(os.path.join(hwdef_dir, board, "hwdef.dat"))
hwdef_dir = os.path.join("libraries", "AP_HAL_ChibiOS", "hwdef")
if os.path.exists(os.path.join(hwdef_dir, board, "hwdef.dat")):
return True
return False
def get_required_compiler(vehicle, tag, board): def get_required_compiler(vehicle, tag, board):
@ -491,6 +502,20 @@ is bob we will attempt to checkout bob-AVR'''
files_to_copy.append((filepath, os.path.basename(filepath))) files_to_copy.append((filepath, os.path.basename(filepath)))
if not os.path.exists(bare_path): if not os.path.exists(bare_path):
raise Exception("No elf file?!") raise Exception("No elf file?!")
# attempt to run an extract_features.py to create features.txt:
features_text = None
ef_path = os.path.join(topdir(), "Tools", "scripts", "extract_features.py")
if os.path.exists(ef_path):
try:
features_text = self.run_program("EF", [ef_path, bare_path], show_output=False)
except Exception as e:
self.print_exception_caught(e)
self.progress("Failed to extract features")
pass
else:
self.progress("Not extracting features as (%s) does not exist" % (ef_path,))
# only rename the elf if we have have other files to # only rename the elf if we have have other files to
# copy. So linux gets "arducopter" and stm32 gets # copy. So linux gets "arducopter" and stm32 gets
# "arducopter.elf" # "arducopter.elf"
@ -512,6 +537,9 @@ is bob we will attempt to checkout bob-AVR'''
if not os.path.exists(ddir): if not os.path.exists(ddir):
self.mkpath(ddir) self.mkpath(ddir)
self.addfwversion(ddir, vehicle) self.addfwversion(ddir, vehicle)
features_filepath = os.path.join(ddir, "features.txt",)
self.progress("Writing (%s)" % features_filepath)
self.write_string_to_filepath(features_text, features_filepath)
self.progress("Copying %s to %s" % (path, ddir,)) self.progress("Copying %s to %s" % (path, ddir,))
shutil.copy(path, os.path.join(ddir, target_filename)) shutil.copy(path, os.path.join(ddir, target_filename))
# the most recent build of every tag is kept around: # the most recent build of every tag is kept around:
@ -521,10 +549,13 @@ is bob we will attempt to checkout bob-AVR'''
# must addfwversion even if path already # must addfwversion even if path already
# exists as we re-use the "beta" directories # exists as we re-use the "beta" directories
self.addfwversion(tdir, vehicle) self.addfwversion(tdir, vehicle)
features_filepath = os.path.join(tdir, "features.txt")
self.progress("Writing (%s)" % features_filepath)
self.write_string_to_filepath(features_text, features_filepath)
shutil.copy(path, os.path.join(tdir, target_filename)) shutil.copy(path, os.path.join(tdir, target_filename))
except Exception as e: except Exception as e:
self.print_exception_caught(e) self.print_exception_caught(e)
self.progress("Failed to copy %s to %s: %s" % (path, ddir, str(e))) self.progress("Failed to copy %s to %s: %s" % (path, tdir, str(e)))
# why is touching this important? -pb20170816 # why is touching this important? -pb20170816
self.touch_filepath(os.path.join(self.binaries, self.touch_filepath(os.path.join(self.binaries,
vehicle_binaries_subdir, tag)) vehicle_binaries_subdir, tag))

View File

@ -1,52 +0,0 @@
#!/usr/bin/env python
'''
recurse through directory tree rooted at supplied path. For every elf file found, write out next to it a features.txt
'''
import optparse
import os
import sys
import extract_features
class GenerateFeatureTxtFiles(object):
def __init__(self, path):
self.path = path
def write_features_txt_for_filepath(self, filepath):
ef = extract_features.ExtractFeatures(filepath)
text = ef.create_string()
features_txt_filepath = os.path.join(os.path.dirname(filepath), "features.txt")
with open(features_txt_filepath, "w") as fh:
fh.write(text)
def run(self):
done_dirpaths = dict()
for (dirpath, dirnames, filenames) in os.walk(self.path):
for filename in filenames:
if os.path.splitext(filename)[1].upper() != ".ELF":
continue
if dirpath in done_dirpaths:
raise ValueError(
"Already processed elf (%s) in dirpath (%s) but also found elf (%s)" %
(done_dirpaths[dirpath], dirpath, filename))
done_dirpaths[dirpath] = filename
filepath = os.path.join(dirpath, filename)
self.write_features_txt_for_filepath(filepath)
if __name__ == '__main__':
parser = optparse.OptionParser("generate_features_txt_files.py DIRPATH")
cmd_opts, cmd_args = parser.parse_args()
if len(cmd_args) < 1:
parser.print_help()
sys.exit(1)
dirpath = cmd_args[0]
gen = GenerateFeatureTxtFiles(dirpath)
gen.run()