Tools: autotest: add test for Copter loiter-to-alt

This commit is contained in:
Peter Barker 2018-07-25 12:57:08 +10:00 committed by Randy Mackay
parent f0ca4de313
commit 4e82250055
3 changed files with 69 additions and 0 deletions

View File

@ -357,6 +357,58 @@ class AutoTestCopter(AutoTest):
return return
raise AutoTestTimeoutException("Did not get home and disarm") raise AutoTestTimeoutException("Did not get home and disarm")
def fly_loiter_to_alt(self):
"""loiter to alt"""
self.context_push()
ex = None
try:
self.set_parameter("PLND_ENABLED", 1)
self.fetch_parameters()
self.set_parameter("PLND_TYPE", 4)
self.set_parameter("RNGFND_TYPE", 1)
self.set_parameter("RNGFND_MIN_CM", 0)
self.set_parameter("RNGFND_MAX_CM", 4000)
self.set_parameter("RNGFND_PIN", 0)
self.set_parameter("RNGFND_SCALING", 12.12)
self.reboot_sitl()
global num_wp
num_wp = self.load_mission("copter_loiter_to_alt.txt")
if not num_wp:
self.progress("load copter_loiter_to_target failed")
raise NotAchievedException()
self.mavproxy.send('switch 5\n')
self.wait_mode('LOITER')
self.wait_ready_to_arm()
self.arm_vehicle()
self.mavproxy.send('mode auto\n')
self.wait_mode('AUTO')
self.set_rc(3, 1550)
self.wait_current_waypoint(2)
self.set_rc(3, 1500)
self.mav.motors_disarmed_wait()
except Exception as e:
ex = e
self.context_pop()
self.reboot_sitl()
if ex is not None:
raise ex
def fly_throttle_failsafe(self, side=60, timeout=180): def fly_throttle_failsafe(self, side=60, timeout=180):
"""Fly east, Failsafe, return, land.""" """Fly east, Failsafe, return, land."""
@ -2146,12 +2198,15 @@ class AutoTestCopter(AutoTest):
self.run_test("Test submode change", self.run_test("Test submode change",
self.fly_guided_change_submode) self.fly_guided_change_submode)
self.run_test("Loiter-To-Alt", self.fly_loiter_to_alt)
self.progress("Waiting for location") self.progress("Waiting for location")
self.homeloc = self.mav.location() self.homeloc = self.mav.location()
self.progress("Home location: %s" % self.homeloc) self.progress("Home location: %s" % self.homeloc)
self.mavproxy.send('switch 6\n') # stabilize mode self.mavproxy.send('switch 6\n') # stabilize mode
self.mav.wait_heartbeat() self.mav.wait_heartbeat()
self.wait_mode('STABILIZE') self.wait_mode('STABILIZE')
self.set_rc(3, 1000)
self.progress("Waiting reading for arm") self.progress("Waiting reading for arm")
self.wait_ready_to_arm() self.wait_ready_to_arm()

View File

@ -1078,6 +1078,14 @@ class AutoTest(ABC):
return True return True
raise WaitLocationTimeout("Failed to attain location") raise WaitLocationTimeout("Failed to attain location")
def wait_current_waypoint(self, wpnum, timeout=60):
tstart = self.get_sim_time()
while self.get_sim_time() < tstart + timeout:
seq = self.mav.waypoint_current()
self.progress("Waiting for wp=%u current=%u" % (wpnum, seq))
if seq == wpnum:
break;
def wait_waypoint(self, def wait_waypoint(self,
wpnum_start, wpnum_start,
wpnum_end, wpnum_end,

View File

@ -0,0 +1,6 @@
QGC WPL 110
0 0 0 16 0.000000 0.000000 0.000000 0.000000 -35.362938 149.165085 584.000000 1
1 0 3 22 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 5.000000 1
2 0 3 31 0.000000 0.000000 0.000000 0.000000 -35.362989 149.165061 30.00000 1
3 0 10 31 0.000000 0.000000 0.000000 1.000000 0.000000 0.000000 2.000000 1
4 0 0 20 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 1