Tools: autotest: Copter: add Auto RTL test

This commit is contained in:
Iampete1 2024-03-03 19:05:50 +00:00 committed by Randy Mackay
parent 1b1ce9530c
commit 801663a3e6

View File

@ -26,6 +26,7 @@ from vehicle_test_suite import NotAchievedException, AutoTestTimeoutException, P
from vehicle_test_suite import Test
from vehicle_test_suite import MAV_POS_TARGET_TYPE_MASK
from vehicle_test_suite import WaitAndMaintainArmed
from vehicle_test_suite import WaitModeTimeout
from pymavlink.rotmat import Vector3
@ -10909,6 +10910,120 @@ class AutoTestCopter(vehicle_test_suite.TestSuite):
self.wait_altitude(0.5, 100, relative=True, timeout=10)
self.do_RTL()
def AutoRTL(self):
'''Test Auto RTL mode using do land start and return path start mission items'''
alt = 50
guided_loc = self.home_relative_loc_ne(1000, 0)
guided_loc.alt += alt
# Arm, take off and fly to guided location
self.takeoff(mode='GUIDED')
self.fly_guided_move_to(guided_loc, timeout=240)
# Try auto RTL mode, should fail with no mission
try:
self.change_mode('AUTO_RTL', timeout=10)
raise NotAchievedException("Should not change mode with no mission")
except WaitModeTimeout:
pass
except Exception as e:
raise e
# pymavlink does not understand the new return path command yet, at some point it will
cmd_return_path_start = 188 # mavutil.mavlink.MAV_CMD_DO_RETURN_PATH_START
# Do land start and do return path should both fail as commands too
self.run_cmd(mavutil.mavlink.MAV_CMD_DO_LAND_START, want_result=mavutil.mavlink.MAV_RESULT_FAILED)
self.run_cmd(cmd_return_path_start, want_result=mavutil.mavlink.MAV_RESULT_FAILED)
# Load mission with do land start
self.upload_simple_relhome_mission([
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 1000, 0, alt), # 1
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 750, 0, alt), # 2
self.create_MISSION_ITEM_INT(mavutil.mavlink.MAV_CMD_DO_LAND_START), # 3
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 500, 0, alt), # 4
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 250, 0, alt), # 5
])
# Return path should still fail
self.run_cmd(cmd_return_path_start, want_result=mavutil.mavlink.MAV_RESULT_FAILED)
# Do land start should jump to the waypoint following the item
self.run_cmd(mavutil.mavlink.MAV_CMD_DO_LAND_START, want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED)
self.drain_mav()
self.assert_current_waypoint(4)
# Back to guided location
self.change_mode('GUIDED')
self.fly_guided_move_to(guided_loc)
# mode change to Auto RTL should do the same
self.change_mode('AUTO_RTL')
self.drain_mav()
self.assert_current_waypoint(4)
# Back to guided location
self.change_mode('GUIDED')
self.fly_guided_move_to(guided_loc)
# Add a return path item
self.upload_simple_relhome_mission([
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 1250, 0, alt), # 1
self.create_MISSION_ITEM_INT(cmd_return_path_start), # 2
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 900, 0, alt), # 3
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 750, 0, alt), # 4
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 550, 0, alt), # 5
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 500, 0, alt), # 6
self.create_MISSION_ITEM_INT(mavutil.mavlink.MAV_CMD_DO_LAND_START), # 7
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, 250, 0, alt), # 8
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, -250, 0, alt), # 9
(mavutil.mavlink.MAV_CMD_NAV_WAYPOINT, -500, 0, alt), # 10
])
# Return path should now work
self.run_cmd(cmd_return_path_start, want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED)
self.drain_mav()
self.assert_current_waypoint(3)
# Back to guided location
self.change_mode('GUIDED')
self.fly_guided_move_to(guided_loc)
# mode change to Auto RTL should join the return path
self.change_mode('AUTO_RTL')
self.drain_mav()
self.assert_current_waypoint(3)
# do land start should still work
self.run_cmd(mavutil.mavlink.MAV_CMD_DO_LAND_START, want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED)
self.drain_mav()
self.assert_current_waypoint(8)
# Move a bit closer in guided
return_path_test = self.home_relative_loc_ne(600, 0)
return_path_test.alt += alt
self.change_mode('GUIDED')
self.fly_guided_move_to(return_path_test, timeout=100)
# check the mission is joined further along
self.run_cmd(cmd_return_path_start, want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED)
self.drain_mav()
self.assert_current_waypoint(5)
# fly over home
home = self.home_relative_loc_ne(0, 0)
home.alt += alt
self.change_mode('GUIDED')
self.fly_guided_move_to(home, timeout=140)
# Should never join return path after do land start
self.run_cmd(cmd_return_path_start, want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED)
self.drain_mav()
self.assert_current_waypoint(6)
# Done
self.land_and_disarm()
def tests2b(self): # this block currently around 9.5mins here
'''return list of all tests'''
ret = ([
@ -10990,6 +11105,7 @@ class AutoTestCopter(vehicle_test_suite.TestSuite):
self.LoiterToGuidedHomeVSOrigin,
self.GuidedModeThrust,
self.CompassMot,
self.AutoRTL,
])
return ret