autotest: tidy various ArduPlane autotests

autotest: tidy Plane TerrainRally test

autotest: tidy Plane TestFlaps test

autotest: tidy Plane ThrottleFailsafe test

autotest: tidy Plane GripperMission test

autotest: tidy Plane FenceStatic test

autotest: tidy Plane FenceRTL tests

autotest: tidy FenceRetRally test

autotest: tidy Plane ahrs2 test

autotest: tidy Plane RangeFinder test

autotest: tidy Plane ADSB test

autotest: tidy Plane LOITER test

autotest: tidy Plane EKFLaneswitch test

autotest: tidy Plane FenceAltCeilFloor test

autotest: tidy Plane FenceMinAltAutoEnable

autotest: tidy Plane FenceMinAltEnableAutoland

autotest: tidy Plane FenceMinAltAutoEnableAbort

autotest: tidy Plane FenceCircleExclusionAutoEnable

autotest: tidy self.homeloc out of MainFlight
This commit is contained in:
Peter Barker 2024-07-27 22:55:25 +10:00 committed by Peter Barker
parent 2ce6532698
commit 317c59c709

View File

@ -173,7 +173,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def fly_RTL(self): def fly_RTL(self):
"""Fly to home.""" """Fly to home."""
self.progress("Flying home in RTL") self.progress("Flying home in RTL")
target_loc = self.homeloc target_loc = self.home_position_as_mav_location()
target_loc.alt += 100 target_loc.alt += 100
self.change_mode('RTL') self.change_mode('RTL')
self.wait_location(target_loc, self.wait_location(target_loc,
@ -275,8 +275,10 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
return return
raise NotAchievedException("Failed to attain level flight") raise NotAchievedException("Failed to attain level flight")
def change_altitude(self, altitude, accuracy=30): def change_altitude(self, altitude, accuracy=30, relative=False):
"""Get to a given altitude.""" """Get to a given altitude."""
if relative:
altitude += self.home_position_as_mav_location().alt
self.change_mode('FBWA') self.change_mode('FBWA')
alt_error = self.mav.messages['VFR_HUD'].alt - altitude alt_error = self.mav.messages['VFR_HUD'].alt - altitude
if alt_error > 0: if alt_error > 0:
@ -293,7 +295,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
"""Fly a left axial roll.""" """Fly a left axial roll."""
# full throttle! # full throttle!
self.set_rc(3, 2000) self.set_rc(3, 2000)
self.change_altitude(self.homeloc.alt+300) self.change_altitude(300, relative=True)
# fly the roll in manual # fly the roll in manual
self.change_mode('MANUAL') self.change_mode('MANUAL')
@ -320,7 +322,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
"""Fly a inside loop.""" """Fly a inside loop."""
# full throttle! # full throttle!
self.set_rc(3, 2000) self.set_rc(3, 2000)
self.change_altitude(self.homeloc.alt+300) self.change_altitude(300, relative=True)
# fly the loop in manual # fly the loop in manual
self.change_mode('MANUAL') self.change_mode('MANUAL')
@ -432,7 +434,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
# full throttle! # full throttle!
self.set_rc(3, 2000) self.set_rc(3, 2000)
self.set_rc(2, 1300) self.set_rc(2, 1300)
self.change_altitude(self.homeloc.alt+300) self.change_altitude(300, relative=True)
self.set_rc(2, 1500) self.set_rc(2, 1500)
self.change_mode('STABILIZE') self.change_mode('STABILIZE')
@ -458,7 +460,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
# full throttle! # full throttle!
self.set_rc(3, 2000) self.set_rc(3, 2000)
self.set_rc(2, 1300) self.set_rc(2, 1300)
self.change_altitude(self.homeloc.alt+300) self.change_altitude(300, relative=True)
self.set_rc(2, 1500) self.set_rc(2, 1500)
self.change_mode('ACRO') self.change_mode('ACRO')
@ -1031,10 +1033,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def TestFlaps(self): def TestFlaps(self):
"""Test flaps functionality.""" """Test flaps functionality."""
filename = "flaps.txt" filename = "flaps.txt"
self.context_push()
ex = None
try:
flaps_ch = 5 flaps_ch = 5
flaps_ch_min = 1000 flaps_ch_min = 1000
flaps_ch_trim = 1500 flaps_ch_trim = 1500
@ -1081,45 +1079,15 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Flying mission %s" % filename) self.progress("Flying mission %s" % filename)
self.load_mission(filename) self.load_mission(filename)
self.set_current_waypoint(1)
self.change_mode('AUTO') self.change_mode('AUTO')
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.arm_vehicle() self.arm_vehicle()
last_mission_current_msg = 0 # flaps should deploy for landing (RC input value used for position?!)
last_seq = None self.wait_servo_channel_value(servo_ch, flaps_ch_trim, timeout=300)
while self.armed():
m = self.mav.recv_match(type='MISSION_CURRENT', blocking=True)
time_delta = (self.get_sim_time_cached() -
last_mission_current_msg)
if (time_delta > 1 or m.seq != last_seq):
dist = None
x = self.mav.messages.get("NAV_CONTROLLER_OUTPUT", None)
if x is not None:
dist = x.wp_dist
self.progress("MISSION_CURRENT.seq=%u (dist=%s)" %
(m.seq, str(dist)))
last_mission_current_msg = self.get_sim_time_cached()
last_seq = m.seq
# flaps should undeploy at the end # flaps should undeploy at the end
self.wait_servo_channel_value(servo_ch, servo_ch_min, timeout=30) self.wait_servo_channel_value(servo_ch, servo_ch_min, timeout=30)
# do a short flight in FBWA, watching for flaps
# self.mavproxy.send('switch 4\n')
# self.wait_mode('FBWA')
# self.delay_sim_time(10)
# self.mavproxy.send('switch 6\n')
# self.wait_mode('MANUAL')
# self.delay_sim_time(10)
self.progress("Flaps OK") self.progress("Flaps OK")
except Exception as e:
self.print_exception_caught(e)
ex = e
self.context_pop()
if ex:
if self.armed():
self.disarm_vehicle()
raise ex
def TestRCRelay(self): def TestRCRelay(self):
'''Test Relay RC Channel Option''' '''Test Relay RC Channel Option'''
@ -1284,8 +1252,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Ensure long failsafe can trigger when short failsafe disabled") self.progress("Ensure long failsafe can trigger when short failsafe disabled")
self.context_push() self.context_push()
self.context_collect("STATUSTEXT") self.context_collect("STATUSTEXT")
ex = None
try:
self.set_parameters({ self.set_parameters({
"FS_SHORT_ACTN": 3, # 3 means disabled "FS_SHORT_ACTN": 3, # 3 means disabled
"SIM_RC_FAIL": 1, "SIM_RC_FAIL": 1,
@ -1304,12 +1270,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
}) })
self.wait_statustext("Long Failsafe on", check_context=True) self.wait_statustext("Long Failsafe on", check_context=True)
self.wait_mode("RTL") self.wait_mode("RTL")
except Exception as e:
self.print_exception_caught(e)
ex = e
self.context_pop() self.context_pop()
if ex is not None:
raise ex
self.start_subtest("Not use RC throttle input when THR_FAILSAFE==2") self.start_subtest("Not use RC throttle input when THR_FAILSAFE==2")
self.takeoff(100) self.takeoff(100)
@ -1432,9 +1393,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def TestGripperMission(self): def TestGripperMission(self):
'''Test Gripper mission items''' '''Test Gripper mission items'''
self.context_push()
ex = None
try:
self.set_parameter("RTL_AUTOLAND", 1) self.set_parameter("RTL_AUTOLAND", 1)
self.load_mission("plane-gripper-mission.txt") self.load_mission("plane-gripper-mission.txt")
self.set_current_waypoint(1) self.set_current_waypoint(1)
@ -1444,12 +1402,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.wait_statustext("Gripper Grabbed", timeout=60) self.wait_statustext("Gripper Grabbed", timeout=60)
self.wait_statustext("Gripper Released", timeout=60) self.wait_statustext("Gripper Released", timeout=60)
self.wait_statustext("Auto disarmed", timeout=60) self.wait_statustext("Auto disarmed", timeout=60)
except Exception as e:
self.print_exception_caught(e)
ex = e
self.context_pop()
if ex is not None:
raise ex
def assert_fence_sys_status(self, present, enabled, health): def assert_fence_sys_status(self, present, enabled, health):
self.delay_sim_time(1) self.delay_sim_time(1)
@ -1538,8 +1490,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def FenceStatic(self): def FenceStatic(self):
'''Test Basic Fence Functionality''' '''Test Basic Fence Functionality'''
ex = None
try:
self.progress("Checking for bizarre healthy-when-not-present-or-enabled") self.progress("Checking for bizarre healthy-when-not-present-or-enabled")
self.set_parameter("FENCE_TYPE", 4) # Start by only setting polygon fences, otherwise fence will report present self.set_parameter("FENCE_TYPE", 4) # Start by only setting polygon fences, otherwise fence will report present
self.assert_fence_sys_status(False, False, True) self.assert_fence_sys_status(False, False, True)
@ -1642,18 +1592,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.delay_sim_time(2) # Allow breach to propagate self.delay_sim_time(2) # Allow breach to propagate
self.try_arm(False, "vehicle outside Polygon fence") self.try_arm(False, "vehicle outside Polygon fence")
self.do_fence_disable() self.do_fence_disable()
self.clear_fence()
except Exception as e:
self.print_exception_caught(e)
ex = e
self.clear_fence()
if ex is not None:
raise ex
def test_fence_breach_circle_at(self, loc, disable_on_breach=False): def test_fence_breach_circle_at(self, loc, disable_on_breach=False):
ex = None
try:
self.load_fence("CMAC-fence.txt") self.load_fence("CMAC-fence.txt")
want_radius = 100 want_radius = 100
# when ArduPlane is fixed, remove this fudge factor # when ArduPlane is fixed, remove this fudge factor
@ -1690,61 +1630,26 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.assert_fence_sys_status(True, True, False) self.assert_fence_sys_status(True, True, False)
break break
if disable_on_breach:
self.do_fence_disable()
self.wait_circling_point_with_radius(loc, expected_radius) self.wait_circling_point_with_radius(loc, expected_radius)
self.do_fence_disable()
self.disarm_vehicle(force=True) self.disarm_vehicle(force=True)
self.reboot_sitl() self.reboot_sitl()
except Exception as e:
self.print_exception_caught(e)
ex = e
self.clear_fence()
if ex is not None:
raise ex
def FenceRTL(self): def FenceRTL(self):
'''Test Fence RTL''' '''Test Fence RTL'''
self.progress("Testing FENCE_ACTION_RTL no rally point") self.progress("Testing FENCE_ACTION_RTL no rally point")
# have to disable the fence once we've breached or we breach # have to disable the fence once we've breached or we breach
# it as part of the loiter-at-home! # it as part of the loiter-at-home!
self.test_fence_breach_circle_at(self.home_position_as_mav_location(), self.test_fence_breach_circle_at(self.home_position_as_mav_location())
disable_on_breach=True)
def FenceRTLRally(self): def FenceRTLRally(self):
'''Test Fence RTL Rally''' '''Test Fence RTL Rally'''
ex = None
target_system = 1
target_component = 1
try:
self.progress("Testing FENCE_ACTION_RTL with rally point") self.progress("Testing FENCE_ACTION_RTL with rally point")
self.wait_ready_to_arm() self.wait_ready_to_arm()
loc = self.home_relative_loc_ne(50, -50) loc = self.home_relative_loc_ne(50, -50)
self.upload_rally_points_from_locations([loc])
self.set_parameter("RALLY_TOTAL", 1)
self.mav.mav.rally_point_send(target_system,
target_component,
0, # sequence number
1, # total count
int(loc.lat * 1e7),
int(loc.lng * 1e7),
15,
0, # "break" alt?!
0, # "land dir"
0) # flags
self.delay_sim_time(1)
if self.mavproxy is not None:
self.mavproxy.send("rally list\n")
self.test_fence_breach_circle_at(loc) self.test_fence_breach_circle_at(loc)
except Exception as e:
self.print_exception_caught(e)
ex = e
self.clear_mission(mavutil.mavlink.MAV_MISSION_TYPE_RALLY)
if ex is not None:
raise ex
def FenceRetRally(self): def FenceRetRally(self):
""" Tests the FENCE_RET_RALLY flag, either returning to fence return point, """ Tests the FENCE_RET_RALLY flag, either returning to fence return point,
@ -1754,7 +1659,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Testing FENCE_ACTION_RTL with fence rally point") self.progress("Testing FENCE_ACTION_RTL with fence rally point")
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.homeloc = self.mav.location()
# Grab a location for fence return point, and upload it. # Grab a location for fence return point, and upload it.
fence_loc = self.home_position_as_mav_location() fence_loc = self.home_position_as_mav_location()
@ -1784,18 +1688,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
# Grab a location for rally point, and upload it. # Grab a location for rally point, and upload it.
rally_loc = self.home_relative_loc_ne(-50, 50) rally_loc = self.home_relative_loc_ne(-50, 50)
self.set_parameter("RALLY_TOTAL", 1) self.upload_rally_points_from_locations([rally_loc])
self.mav.mav.rally_point_send(target_system,
target_component,
0, # sequence number
1, # total count
int(rally_loc.lat * 1e7),
int(rally_loc.lng * 1e7),
15,
0, # "break" alt?!
0, # "land dir"
0) # flags
self.delay_sim_time(1)
return_radius = 100 return_radius = 100
return_alt = 80 return_alt = 80
@ -1821,7 +1714,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.delay_sim_time(15) self.delay_sim_time(15)
# Fly up before re-triggering fence breach. Fly to fence return point # Fly up before re-triggering fence breach. Fly to fence return point
self.change_altitude(self.homeloc.alt+30) self.change_altitude(30, relative=True)
self.set_parameters({ self.set_parameters({
"FENCE_RET_RALLY": 0, "FENCE_RET_RALLY": 0,
"FENCE_ALT_MIN": 60, "FENCE_ALT_MIN": 60,
@ -1867,12 +1760,12 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Got required terrain") self.progress("Got required terrain")
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.homeloc = self.mav.location() homeloc = self.mav.location()
guided_loc = mavutil.location(-35.39723762, 149.07284612, self.homeloc.alt+99.0, 0) guided_loc = mavutil.location(-35.39723762, 149.07284612, homeloc.alt+99.0, 0)
rally_loc = mavutil.location(-35.3654952000, 149.1558698000, self.homeloc.alt+100, 0) rally_loc = mavutil.location(-35.3654952000, 149.1558698000, homeloc.alt+100, 0)
terrain_wait_path(self.homeloc, rally_loc, 10) terrain_wait_path(homeloc, rally_loc, 10)
# set a rally point to the west of home # set a rally point to the west of home
self.upload_rally_points_from_locations([rally_loc]) self.upload_rally_points_from_locations([rally_loc])
@ -1999,20 +1892,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def fly_ahrs2_test(self): def fly_ahrs2_test(self):
'''check secondary estimator is looking OK''' '''check secondary estimator is looking OK'''
ahrs2 = self.mav.recv_match(type='AHRS2', blocking=True, timeout=1) ahrs2 = self.assert_receive_message('AHRS2', verbose=1)
if ahrs2 is None: gpi = self.assert_receive_message('GLOBAL_POSITION_INT', verbose=1)
raise NotAchievedException("Did not receive AHRS2 message")
self.progress("AHRS2: %s" % str(ahrs2))
# check location
gpi = self.mav.recv_match(
type='GLOBAL_POSITION_INT',
blocking=True,
timeout=5
)
if gpi is None:
raise NotAchievedException("Did not receive GLOBAL_POSITION_INT message")
self.progress("GPI: %s" % str(gpi))
if self.get_distance_int(gpi, ahrs2) > 10: if self.get_distance_int(gpi, ahrs2) > 10:
raise NotAchievedException("Secondary location looks bad") raise NotAchievedException("Secondary location looks bad")
@ -2025,10 +1906,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Asserting we do support transfer of fence via mission item protocol") self.progress("Asserting we do support transfer of fence via mission item protocol")
self.assert_capability(mavutil.mavlink.MAV_PROTOCOL_CAPABILITY_MISSION_FENCE) self.assert_capability(mavutil.mavlink.MAV_PROTOCOL_CAPABILITY_MISSION_FENCE)
# grab home position:
self.mav.recv_match(type='HOME_POSITION', blocking=True)
self.homeloc = self.mav.location()
self.run_subtest("Takeoff", self.takeoff) self.run_subtest("Takeoff", self.takeoff)
self.run_subtest("Set Attitude Target", self.set_attitude_target) self.run_subtest("Set Attitude Target", self.set_attitude_target)
@ -2322,9 +2199,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def RangeFinder(self): def RangeFinder(self):
'''Test RangeFinder Basic Functionality''' '''Test RangeFinder Basic Functionality'''
self.context_push()
self.progress("Making sure we don't ordinarily get RANGEFINDER") self.progress("Making sure we don't ordinarily get RANGEFINDER")
self.assert_not_receive_message('RANGEFDINDER') self.assert_not_receive_message('RANGEFINDER')
self.set_analog_rangefinder_parameters() self.set_analog_rangefinder_parameters()
@ -2338,12 +2214,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.arm_vehicle() self.arm_vehicle()
self.wait_waypoint(5, 5, max_dist=100) self.wait_waypoint(5, 5, max_dist=100)
rf = self.mav.recv_match(type="RANGEFINDER", timeout=1, blocking=True) rf = self.assert_receive_message('RANGEFINDER')
if rf is None: gpi = self.assert_receive_message('GLOBAL_POSITION_INT')
raise NotAchievedException("Did not receive rangefinder message")
gpi = self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True, timeout=1)
if gpi is None:
raise NotAchievedException("Did not receive GLOBAL_POSITION_INT message")
if abs(rf.distance - gpi.relative_alt/1000.0) > 3: if abs(rf.distance - gpi.relative_alt/1000.0) > 3:
raise NotAchievedException( raise NotAchievedException(
"rangefinder alt (%s) disagrees with global-position-int.relative_alt (%s)" % "rangefinder alt (%s) disagrees with global-position-int.relative_alt (%s)" %
@ -2354,9 +2226,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
if not self.current_onboard_log_contains_message("RFND"): if not self.current_onboard_log_contains_message("RFND"):
raise NotAchievedException("No RFND messages in log") raise NotAchievedException("No RFND messages in log")
self.context_pop()
self.reboot_sitl()
def rc_defaults(self): def rc_defaults(self):
ret = super(AutoTestPlane, self).rc_defaults() ret = super(AutoTestPlane, self).rc_defaults()
ret[3] = 1000 ret[3] = 1000
@ -2429,12 +2298,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.reboot_sitl() self.reboot_sitl()
self.assert_receive_message('ADSB_VEHICLE', timeout=30) self.assert_receive_message('ADSB_VEHICLE', timeout=30)
def ADSB(self): def ADSBResumeActionResumeLoiter(self):
'''Test ADSB'''
self.ADSB_f_action_rtl()
self.ADSB_r_action_resume_or_loiter()
def ADSB_r_action_resume_or_loiter(self):
'''ensure we resume auto mission or enter loiter''' '''ensure we resume auto mission or enter loiter'''
self.set_parameters({ self.set_parameters({
"ADSB_TYPE": 1, "ADSB_TYPE": 1,
@ -2472,10 +2336,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.fly_home_land_and_disarm() self.fly_home_land_and_disarm()
def ADSB_f_action_rtl(self): def ADSBFailActionRTL(self):
self.context_push() '''test ADSB avoidance action of RTL'''
ex = None
try:
# message ADSB_VEHICLE 37 -353632614 1491652305 0 584070 0 0 0 "bob" 3 1 255 17 # message ADSB_VEHICLE 37 -353632614 1491652305 0 584070 0 0 0 "bob" 3 1 255 17
self.set_parameter("RC12_OPTION", 38) # avoid-adsb self.set_parameter("RC12_OPTION", 38) # avoid-adsb
self.set_rc(12, 2000) self.set_rc(12, 2000)
@ -2527,14 +2389,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
if m is not None: if m is not None:
raise NotAchievedException("Got collision message when I shouldn't have") raise NotAchievedException("Got collision message when I shouldn't have")
except Exception as e:
self.print_exception_caught(e)
ex = e
self.context_pop()
self.reboot_sitl()
if ex is not None:
raise ex
def GuidedRequest(self, target_system=1, target_component=1): def GuidedRequest(self, target_system=1, target_component=1):
'''Test handling of MISSION_ITEM in guided mode''' '''Test handling of MISSION_ITEM in guided mode'''
self.progress("Takeoff") self.progress("Takeoff")
@ -2634,9 +2488,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
now = self.get_sim_time_cached() now = self.get_sim_time_cached()
if now - tstart > 60: if now - tstart > 60:
break break
m = self.mav.recv_match(type='VFR_HUD', blocking=True, timeout=5) m = self.assert_receive_message('VFR_HUD')
if m is None:
raise NotAchievedException("Did not get VFR_HUD")
new_throttle = m.throttle new_throttle = m.throttle
alt = m.alt alt = m.alt
m = self.assert_receive_message('ATTITUDE', timeout=5) m = self.assert_receive_message('ATTITUDE', timeout=5)
@ -3463,9 +3315,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
def EKFlaneswitch(self): def EKFlaneswitch(self):
'''Test EKF3 Affinity and Lane Switching''' '''Test EKF3 Affinity and Lane Switching'''
self.context_push()
ex = None
# new lane swtich available only with EK3 # new lane swtich available only with EK3
self.set_parameters({ self.set_parameters({
"EK3_ENABLE": 1, "EK3_ENABLE": 1,
@ -3496,13 +3345,12 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
return return
newlane = int(message.text[-1]) newlane = int(message.text[-1])
self.lane_switches.append(newlane) self.lane_switches.append(newlane)
self.install_message_hook(statustext_hook) self.install_message_hook_context(statustext_hook)
# get flying # get flying
self.takeoff(alt=50) self.takeoff(alt=50)
self.change_mode('CIRCLE') self.change_mode('CIRCLE')
try:
################################################################### ###################################################################
self.progress("Checking EKF3 Lane Switching trigger from all sensors") self.progress("Checking EKF3 Lane Switching trigger from all sensors")
################################################################### ###################################################################
@ -3638,23 +3486,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.disarm_vehicle(force=True) self.disarm_vehicle(force=True)
except Exception as e:
self.print_exception_caught(e)
ex = e
self.remove_message_hook(statustext_hook)
self.context_pop()
# some parameters need reboot to take effect
self.reboot_sitl()
if ex is not None:
raise ex
def FenceAltCeilFloor(self): def FenceAltCeilFloor(self):
'''Tests the fence ceiling and floor''' '''Tests the fence ceiling and floor'''
fence_bit = mavutil.mavlink.MAV_SYS_STATUS_GEOFENCE
self.set_parameters({ self.set_parameters({
"FENCE_TYPE": 9, # Set fence type to max and min alt "FENCE_TYPE": 9, # Set fence type to max and min alt
"FENCE_ACTION": 0, # Set action to report "FENCE_ACTION": 0, # Set action to report
@ -3663,36 +3496,32 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
}) })
# Grab Home Position # Grab Home Position
self.mav.recv_match(type='HOME_POSITION', blocking=True) self.wait_ready_to_arm()
self.homeloc = self.mav.location() startpos = self.mav.location()
cruise_alt = 150 cruise_alt = 150
self.takeoff(cruise_alt) self.takeoff(cruise_alt)
# note that while we enable the fence here, since the action
# is set to report-only the fence continues to show as
# not-enabled in the assert calls below
self.do_fence_enable() self.do_fence_enable()
self.progress("Fly above ceiling and check for breach") self.progress("Fly above ceiling and check for breach")
self.change_altitude(self.homeloc.alt + cruise_alt + 80) self.change_altitude(startpos.alt + cruise_alt + 80)
m = self.mav.recv_match(type='SYS_STATUS', blocking=True) self.assert_fence_sys_status(True, False, False)
self.progress("Got (%s)" % str(m))
if ((m.onboard_control_sensors_health & fence_bit)):
raise NotAchievedException("Fence Ceiling did not breach")
self.progress("Return to cruise alt and check for breach clear") self.progress("Return to cruise alt")
self.change_altitude(self.homeloc.alt + cruise_alt) self.change_altitude(startpos.alt + cruise_alt)
m = self.mav.recv_match(type='SYS_STATUS', blocking=True) self.progress("Ensure breach has clearned")
self.progress("Got (%s)" % str(m)) self.assert_fence_sys_status(True, False, True)
if (not (m.onboard_control_sensors_health & fence_bit)):
raise NotAchievedException("Fence breach did not clear")
self.progress("Fly below floor and check for breach") self.progress("Fly below floor and check for breach")
self.change_altitude(self.homeloc.alt + cruise_alt - 80) self.change_altitude(startpos.alt + cruise_alt - 80)
m = self.mav.recv_match(type='SYS_STATUS', blocking=True) self.progress("Ensure breach has clearned")
self.progress("Got (%s)" % str(m)) self.assert_fence_sys_status(True, False, False)
if ((m.onboard_control_sensors_health & fence_bit)):
raise NotAchievedException("Fence Floor did not breach")
self.do_fence_disable() self.do_fence_disable()
@ -3713,9 +3542,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
# check we can takeoff again # check we can takeoff again
for i in [1, 2]: for i in [1, 2]:
# Grab Home Position # Grab Home Position
self.mav.recv_match(type='HOME_POSITION', blocking=True)
self.homeloc = self.mav.location()
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.arm_vehicle() self.arm_vehicle()
# max alt fence should now be enabled # max alt fence should now be enabled
@ -3754,9 +3580,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
}) })
# Grab Home Position # Grab Home Position
self.mav.recv_match(type='HOME_POSITION', blocking=True)
self.homeloc = self.mav.location()
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.arm_vehicle() self.arm_vehicle()
@ -3781,9 +3604,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.set_rc(3, 1000) # lower throttle self.set_rc(3, 1000) # lower throttle
# Now check we can land # Now check we can land
self.fly_home_land_and_disarm() self.fly_home_land_and_disarm()
self.clear_mission(mavutil.mavlink.MAV_MISSION_TYPE_ALL)
self.set_current_waypoint(0, check_afterwards=False)
self.set_rc(3, 1000) # lower throttle
def FenceMinAltAutoEnableAbort(self): def FenceMinAltAutoEnableAbort(self):
'''Tests autoenablement of the alt min fence and fences on arming''' '''Tests autoenablement of the alt min fence and fences on arming'''
@ -3797,10 +3617,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
"RTL_AUTOLAND" : 2, "RTL_AUTOLAND" : 2,
}) })
# Grab Home Position
self.mav.recv_match(type='HOME_POSITION', blocking=True)
self.homeloc = self.mav.location()
self.wait_ready_to_arm() self.wait_ready_to_arm()
self.arm_vehicle() self.arm_vehicle()
@ -3837,7 +3653,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.change_mode("AUTO") self.change_mode("AUTO")
self.clear_mission(mavutil.mavlink.MAV_MISSION_TYPE_ALL) self.clear_mission(mavutil.mavlink.MAV_MISSION_TYPE_ALL)
self.fly_home_land_and_disarm(timeout=150) self.fly_home_land_and_disarm(timeout=150)
self.wait_disarmed()
def FenceAutoEnableDisableSwitch(self): def FenceAutoEnableDisableSwitch(self):
'''Tests autoenablement of regular fences and manual disablement''' '''Tests autoenablement of regular fences and manual disablement'''
@ -3859,7 +3674,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
fence_bit = mavutil.mavlink.MAV_SYS_STATUS_GEOFENCE fence_bit = mavutil.mavlink.MAV_SYS_STATUS_GEOFENCE
# Grab Home Position # Grab Home Position
self.mav.recv_match(type='HOME_POSITION', blocking=True) self.mav.recv_match(type='HOME_POSITION', blocking=True)
self.homeloc = self.mav.location()
self.set_rc_from_map({7: 1000}) # Turn fence off with aux function self.set_rc_from_map({7: 1000}) # Turn fence off with aux function
self.wait_ready_to_arm() self.wait_ready_to_arm()
@ -3868,7 +3682,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Fly above ceiling and check there is no breach") self.progress("Fly above ceiling and check there is no breach")
self.set_rc(3, 2000) self.set_rc(3, 2000)
self.change_altitude(self.homeloc.alt + cruise_alt + 80) self.change_altitude(cruise_alt + 80, relative=True)
m = self.mav.recv_match(type='SYS_STATUS', blocking=True) m = self.mav.recv_match(type='SYS_STATUS', blocking=True)
self.progress("Got (%s)" % str(m)) self.progress("Got (%s)" % str(m))
if (not (m.onboard_control_sensors_health & fence_bit)): if (not (m.onboard_control_sensors_health & fence_bit)):
@ -3876,10 +3690,10 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Return to cruise alt") self.progress("Return to cruise alt")
self.set_rc(3, 1500) self.set_rc(3, 1500)
self.change_altitude(self.homeloc.alt + cruise_alt) self.change_altitude(cruise_alt, relative=True)
self.progress("Fly below floor and check for no breach") self.progress("Fly below floor and check for no breach")
self.change_altitude(self.homeloc.alt + 25) self.change_altitude(25, relative=True)
m = self.mav.recv_match(type='SYS_STATUS', blocking=True) m = self.mav.recv_match(type='SYS_STATUS', blocking=True)
self.progress("Got (%s)" % str(m)) self.progress("Got (%s)" % str(m))
if (not (m.onboard_control_sensors_health & fence_bit)): if (not (m.onboard_control_sensors_health & fence_bit)):
@ -3887,7 +3701,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Fly above floor and check fence is not re-enabled") self.progress("Fly above floor and check fence is not re-enabled")
self.set_rc(3, 2000) self.set_rc(3, 2000)
self.change_altitude(self.homeloc.alt + 75) self.change_altitude(75, relative=True)
m = self.mav.recv_match(type='SYS_STATUS', blocking=True) m = self.mav.recv_match(type='SYS_STATUS', blocking=True)
self.progress("Got (%s)" % str(m)) self.progress("Got (%s)" % str(m))
if (m.onboard_control_sensors_enabled & fence_bit): if (m.onboard_control_sensors_enabled & fence_bit):
@ -3895,7 +3709,7 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.progress("Return to cruise alt") self.progress("Return to cruise alt")
self.set_rc(3, 1500) self.set_rc(3, 1500)
self.change_altitude(self.homeloc.alt + cruise_alt) self.change_altitude(cruise_alt, relative=True)
self.fly_home_land_and_disarm(timeout=250) self.fly_home_land_and_disarm(timeout=250)
def FenceCircleExclusionAutoEnable(self): def FenceCircleExclusionAutoEnable(self):
@ -3908,10 +3722,6 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
"RTL_AUTOLAND" : 2, "RTL_AUTOLAND" : 2,
}) })
# Grab Home Position
self.mav.recv_match(type='HOME_POSITION', blocking=True)
self.homeloc = self.mav.location()
fence_loc = self.home_position_as_mav_location() fence_loc = self.home_position_as_mav_location()
self.location_offset_ne(fence_loc, 300, 0) self.location_offset_ne(fence_loc, 300, 0)
@ -3922,23 +3732,12 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
} }
)]) )])
self.wait_ready_to_arm()
self.arm_vehicle()
self.takeoff(alt=50, mode='TAKEOFF') self.takeoff(alt=50, mode='TAKEOFF')
self.change_mode("FBWA") self.change_mode("FBWA")
self.set_rc(3, 1100) # lower throttle self.set_rc(3, 1100) # lower throttle
self.progress("Waiting for RTL") self.progress("Waiting for RTL")
tstart = self.get_sim_time() self.wait_mode('RTL')
mode = "RTL"
while not self.mode_is(mode, drain_mav=False):
self.mav.messages['HEARTBEAT'].custom_mode
self.progress("mav.flightmode=%s Want=%s Alt=%f" % (
self.mav.flightmode, mode, self.get_altitude(relative=True)))
if (self.get_sim_time_cached() > tstart + 120):
raise WaitModeTimeout("Did not change mode")
self.progress("Got mode %s" % mode)
# Now check we can land # Now check we can land
self.fly_home_land_and_disarm() self.fly_home_land_and_disarm()
@ -5873,7 +5672,8 @@ class AutoTestPlane(vehicle_test_suite.TestSuite):
self.FenceNoFenceReturnPoint, self.FenceNoFenceReturnPoint,
self.FenceNoFenceReturnPointInclusion, self.FenceNoFenceReturnPointInclusion,
self.FenceDisableUnderAction, self.FenceDisableUnderAction,
self.ADSB, self.ADSBFailActionRTL,
self.ADSBResumeActionResumeLoiter,
self.SimADSB, self.SimADSB,
self.Button, self.Button,
self.FRSkySPort, self.FRSkySPort,