From f30bca01c9255120e287d3bb5c05a97e64e38a20 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sun, 27 Nov 2011 18:52:54 -0800 Subject: [PATCH] autotest: use idle_hooks to prevent lockup --- Tools/autotest/arducopter.py | 1 + Tools/autotest/common.py | 12 ++++++++---- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/Tools/autotest/arducopter.py b/Tools/autotest/arducopter.py index 92683fe8a7..82f281e153 100644 --- a/Tools/autotest/arducopter.py +++ b/Tools/autotest/arducopter.py @@ -286,6 +286,7 @@ def fly_ArduCopter(viewerip=None): print("Failed to start mavlink connection on 127.0.0.1:19550" % msg) raise mav.message_hooks.append(message_hook) + mav.idle_hooks.append(idle_hook) failed = False diff --git a/Tools/autotest/common.py b/Tools/autotest/common.py index c89be9282c..3e7808489b 100644 --- a/Tools/autotest/common.py +++ b/Tools/autotest/common.py @@ -4,17 +4,21 @@ import util, pexpect, time, math # messages. This keeps the output to stdout flowing expect_list = [] -def message_hook(mav, msg): - '''called as each mavlink msg is received''' +def idle_hook(mav): + '''called when waiting for a mavlink message''' global expect_list -# if msg.get_type() in [ 'NAV_CONTROLLER_OUTPUT', 'GPS_RAW' ]: -# print(msg) for p in expect_list: try: p.read_nonblocking(100, timeout=0) except pexpect.TIMEOUT: pass +def message_hook(mav, msg): + '''called as each mavlink msg is received''' +# if msg.get_type() in [ 'NAV_CONTROLLER_OUTPUT', 'GPS_RAW' ]: +# print(msg) + idle_hook(mav) + def expect_callback(e): '''called when waiting for a expect pattern''' global expect_list