mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 09:58:28 -04:00
autotest: switched to binary log download over MAVLink
This commit is contained in:
parent
3b2ef31cc0
commit
6121b9c58e
@ -151,6 +151,9 @@ def drive_APMrover2(viewerip=None, map=False):
|
|||||||
if not drive_mission(mavproxy, mav, os.path.join(testdir, "rover1.txt")):
|
if not drive_mission(mavproxy, mav, os.path.join(testdir, "rover1.txt")):
|
||||||
print("Failed mission")
|
print("Failed mission")
|
||||||
failed = True
|
failed = True
|
||||||
|
if not log_download(mavproxy, mav, util.reltopdir("../buildlogs/APMrover2-log.bin")):
|
||||||
|
print("Failed log download")
|
||||||
|
failed = True
|
||||||
# if not drive_left_circuit(mavproxy, mav):
|
# if not drive_left_circuit(mavproxy, mav):
|
||||||
# print("Failed left circuit")
|
# print("Failed left circuit")
|
||||||
# failed = True
|
# failed = True
|
||||||
|
@ -1125,6 +1125,10 @@ def fly_ArduCopter(viewerip=None, map=False):
|
|||||||
print("disarm_motors failed")
|
print("disarm_motors failed")
|
||||||
failed = True
|
failed = True
|
||||||
|
|
||||||
|
if not log_download(mavproxy, mav, util.reltopdir("../buildlogs/ArduCopter-log.bin")):
|
||||||
|
print("Failed log download")
|
||||||
|
failed = True
|
||||||
|
|
||||||
except pexpect.TIMEOUT, e:
|
except pexpect.TIMEOUT, e:
|
||||||
failed = True
|
failed = True
|
||||||
|
|
||||||
@ -1264,6 +1268,10 @@ def fly_CopterAVC(viewerip=None, map=False):
|
|||||||
print("disarm_motors failed")
|
print("disarm_motors failed")
|
||||||
failed = True
|
failed = True
|
||||||
|
|
||||||
|
if not log_download(mavproxy, mav, util.reltopdir("../buildlogs/CopterAVC-log.bin")):
|
||||||
|
print("Failed log download")
|
||||||
|
failed = True
|
||||||
|
|
||||||
except pexpect.TIMEOUT, e:
|
except pexpect.TIMEOUT, e:
|
||||||
failed = True
|
failed = True
|
||||||
|
|
||||||
|
@ -535,6 +535,9 @@ def fly_ArduPlane(viewerip=None, map=False):
|
|||||||
target_altitude=homeloc.alt+100):
|
target_altitude=homeloc.alt+100):
|
||||||
print("Failed mission")
|
print("Failed mission")
|
||||||
failed = True
|
failed = True
|
||||||
|
if not log_download(mavproxy, mav, util.reltopdir("../buildlogs/ArduPlane-log.bin")):
|
||||||
|
print("Failed log download")
|
||||||
|
failed = True
|
||||||
except pexpect.TIMEOUT, e:
|
except pexpect.TIMEOUT, e:
|
||||||
print("Failed with timeout")
|
print("Failed with timeout")
|
||||||
failed = True
|
failed = True
|
||||||
|
@ -34,44 +34,6 @@ def get_default_params(atype):
|
|||||||
print("Saved defaults for %s to %s" % (atype, dest))
|
print("Saved defaults for %s to %s" % (atype, dest))
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def dump_logs(atype, logname=None):
|
|
||||||
'''dump DataFlash logs'''
|
|
||||||
print("Dumping logs for %s" % atype)
|
|
||||||
|
|
||||||
if logname is None:
|
|
||||||
logname = atype
|
|
||||||
|
|
||||||
sil = util.start_SIL(atype)
|
|
||||||
logfile = util.reltopdir('../buildlogs/%s.flashlog' % logname)
|
|
||||||
log = open(logfile, mode='w')
|
|
||||||
mavproxy = util.start_MAVProxy_SIL(atype, setup=True, logfile=log)
|
|
||||||
mavproxy.send('\n\n\n')
|
|
||||||
print("navigating menus")
|
|
||||||
mavproxy.expect(']')
|
|
||||||
mavproxy.send("logs\n")
|
|
||||||
mavproxy.expect("logs enabled:")
|
|
||||||
lognums = []
|
|
||||||
i = mavproxy.expect(["No logs", "(\d+) logs"])
|
|
||||||
if i == 0:
|
|
||||||
numlogs = 0
|
|
||||||
else:
|
|
||||||
numlogs = int(mavproxy.match.group(1))
|
|
||||||
for i in range(numlogs):
|
|
||||||
mavproxy.expect("Log (\d+)")
|
|
||||||
lognums.append(int(mavproxy.match.group(1)))
|
|
||||||
mavproxy.expect("Log]")
|
|
||||||
for i in range(numlogs):
|
|
||||||
print("Dumping log %u (i=%u)" % (lognums[i], i))
|
|
||||||
mavproxy.send("dump %u\n" % lognums[i])
|
|
||||||
mavproxy.expect("logs enabled:", timeout=120)
|
|
||||||
mavproxy.expect("Log]")
|
|
||||||
util.pexpect_close(mavproxy)
|
|
||||||
util.pexpect_close(sil)
|
|
||||||
log.close()
|
|
||||||
print("Saved log for %s to %s" % (atype, logfile))
|
|
||||||
return True
|
|
||||||
|
|
||||||
|
|
||||||
def build_all():
|
def build_all():
|
||||||
'''run the build_all.sh script'''
|
'''run the build_all.sh script'''
|
||||||
print("Running build_all.sh")
|
print("Running build_all.sh")
|
||||||
@ -168,21 +130,17 @@ steps = [
|
|||||||
'build.ArduPlane',
|
'build.ArduPlane',
|
||||||
'defaults.ArduPlane',
|
'defaults.ArduPlane',
|
||||||
'fly.ArduPlane',
|
'fly.ArduPlane',
|
||||||
'logs.ArduPlane',
|
|
||||||
|
|
||||||
'build2560.APMrover2',
|
'build2560.APMrover2',
|
||||||
'build.APMrover2',
|
'build.APMrover2',
|
||||||
'defaults.APMrover2',
|
'defaults.APMrover2',
|
||||||
'drive.APMrover2',
|
'drive.APMrover2',
|
||||||
'logs.APMrover2',
|
|
||||||
|
|
||||||
'build2560.ArduCopter',
|
'build2560.ArduCopter',
|
||||||
'build.ArduCopter',
|
'build.ArduCopter',
|
||||||
'defaults.ArduCopter',
|
'defaults.ArduCopter',
|
||||||
'fly.ArduCopter',
|
'fly.ArduCopter',
|
||||||
'logs.ArduCopter',
|
|
||||||
'fly.CopterAVC',
|
'fly.CopterAVC',
|
||||||
'logs.CopterAVC',
|
|
||||||
|
|
||||||
'convertgpx',
|
'convertgpx',
|
||||||
]
|
]
|
||||||
@ -237,18 +195,6 @@ def run_step(step):
|
|||||||
if step == 'defaults.APMrover2':
|
if step == 'defaults.APMrover2':
|
||||||
return get_default_params('APMrover2')
|
return get_default_params('APMrover2')
|
||||||
|
|
||||||
if step == 'logs.ArduPlane':
|
|
||||||
return dump_logs('ArduPlane')
|
|
||||||
|
|
||||||
if step == 'logs.ArduCopter':
|
|
||||||
return dump_logs('ArduCopter')
|
|
||||||
|
|
||||||
if step == 'logs.CopterAVC':
|
|
||||||
return dump_logs('ArduCopter', 'CopterAVC')
|
|
||||||
|
|
||||||
if step == 'logs.APMrover2':
|
|
||||||
return dump_logs('APMrover2')
|
|
||||||
|
|
||||||
if step == 'fly.ArduCopter':
|
if step == 'fly.ArduCopter':
|
||||||
return arducopter.fly_ArduCopter(viewerip=opts.viewerip, map=opts.map)
|
return arducopter.fly_ArduCopter(viewerip=opts.viewerip, map=opts.map)
|
||||||
|
|
||||||
@ -343,7 +289,7 @@ def write_fullresults():
|
|||||||
global results
|
global results
|
||||||
results.addglob("Google Earth track", '*.kmz')
|
results.addglob("Google Earth track", '*.kmz')
|
||||||
results.addfile('Full Logs', 'autotest-output.txt')
|
results.addfile('Full Logs', 'autotest-output.txt')
|
||||||
results.addglob('DataFlash Log', '*.flashlog')
|
results.addglob('DataFlash Log', '*-log.bin')
|
||||||
results.addglob("MAVLink log", '*.tlog')
|
results.addglob("MAVLink log", '*.tlog')
|
||||||
results.addglob("GPX track", '*.gpx')
|
results.addglob("GPX track", '*.gpx')
|
||||||
results.addfile('ArduPlane build log', 'ArduPlane.txt')
|
results.addfile('ArduPlane build log', 'ArduPlane.txt')
|
||||||
|
@ -242,3 +242,14 @@ def sim_location(mav):
|
|||||||
from pymavlink import mavutil
|
from pymavlink import mavutil
|
||||||
m = mav.recv_match(type='SIMSTATE', blocking=True)
|
m = mav.recv_match(type='SIMSTATE', blocking=True)
|
||||||
return mavutil.location(m.lat*1.0e-7, m.lng*1.0e-7, 0, math.degrees(m.yaw))
|
return mavutil.location(m.lat*1.0e-7, m.lng*1.0e-7, 0, math.degrees(m.yaw))
|
||||||
|
|
||||||
|
def log_download(mavproxy, mav, filename, timeout=60):
|
||||||
|
'''download latest log'''
|
||||||
|
mavproxy.send("log list\n")
|
||||||
|
mavproxy.expect("numLogs")
|
||||||
|
mav.wait_heartbeat()
|
||||||
|
mav.wait_heartbeat()
|
||||||
|
mavproxy.send("log download latest %s\n" % filename)
|
||||||
|
mavproxy.expect("Finished downloading", timeout=timeout)
|
||||||
|
return True
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user