mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
autotest: add simple test for IE24 generator
Tools: Modified richenpower autotest setup autotest: IE24: Add error code failsafe test
This commit is contained in:
parent
c52298352a
commit
b788a172c8
@ -5101,6 +5101,8 @@ class AutoTestCopter(AutoTest):
|
|||||||
self.set_parameter("RC9_OPTION", 85)
|
self.set_parameter("RC9_OPTION", 85)
|
||||||
self.set_parameter("LOG_DISARMED", 1)
|
self.set_parameter("LOG_DISARMED", 1)
|
||||||
self.set_parameter("BATT2_MONITOR", 17)
|
self.set_parameter("BATT2_MONITOR", 17)
|
||||||
|
self.set_parameter("GEN_TYPE", 3)
|
||||||
|
self.reboot_sitl()
|
||||||
self.set_rc(9, 1000) # remember this is a switch position - stop
|
self.set_rc(9, 1000) # remember this is a switch position - stop
|
||||||
self.customise_SITL_commandline(["--uartF=sim:richenpower"])
|
self.customise_SITL_commandline(["--uartF=sim:richenpower"])
|
||||||
self.mavproxy.expect("requested state is not RUN")
|
self.mavproxy.expect("requested state is not RUN")
|
||||||
@ -5159,6 +5161,50 @@ class AutoTestCopter(AutoTest):
|
|||||||
if not self.current_onboard_log_contains_message("GEN"):
|
if not self.current_onboard_log_contains_message("GEN"):
|
||||||
raise NotAchievedException("Did not find expected GEN message")
|
raise NotAchievedException("Did not find expected GEN message")
|
||||||
|
|
||||||
|
def test_ie24(self):
|
||||||
|
self.context_push()
|
||||||
|
ex = None
|
||||||
|
try:
|
||||||
|
self.set_parameter("SERIAL5_PROTOCOL", 30)
|
||||||
|
self.set_parameter("SERIAL5_BAUD", 115200)
|
||||||
|
self.set_parameter("GEN_TYPE", 2)
|
||||||
|
self.set_parameter("BATT2_MONITOR", 17)
|
||||||
|
self.set_parameter("SIM_IE24_ENABLE", 1)
|
||||||
|
self.set_parameter("LOG_DISARMED", 1)
|
||||||
|
|
||||||
|
self.customise_SITL_commandline(["--uartF=sim:ie24"])
|
||||||
|
self.wait_ready_to_arm()
|
||||||
|
self.arm_vehicle()
|
||||||
|
self.disarm_vehicle()
|
||||||
|
|
||||||
|
# Test for pre-arm check fail when state is not running
|
||||||
|
self.start_subtest("If you haven't taken off generator error should cause instant failsafe and disarm")
|
||||||
|
self.set_parameter("SIM_IE24_STATE", 8)
|
||||||
|
self.wait_statustext("Status not running")
|
||||||
|
self.try_arm(result=False,
|
||||||
|
expect_msg="Status not running")
|
||||||
|
self.set_parameter("SIM_IE24_STATE", 2) # Explicitly set state to running
|
||||||
|
|
||||||
|
# Test that error code does result in failsafe
|
||||||
|
self.start_subtest("If you haven't taken off generator error should cause instant failsafe and disarm")
|
||||||
|
self.change_mode("STABILIZE")
|
||||||
|
self.set_parameter("DISARM_DELAY", 0)
|
||||||
|
self.arm_vehicle()
|
||||||
|
self.set_parameter("SIM_IE24_ERROR", 30)
|
||||||
|
self.disarm_wait(timeout=1)
|
||||||
|
self.set_parameter("SIM_IE24_ERROR", 0)
|
||||||
|
self.set_parameter("DISARM_DELAY", 10)
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
self.progress("Exception caught: %s" % (
|
||||||
|
self.get_exception_stacktrace(e)))
|
||||||
|
ex = e
|
||||||
|
|
||||||
|
self.context_pop()
|
||||||
|
|
||||||
|
if ex is not None:
|
||||||
|
raise ex
|
||||||
|
|
||||||
def get_mission_count(self):
|
def get_mission_count(self):
|
||||||
return self.get_parameter("MIS_TOTAL")
|
return self.get_parameter("MIS_TOTAL")
|
||||||
|
|
||||||
@ -5724,6 +5770,10 @@ class AutoTestCopter(AutoTest):
|
|||||||
"Test RichenPower generator",
|
"Test RichenPower generator",
|
||||||
self.test_richenpower),
|
self.test_richenpower),
|
||||||
|
|
||||||
|
("IE24",
|
||||||
|
"Test IntelligentEnergy 2.4kWh generator",
|
||||||
|
self.test_ie24),
|
||||||
|
|
||||||
("LogUpload",
|
("LogUpload",
|
||||||
"Log upload",
|
"Log upload",
|
||||||
self.log_upload),
|
self.log_upload),
|
||||||
|
Loading…
Reference in New Issue
Block a user