autotest: added wait_mode() helper

This commit is contained in:
Andrew Tridgell 2011-11-12 22:12:38 +11:00
parent 1e22945981
commit 0f00b4c722
2 changed files with 27 additions and 10 deletions

View File

@ -18,7 +18,7 @@ def arm_motors(mavproxy):
'''arm motors''' '''arm motors'''
print("Arming motors") print("Arming motors")
mavproxy.send('switch 6\n') # stabilize mode mavproxy.send('switch 6\n') # stabilize mode
mavproxy.expect('STABILIZE>') mav.wait_mode('STABILIZE')
mavproxy.send('rc 3 1000\n') mavproxy.send('rc 3 1000\n')
mavproxy.send('rc 4 2000\n') mavproxy.send('rc 4 2000\n')
mavproxy.expect('APM: ARMING MOTORS') mavproxy.expect('APM: ARMING MOTORS')
@ -41,7 +41,7 @@ def disarm_motors(mavproxy):
def takeoff(mavproxy, mav): def takeoff(mavproxy, mav):
'''takeoff get to 30m altitude''' '''takeoff get to 30m altitude'''
mavproxy.send('switch 6\n') # stabilize mode mavproxy.send('switch 6\n') # stabilize mode
mavproxy.expect('STABILIZE>') mav.wait_mode('STABILIZE')
mavproxy.send('rc 3 1500\n') mavproxy.send('rc 3 1500\n')
wait_altitude(mav, 30, 40) wait_altitude(mav, 30, 40)
print("TAKEOFF COMPLETE") print("TAKEOFF COMPLETE")
@ -50,10 +50,8 @@ def takeoff(mavproxy, mav):
def loiter(mavproxy, mav, maxaltchange=10, holdtime=10, timeout=60): def loiter(mavproxy, mav, maxaltchange=10, holdtime=10, timeout=60):
'''hold loiter position''' '''hold loiter position'''
mavproxy.send('switch 2\n') # loiter mode mavproxy.send('switch 5\n') # loiter mode
mavproxy.expect('LOITER>') mav.wait_mode('LOITER')
mavproxy.send('status\n')
mavproxy.expect('>')
m = mav.recv_match(type='VFR_HUD', blocking=True) m = mav.recv_match(type='VFR_HUD', blocking=True)
start_altitude = m.alt start_altitude = m.alt
tstart = time.time() tstart = time.time()
@ -74,7 +72,7 @@ def loiter(mavproxy, mav, maxaltchange=10, holdtime=10, timeout=60):
def fly_square(mavproxy, mav, side=50, timeout=120): def fly_square(mavproxy, mav, side=50, timeout=120):
'''fly a square, flying N then E''' '''fly a square, flying N then E'''
mavproxy.send('switch 6\n') mavproxy.send('switch 6\n')
mavproxy.expect('STABILIZE>') mav.wait_mode('STABILIZE')
tstart = time.time() tstart = time.time()
failed = False failed = False
@ -134,9 +132,7 @@ def land(mavproxy, mav, timeout=60):
'''land the quad''' '''land the quad'''
print("STARTING LANDING") print("STARTING LANDING")
mavproxy.send('switch 6\n') mavproxy.send('switch 6\n')
mavproxy.expect('STABILIZE>') mav.wait_mode('STABILIZE')
mavproxy.send('status\n')
mavproxy.expect('>')
# start by dropping throttle till we have lost 5m # start by dropping throttle till we have lost 5m
mavproxy.send('rc 3 1380\n') mavproxy.send('rc 3 1380\n')

View File

@ -35,6 +35,9 @@ class location(object):
self.lng = lng self.lng = lng
self.alt = alt self.alt = alt
def __str__(self):
return "lat=%.6f,lon=%.6f,alt=%.1f" % (self.lat, self.lng, self.alt)
def get_distance(loc1, loc2): def get_distance(loc1, loc2):
'''get ground distance between two locations''' '''get ground distance between two locations'''
dlat = loc2.lat - loc1.lat dlat = loc2.lat - loc1.lat
@ -72,6 +75,20 @@ def wait_altitude(mav, alt_min, alt_max, timeout=30):
return False return False
def wait_roll(mav, roll, accuracy, timeout=30):
'''wait for a given roll in degrees'''
tstart = time.time()
print("Waiting for roll of %u" % roll)
while time.time() < tstart + timeout:
m = mav.recv_match(type='ATTITUDE', blocking=True)
r = math.degrees(m.roll)
print("Roll %u" % r)
if math.fabs(r - roll) <= accuracy:
return True
print("Failed to attain roll %u" % roll)
return False
def wait_heading(mav, heading, accuracy=5, timeout=30): def wait_heading(mav, heading, accuracy=5, timeout=30):
'''wait for a given heading''' '''wait for a given heading'''
@ -155,3 +172,7 @@ def save_wp(mavproxy, mav):
mavproxy.send('rc 7 1000\n') mavproxy.send('rc 7 1000\n')
mav.recv_match(condition='RC_CHANNELS_RAW.chan7_raw==1000', blocking=True) mav.recv_match(condition='RC_CHANNELS_RAW.chan7_raw==1000', blocking=True)
mavproxy.send('wp list\n') mavproxy.send('wp list\n')
def wait_mode(mav, mode):
'''wait for a flight mode to be engaged'''
mav.recv_match(condition='MAV.flightmode=="%s"' % mode, blocking=True)