From 1ecdab3a70339ca21adc3ca1a016c3c247259979 Mon Sep 17 00:00:00 2001 From: Roland Dobai Date: Thu, 22 Jul 2021 14:03:31 +0200 Subject: [PATCH] CI: Debug GDB issues --- .../panic/test_panic_util/test_panic_util.py | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/tools/test_apps/system/panic/test_panic_util/test_panic_util.py b/tools/test_apps/system/panic/test_panic_util/test_panic_util.py index 1acfa78dfc..4be900c520 100644 --- a/tools/test_apps/system/panic/test_panic_util/test_panic_util.py +++ b/tools/test_apps/system/panic/test_panic_util/test_panic_util.py @@ -5,7 +5,7 @@ import subprocess import sys import ttfw_idf -from pygdbmi.gdbcontroller import GdbController +from pygdbmi.gdbcontroller import GdbController, GdbTimeoutError, NoGdbProcessError from tiny_test_fw import DUT, TinyFW, Utility from tiny_test_fw.Utility import CaseConfig, SearchCases @@ -161,6 +161,23 @@ class PanicTestMixin(object): Utility.console_log('Starting GDB...', 'orange') self.gdb = GdbController(gdb_path=self.TOOLCHAIN_PREFIX + 'gdb') + Utility.console_log('Running command: {}'.format(self.gdb.get_subprocess_cmd()), 'orange') + + for _ in range(10): + try: + # GdbController creates a process with subprocess.Popen(). Is it really running? It is probable that + # an RPI under high load will get non-responsive during creating a lot of processes. + resp = self.gdb.get_gdb_response(timeout_sec=10) # calls verify_valid_gdb_subprocess() internally + # it will be interesting to look up this response if the next GDB command fails (times out) + Utility.console_log('GDB response: {}'.format(resp), 'orange') + break # success + except GdbTimeoutError: + Utility.console_log('GDB internal error: cannot get response from the subprocess', 'orange') + except NoGdbProcessError: + Utility.console_log('GDB internal error: process is not running', 'red') + break # failure - TODO: create another GdbController + except ValueError: + Utility.console_log('GDB internal error: select() returned an unexpected file number', 'red') # pygdbmi logs to console by default, make it log to a file instead log_folder = self.app.get_log_folder(TEST_SUITE)