From b896b3ed9d952a48c8cf177b05217e567b300724 Mon Sep 17 00:00:00 2001 From: Andy Piper Date: Wed, 11 Dec 2024 09:40:04 +0000 Subject: [PATCH] autotest: test for fence margin warnings --- Tools/autotest/arducopter.py | 88 ++++++++++++++++++++++++++++++++++++ 1 file changed, 88 insertions(+) diff --git a/Tools/autotest/arducopter.py b/Tools/autotest/arducopter.py index fe808916d4..c01872a24e 100644 --- a/Tools/autotest/arducopter.py +++ b/Tools/autotest/arducopter.py @@ -1908,6 +1908,93 @@ class AutoTestCopter(vehicle_test_suite.TestSuite): # Disable the fence using mavlink command to ensure cleaned up SITL state self.assert_fence_disabled() + def FenceMargin(self, timeout=180): + '''Test warning on crossing fence margin''' + # enable fence, disable avoidance + self.set_parameters({ + "FENCE_ENABLE": 1, + "FENCE_TYPE": 6, # polygon and circle fences + "FENCE_MARGIN" : 20, + "FENCE_RADIUS" : 150, + "AVOID_ENABLE": 0, + "FENCE_OPTIONS": 4 + }) + + self.change_mode("LOITER") + self.wait_ready_to_arm() + + # fence requires home to be set: + m = self.poll_home_position(quiet=False) + + ## 110m polyfence + home_loc = self.mav.location() + locs = [ + mavutil.location(home_loc.lat - 0.0013, home_loc.lng - 0.0013, 0, 0), + mavutil.location(home_loc.lat - 0.0013, home_loc.lng + 0.0013, 0, 0), + mavutil.location(home_loc.lat + 0.0013, home_loc.lng + 0.0013, 0, 0), + mavutil.location(home_loc.lat + 0.0013, home_loc.lng - 0.0013, 0, 0), + ] + self.upload_fences_from_locations([ + (mavutil.mavlink.MAV_CMD_NAV_FENCE_POLYGON_VERTEX_INCLUSION, locs), + ]) + + self.takeoff(10, mode="LOITER") + + # first east + self.progress("turn east") + self.set_rc(4, 1580) + self.wait_heading(160, timeout=60) + self.set_rc(4, 1500) + + fence_radius = self.get_parameter("FENCE_RADIUS") + + self.progress("flying forward (east) until we hit fence") + pitching_forward = True + self.set_rc(2, 1100) + + self.wait_statustext("Circle fence outside margin") + self.progress("Waiting for fence breach") + tstart = self.get_sim_time() + while not self.mode_is("RTL"): + if self.get_sim_time_cached() - tstart > 30: + raise NotAchievedException("Did not breach fence") + + m = self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True) + alt = m.relative_alt / 1000.0 # mm -> m + home_distance = self.distance_to_home(use_cached_home=True) + self.progress("Alt: %.02f HomeDistance: %.02f (fence radius=%f)" % + (alt, home_distance, fence_radius)) + + self.wait_statustext("Circle fence inside margin") + self.progress("Waiting until we get home and disarm") + tstart = self.get_sim_time() + while self.get_sim_time_cached() < tstart + timeout: + m = self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True) + alt = m.relative_alt / 1000.0 # mm -> m + home_distance = self.distance_to_home(use_cached_home=True) + self.progress("Alt: %.02f HomeDistance: %.02f" % + (alt, home_distance)) + # recenter pitch sticks once we're home so we don't fly off again + if pitching_forward and home_distance < 50: + pitching_forward = False + self.set_rc(2, 1475) + # disable fence + self.set_parameter("FENCE_ENABLE", 0) + if (alt <= 1 and home_distance < 10) or (not self.armed() and home_distance < 10): + # reduce throttle + self.zero_throttle() + self.change_mode("LAND") + self.wait_landed_and_disarmed() + self.progress("Reached home OK") + self.zero_throttle() + return + + # give we're testing RTL, doing one here probably doesn't make sense + home_distance = self.distance_to_home(use_cached_home=True) + raise AutoTestTimeoutException( + "Fence test failed to reach home (%fm distance) - " + "timed out after %u seconds" % (home_distance, timeout,)) + def GPSGlitchLoiter(self, timeout=30, max_distance=20): """fly_gps_glitch_loiter_test. Fly south east in loiter and test reaction to gps glitch.""" @@ -10806,6 +10893,7 @@ class AutoTestCopter(vehicle_test_suite.TestSuite): self.FenceFloorEnabledLanding, self.FenceFloorAutoDisableLanding, self.FenceFloorAutoEnableOnArming, + self.FenceMargin, self.AutoTuneSwitch, self.GPSGlitchLoiter, self.GPSGlitchLoiter2,