Tools: autotest: add IRLock SITL test

This commit is contained in:
Pierre Kancir 2021-06-14 12:33:05 +02:00 committed by Peter Barker
parent ddb7378bdd
commit 8234fd4c39

View File

@ -3097,53 +3097,55 @@ class AutoTestCopter(AutoTest):
self.wait_statustext("finished motor test") self.wait_statustext("finished motor test")
self.end_subtest("Testing percentage output") self.end_subtest("Testing percentage output")
def fly_precision_sitl(self): def fly_precision_landing_drivers(self):
"""Use SITL PrecLand backend precision messages to land aircraft.""" """Use PrecLand backends precision messages to land aircraft."""
self.context_push() self.context_push()
ex = None for backend in [4, 2]: # SITL, SITL-IRLOCK
try: ex = None
self.set_parameter("PLND_ENABLED", 1) try:
self.set_parameter("PLND_TYPE", 4) self.set_parameter("PLND_ENABLED", 1)
self.set_parameter("PLND_TYPE", backend)
self.set_analog_rangefinder_parameters() self.set_analog_rangefinder_parameters()
self.set_parameter("SIM_SONAR_SCALE", 12) self.set_parameter("SIM_SONAR_SCALE", 12)
start = self.mav.location() start = self.mav.location()
target = start target = start
(target.lat, target.lng) = mavextra.gps_offset(start.lat, start.lng, 4, -4) (target.lat, target.lng) = mavextra.gps_offset(start.lat, start.lng, 4, -4)
self.progress("Setting target to %f %f" % (target.lat, target.lng)) self.progress("Setting target to %f %f" % (target.lat, target.lng))
self.set_parameter("SIM_PLD_ENABLE", 1) self.set_parameter("SIM_PLD_ENABLE", 1)
self.set_parameter("SIM_PLD_LAT", target.lat) self.set_parameter("SIM_PLD_LAT", target.lat)
self.set_parameter("SIM_PLD_LON", target.lng) self.set_parameter("SIM_PLD_LON", target.lng)
self.set_parameter("SIM_PLD_HEIGHT", 0) self.set_parameter("SIM_PLD_HEIGHT", 0)
self.set_parameter("SIM_PLD_ALT_LMT", 15) self.set_parameter("SIM_PLD_ALT_LMT", 15)
self.set_parameter("SIM_PLD_DIST_LMT", 10) self.set_parameter("SIM_PLD_DIST_LMT", 10)
self.reboot_sitl()
self.progress("Waiting for location")
self.zero_throttle()
self.takeoff(10, 1800, mode="LOITER")
self.change_mode("LAND")
self.zero_throttle()
self.wait_landed_and_disarmed()
self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True)
new_pos = self.mav.location()
delta = self.get_distance(target, new_pos)
self.progress("Landed %f metres from target position" % delta)
max_delta = 1
if delta > max_delta:
raise NotAchievedException("Did not land close enough to target position (%fm > %fm" % (delta, max_delta))
if not self.current_onboard_log_contains_message("PL"):
raise NotAchievedException("Did not see expected PL message")
except Exception as e:
self.print_exception_caught(e)
ex = e
self.reboot_sitl() self.reboot_sitl()
self.progress("Waiting for location")
self.zero_throttle()
self.takeoff(10, 1800)
self.change_mode("LAND")
self.wait_landed_and_disarmed()
self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True)
new_pos = self.mav.location()
delta = self.get_distance(target, new_pos)
self.progress("Landed %f metres from target position" % delta)
max_delta = 1
if delta > max_delta:
raise NotAchievedException("Did not land close enough to target position (%fm > %fm" % (delta, max_delta))
if not self.current_onboard_log_contains_message("PL"):
raise NotAchievedException("Did not see expected PL message")
except Exception as e:
self.print_exception_caught(e)
ex = e
self.zero_throttle() self.zero_throttle()
self.context_pop() self.context_pop()
self.reboot_sitl() self.reboot_sitl()
@ -7085,8 +7087,8 @@ class AutoTestCopter(AutoTest):
self.fly_precision_companion), # 29s self.fly_precision_companion), # 29s
("PrecisionLandingSITL", ("PrecisionLandingSITL",
"Precision Landing (SITL)", "Precision Landing drivers (SITL)",
self.fly_precision_sitl), # 29s self.fly_precision_landing_drivers), # 29s
("SetModesViaModeSwitch", ("SetModesViaModeSwitch",
"Set modes via modeswitch", "Set modes via modeswitch",