autotest: get Valgrind closer-to-working
This gets us past the reboot problem for the most part, where Valgrind doesn't like you exec'ing
This commit is contained in:
parent
0db8745320
commit
58bdae1b52
@ -901,7 +901,7 @@ class AutoTestCopter(AutoTest):
|
|||||||
self.change_mode("RTL")
|
self.change_mode("RTL")
|
||||||
self.wait_rtl_complete()
|
self.wait_rtl_complete()
|
||||||
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
||||||
self.reboot_sitl_mavproxy()
|
self.reboot_sitl()
|
||||||
self.end_subtest("Completed Batt failsafe disabled test")
|
self.end_subtest("Completed Batt failsafe disabled test")
|
||||||
|
|
||||||
# TWO STAGE BATTERY FAILSAFE: Trigger low battery condition, then critical battery condition. Verify RTL and Land actions complete.
|
# TWO STAGE BATTERY FAILSAFE: Trigger low battery condition, then critical battery condition. Verify RTL and Land actions complete.
|
||||||
@ -921,7 +921,7 @@ class AutoTestCopter(AutoTest):
|
|||||||
self.wait_mode("LAND")
|
self.wait_mode("LAND")
|
||||||
self.wait_landed_and_disarmed()
|
self.wait_landed_and_disarmed()
|
||||||
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
||||||
self.reboot_sitl_mavproxy()
|
self.reboot_sitl()
|
||||||
self.end_subtest("Completed two stage battery failsafe test with RTL and Land")
|
self.end_subtest("Completed two stage battery failsafe test with RTL and Land")
|
||||||
|
|
||||||
# TWO STAGE BATTERY FAILSAFE: Trigger low battery condition, then critical battery condition. Verify both SmartRTL actions complete
|
# TWO STAGE BATTERY FAILSAFE: Trigger low battery condition, then critical battery condition. Verify both SmartRTL actions complete
|
||||||
@ -942,7 +942,7 @@ class AutoTestCopter(AutoTest):
|
|||||||
self.wait_mode("SMART_RTL")
|
self.wait_mode("SMART_RTL")
|
||||||
self.wait_disarmed()
|
self.wait_disarmed()
|
||||||
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
||||||
self.reboot_sitl_mavproxy()
|
self.reboot_sitl()
|
||||||
self.end_subtest("Completed two stage battery failsafe test with SmartRTL")
|
self.end_subtest("Completed two stage battery failsafe test with SmartRTL")
|
||||||
|
|
||||||
# Trigger low battery condition in land mode with FS_OPTIONS set to allow land mode to continue. Verify landing completes uninterupted.
|
# Trigger low battery condition in land mode with FS_OPTIONS set to allow land mode to continue. Verify landing completes uninterupted.
|
||||||
@ -957,7 +957,7 @@ class AutoTestCopter(AutoTest):
|
|||||||
self.wait_mode("LAND")
|
self.wait_mode("LAND")
|
||||||
self.wait_landed_and_disarmed()
|
self.wait_landed_and_disarmed()
|
||||||
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
||||||
self.reboot_sitl_mavproxy()
|
self.reboot_sitl()
|
||||||
self.end_subtest("Completed battery failsafe with FS_OPTIONS set to continue landing")
|
self.end_subtest("Completed battery failsafe with FS_OPTIONS set to continue landing")
|
||||||
|
|
||||||
# Trigger a critical battery condition, which triggers a land mode failsafe. Trigger an RC failure. Verify the RC failsafe is prevented from stopping the low battery landing.
|
# Trigger a critical battery condition, which triggers a land mode failsafe. Trigger an RC failure. Verify the RC failsafe is prevented from stopping the low battery landing.
|
||||||
@ -978,7 +978,7 @@ class AutoTestCopter(AutoTest):
|
|||||||
self.wait_landed_and_disarmed()
|
self.wait_landed_and_disarmed()
|
||||||
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
self.set_parameter('SIM_BATT_VOLTAGE', 12.5)
|
||||||
self.set_parameter("SIM_RC_FAIL", 0)
|
self.set_parameter("SIM_RC_FAIL", 0)
|
||||||
self.reboot_sitl_mavproxy()
|
self.reboot_sitl()
|
||||||
self.end_subtest("Completed battery failsafe critical landing")
|
self.end_subtest("Completed battery failsafe critical landing")
|
||||||
|
|
||||||
# Trigger low battery condition with failsafe set to terminate. Copter will disarm and crash.
|
# Trigger low battery condition with failsafe set to terminate. Copter will disarm and crash.
|
||||||
|
@ -1345,12 +1345,24 @@ class AutoTest(ABC):
|
|||||||
0,
|
0,
|
||||||
0)
|
0)
|
||||||
|
|
||||||
|
def reboot_check_valgrind_log(self):
|
||||||
|
valgrind_log = util.valgrind_log_filepath(binary=self.binary,
|
||||||
|
model=self.frame)
|
||||||
|
if os.path.getsize(valgrind_log) > 0:
|
||||||
|
backup_valgrind_log = ("%s-%s" % (str(int(time.time())), valgrind_log))
|
||||||
|
shutil.move(valgrind_log, backup_valgrind_log)
|
||||||
|
|
||||||
def reboot_sitl_mav(self, required_bootcount=None):
|
def reboot_sitl_mav(self, required_bootcount=None):
|
||||||
"""Reboot SITL instance using mavlink and wait for it to reconnect."""
|
"""Reboot SITL instance using mavlink and wait for it to reconnect."""
|
||||||
old_bootcount = self.get_parameter('STAT_BOOTCNT')
|
old_bootcount = self.get_parameter('STAT_BOOTCNT')
|
||||||
# ardupilot SITL may actually NAK the reboot; replace with
|
# ardupilot SITL may actually NAK the reboot; replace with
|
||||||
# run_cmd when we don't do that.
|
# run_cmd when we don't do that.
|
||||||
self.send_reboot_command()
|
if self.valgrind:
|
||||||
|
self.reboot_check_valgrind_log()
|
||||||
|
self.stop_SITL()
|
||||||
|
self.start_SITL(wipe=False)
|
||||||
|
else:
|
||||||
|
self.send_reboot_command()
|
||||||
self.detect_and_handle_reboot(old_bootcount, required_bootcount=required_bootcount)
|
self.detect_and_handle_reboot(old_bootcount, required_bootcount=required_bootcount)
|
||||||
|
|
||||||
def send_cmd_enter_cpu_lockup(self):
|
def send_cmd_enter_cpu_lockup(self):
|
||||||
@ -1893,11 +1905,15 @@ class AutoTest(ABC):
|
|||||||
|
|
||||||
valgrind_log = util.valgrind_log_filepath(binary=self.binary,
|
valgrind_log = util.valgrind_log_filepath(binary=self.binary,
|
||||||
model=self.frame)
|
model=self.frame)
|
||||||
if os.path.exists(valgrind_log):
|
files = glob.glob("*" + valgrind_log)
|
||||||
|
for valgrind_log in files:
|
||||||
os.chmod(valgrind_log, 0o644)
|
os.chmod(valgrind_log, 0o644)
|
||||||
shutil.copy(valgrind_log,
|
if os.path.getsize(valgrind_log) > 0:
|
||||||
self.buildlogs_path("%s-valgrind.log" %
|
target = self.buildlogs_path("%s-%s" % (
|
||||||
self.log_name()))
|
self.log_name(),
|
||||||
|
os.path.basename(valgrind_log)))
|
||||||
|
self.progress("Valgrind log: moving %s to %s" % (valgrind_log, target))
|
||||||
|
shutil.move(valgrind_log, target)
|
||||||
|
|
||||||
def start_test(self, description):
|
def start_test(self, description):
|
||||||
self.progress("##################################################################################")
|
self.progress("##################################################################################")
|
||||||
|
Loading…
Reference in New Issue
Block a user