autotest: test mag fusion

This commit is contained in:
Clyde McQueen 2024-07-24 10:14:32 -07:00 committed by Peter Barker
parent 872cbc72ff
commit cbef094435

View File

@ -36,6 +36,22 @@ class Joystick():
Lateral = 6 Lateral = 6
# Values for EK3_MAG_CAL
class MagCal():
WHEN_FLYING = 0
WHEN_MANOEUVRING = 1
NEVER = 2
AFTER_FIRST_CLIMB = 3
ALWAYS = 4
# Values for XKFS.MAG_FUSION
class MagFuseSel():
NOT_FUSING = 0
FUSE_YAW = 1
FUSE_MAG = 2
class AutoTestSub(vehicle_test_suite.TestSuite): class AutoTestSub(vehicle_test_suite.TestSuite):
@staticmethod @staticmethod
def get_not_armable_mode_list(): def get_not_armable_mode_list():
@ -850,7 +866,7 @@ class AutoTestSub(vehicle_test_suite.TestSuite):
# restart GPS driver # restart GPS driver
self.reboot_sitl() self.reboot_sitl()
def backup_home(self): def backup_origin(self):
"""Test ORIGIN_LAT and ORIGIN_LON parameters""" """Test ORIGIN_LAT and ORIGIN_LON parameters"""
self.context_push() self.context_push()
@ -881,6 +897,55 @@ class AutoTestSub(vehicle_test_suite.TestSuite):
self.disarm_vehicle() self.disarm_vehicle()
self.context_pop() self.context_pop()
def assert_mag_fusion_selection(self, expect_sel):
"""Get the most recent XKFS message and check the MAG_FUSION value"""
self.progress("Expect mag fusion selection %d" % expect_sel)
mlog = self.dfreader_for_current_onboard_log()
found_sel = MagFuseSel.NOT_FUSING
while True:
m = mlog.recv_match(type='XKFS')
if m is None:
break
found_sel = m.MAG_FUSION
if found_sel != expect_sel:
raise NotAchievedException("Expected mag fusion selection %d, found %d" % (expect_sel, found_sel))
def fuse_mag(self):
"""Test EK3_MAG_CAL values"""
# WHEN_FLYING: switch to FUSE_MAG after sub is armed for 5 seconds; switch to FUSE_YAW on disarm
self.set_parameters({'EK3_MAG_CAL': MagCal.WHEN_FLYING})
self.reboot_sitl()
self.wait_ready_to_arm()
self.assert_mag_fusion_selection(MagFuseSel.FUSE_YAW)
self.arm_vehicle()
self.delay_sim_time(10)
self.assert_mag_fusion_selection(MagFuseSel.FUSE_MAG)
self.disarm_vehicle()
self.delay_sim_time(1)
self.assert_mag_fusion_selection(MagFuseSel.FUSE_YAW)
# AFTER_FIRST_CLIMB: switch to FUSE_MAG after sub is armed and descends 0.5m; switch to FUSE_YAW on disarm
self.set_parameters({'EK3_MAG_CAL': MagCal.AFTER_FIRST_CLIMB})
self.reboot_sitl()
self.wait_ready_to_arm()
self.assert_mag_fusion_selection(MagFuseSel.FUSE_YAW)
altitude = self.get_altitude(relative=True)
self.arm_vehicle()
self.set_rc(Joystick.Throttle, 1300)
self.wait_altitude(altitude_min=altitude-4, altitude_max=altitude-3, relative=False, timeout=60)
self.set_rc(Joystick.Throttle, 1500)
self.assert_mag_fusion_selection(MagFuseSel.FUSE_MAG)
self.disarm_vehicle()
self.delay_sim_time(1)
self.assert_mag_fusion_selection(MagFuseSel.FUSE_YAW)
# ALWAYS
self.set_parameters({'EK3_MAG_CAL': MagCal.ALWAYS})
self.reboot_sitl()
self.wait_ready_to_arm()
self.assert_mag_fusion_selection(MagFuseSel.FUSE_MAG)
def tests(self): def tests(self):
'''return list of all tests''' '''return list of all tests'''
ret = super(AutoTestSub, self).tests() ret = super(AutoTestSub, self).tests()
@ -909,7 +974,8 @@ class AutoTestSub(vehicle_test_suite.TestSuite):
self.MAV_CMD_DO_REPOSITION, self.MAV_CMD_DO_REPOSITION,
self.TerrainMission, self.TerrainMission,
self.SetGlobalOrigin, self.SetGlobalOrigin,
self.backup_home, self.backup_origin,
self.fuse_mag,
]) ])
return ret return ret