autotest: switched to binary log download over MAVLink

This commit is contained in:
Andrew Tridgell 2013-12-28 21:47:12 +11:00
parent 3b2ef31cc0
commit 6121b9c58e
5 changed files with 26 additions and 55 deletions

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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')

View File

@ -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