autotest: validate context nesting

This commit is contained in:
Peter Barker 2020-07-06 10:41:16 +10:00 committed by Peter Barker
parent 98feb06183
commit 6c9d756f11
2 changed files with 20 additions and 2 deletions

View File

@ -206,7 +206,10 @@ class AutoTestSub(AutoTest):
self.progress("Mission OK") self.progress("Mission OK")
def test_gripper_mission(self): def test_gripper_mission(self):
self.context_push() with self.Context(self):
self.test_gripper_body()
def test_gripper_body(self):
ex = None ex = None
try: try:
try: try:
@ -225,7 +228,6 @@ class AutoTestSub(AutoTest):
except Exception as e: except Exception as e:
self.progress("Exception caught") self.progress("Exception caught")
ex = e ex = e
self.context_pop()
if ex is not None: if ex is not None:
raise ex raise ex

View File

@ -2858,6 +2858,15 @@ class AutoTest(ABC):
old_value, old_value,
add_to_context=False) add_to_context=False)
class Context(object):
def __init__(self, testsuite):
self.testsuite = testsuite
def __enter__(self):
self.testsuite.context_push()
def __exit__(self, type, value, traceback):
self.testsuite.context_pop()
return False # re-raise any exception
def sysid_thismav(self): def sysid_thismav(self):
return 1 return 1
@ -3842,6 +3851,7 @@ Also, ignores heartbeats not from our target system'''
self.send_statustext(prettyname) self.send_statustext(prettyname)
self.start_test(prettyname) self.start_test(prettyname)
self.set_current_test_name(name) self.set_current_test_name(name)
old_contexts_length = len(self.contexts)
self.context_push() self.context_push()
start_time = time.time() start_time = time.time()
@ -3883,6 +3893,11 @@ Also, ignores heartbeats not from our target system'''
self.progress('Corefiles detected: %s' % str(corefiles)) self.progress('Corefiles detected: %s' % str(corefiles))
passed = False passed = False
if len(self.contexts) != old_contexts_length:
self.progress("context count mismatch (want=%u got=%u)" %
(old_contexts_length, len(self.contexts)))
passed = False
if passed: if passed:
# self.remove_bin_logs() # can't do this as one of the binlogs is probably open for writing by the SITL process. If we force a rotate before running tests then we can do this. # self.remove_bin_logs() # can't do this as one of the binlogs is probably open for writing by the SITL process. If we force a rotate before running tests then we can do this.
pass pass
@ -5951,6 +5966,7 @@ switch value'''
except Exception as e: except Exception as e:
ex = e ex = e
self.mavproxy.send("fence disable\n") self.mavproxy.send("fence disable\n")
self.context_pop()
if ex is not None: if ex is not None:
raise ex raise ex