mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 18:08:30 -04:00
autotest: ensure we get the BIN flight logs even on mission failure
This commit is contained in:
parent
1fc8116069
commit
7f82397467
@ -180,6 +180,10 @@ def skip_step(step):
|
|||||||
|
|
||||||
def run_step(step):
|
def run_step(step):
|
||||||
'''run one step'''
|
'''run one step'''
|
||||||
|
|
||||||
|
# remove old logs
|
||||||
|
util.run_cmd(util.reltopdir('/bin/rm -rf logs'), dir=util.reltopdir('.'))
|
||||||
|
|
||||||
if step == "prerequisites":
|
if step == "prerequisites":
|
||||||
return test_prerequisites()
|
return test_prerequisites()
|
||||||
|
|
||||||
@ -314,14 +318,18 @@ def write_fullresults():
|
|||||||
results.addfile('ArduPlane code size', 'ArduPlane.sizes.txt')
|
results.addfile('ArduPlane code size', 'ArduPlane.sizes.txt')
|
||||||
results.addfile('ArduPlane stack sizes', 'ArduPlane.framesizes.txt')
|
results.addfile('ArduPlane stack sizes', 'ArduPlane.framesizes.txt')
|
||||||
results.addfile('ArduPlane defaults', 'ArduPlane-defaults.parm')
|
results.addfile('ArduPlane defaults', 'ArduPlane-defaults.parm')
|
||||||
|
results.addglob("ArduPlane log", 'ArduPlane-*.BIN')
|
||||||
results.addfile('ArduCopter build log', 'ArduCopter.txt')
|
results.addfile('ArduCopter build log', 'ArduCopter.txt')
|
||||||
results.addfile('ArduCopter code size', 'ArduCopter.sizes.txt')
|
results.addfile('ArduCopter code size', 'ArduCopter.sizes.txt')
|
||||||
results.addfile('ArduCopter stack sizes', 'ArduCopter.framesizes.txt')
|
results.addfile('ArduCopter stack sizes', 'ArduCopter.framesizes.txt')
|
||||||
results.addfile('ArduCopter defaults', 'ArduCopter-defaults.parm')
|
results.addfile('ArduCopter defaults', 'ArduCopter-defaults.parm')
|
||||||
|
results.addglob("ArduCopter log", 'ArduCopter-*.BIN')
|
||||||
|
results.addglob("CopterAVC log", 'CopterAVC-*.BIN')
|
||||||
results.addfile('APMrover2 build log', 'APMrover2.txt')
|
results.addfile('APMrover2 build log', 'APMrover2.txt')
|
||||||
results.addfile('APMrover2 code size', 'APMrover2.sizes.txt')
|
results.addfile('APMrover2 code size', 'APMrover2.sizes.txt')
|
||||||
results.addfile('APMrover2 stack sizes', 'APMrover2.framesizes.txt')
|
results.addfile('APMrover2 stack sizes', 'APMrover2.framesizes.txt')
|
||||||
results.addfile('APMrover2 defaults', 'APMrover2-defaults.parm')
|
results.addfile('APMrover2 defaults', 'APMrover2-defaults.parm')
|
||||||
|
results.addglob("APMrover2 log", 'APMrover2-*.BIN')
|
||||||
results.addglob('APM:Libraries documentation', 'docs/libraries/index.html')
|
results.addglob('APM:Libraries documentation', 'docs/libraries/index.html')
|
||||||
results.addglob('APM:Plane documentation', 'docs/ArduPlane/index.html')
|
results.addglob('APM:Plane documentation', 'docs/ArduPlane/index.html')
|
||||||
results.addglob('APM:Copter documentation', 'docs/ArduCopter/index.html')
|
results.addglob('APM:Copter documentation', 'docs/ArduCopter/index.html')
|
||||||
@ -333,6 +341,22 @@ def write_fullresults():
|
|||||||
|
|
||||||
results = TestResults()
|
results = TestResults()
|
||||||
|
|
||||||
|
def check_logs(step):
|
||||||
|
'''check for log files from a step'''
|
||||||
|
print("check step: ", step)
|
||||||
|
if step.startswith('fly.'):
|
||||||
|
vehicle = step[4:]
|
||||||
|
elif step.startswith('drive.'):
|
||||||
|
vehicle = step[6:]
|
||||||
|
else:
|
||||||
|
return
|
||||||
|
logs = glob.glob(util.reltopdir("logs/*.BIN"))
|
||||||
|
for log in logs:
|
||||||
|
bname = os.path.basename(log)
|
||||||
|
newname = util.reltopdir("../buildlogs/%s-%s" % (vehicle, bname))
|
||||||
|
print("Renaming %s to %s" % (log, newname))
|
||||||
|
os.rename(log, newname)
|
||||||
|
|
||||||
def run_tests(steps):
|
def run_tests(steps):
|
||||||
'''run a list of steps'''
|
'''run a list of steps'''
|
||||||
global results
|
global results
|
||||||
@ -359,9 +383,11 @@ def run_tests(steps):
|
|||||||
print(">>>> FAILED STEP: %s at %s (%s)" % (step, time.asctime(), msg))
|
print(">>>> FAILED STEP: %s at %s (%s)" % (step, time.asctime(), msg))
|
||||||
traceback.print_exc(file=sys.stdout)
|
traceback.print_exc(file=sys.stdout)
|
||||||
results.add(step, '<span class="failed-text">FAILED</span>', time.time() - t1)
|
results.add(step, '<span class="failed-text">FAILED</span>', time.time() - t1)
|
||||||
|
check_logs(step)
|
||||||
continue
|
continue
|
||||||
results.add(step, '<span class="passed-text">PASSED</span>', time.time() - t1)
|
results.add(step, '<span class="passed-text">PASSED</span>', time.time() - t1)
|
||||||
print(">>>> PASSED STEP: %s at %s" % (step, time.asctime()))
|
print(">>>> PASSED STEP: %s at %s" % (step, time.asctime()))
|
||||||
|
check_logs(step)
|
||||||
if not passed:
|
if not passed:
|
||||||
print("FAILED %u tests: %s" % (len(failed), failed))
|
print("FAILED %u tests: %s" % (len(failed), failed))
|
||||||
|
|
||||||
|
@ -249,7 +249,6 @@ def log_download(mavproxy, mav, filename, timeout=360):
|
|||||||
mav.wait_heartbeat()
|
mav.wait_heartbeat()
|
||||||
mavproxy.send("log download latest %s\n" % filename)
|
mavproxy.send("log download latest %s\n" % filename)
|
||||||
mavproxy.expect("Finished downloading", timeout=timeout)
|
mavproxy.expect("Finished downloading", timeout=timeout)
|
||||||
mavproxy.send("log erase\n")
|
|
||||||
mav.wait_heartbeat()
|
mav.wait_heartbeat()
|
||||||
mav.wait_heartbeat()
|
mav.wait_heartbeat()
|
||||||
return True
|
return True
|
||||||
|
Loading…
Reference in New Issue
Block a user