gst-validate-launcher: Stop in --gdb by default, add --gdb-non-stop

This patch modifies the default behavior of --gdb to not run and quit
automatically the test, but rather wait for user input. This is
usually much more convenient to debug all kinds of bugs.

The automatic run behavior has been moved to a new command switch:
--gdb-non-stop

https://bugzilla.gnome.org/show_bug.cgi?id=796389
This commit is contained in:
Alicia Boya García 2018-05-24 18:25:59 +02:00 committed by Thibault Saunier
parent 683b19895e
commit 2c32ccd7a7
2 changed files with 11 additions and 1 deletions

View file

@ -385,7 +385,11 @@ class Test(Loggable):
if self.hard_timeout is not None: if self.hard_timeout is not None:
self.hard_timeout *= GDB_TIMEOUT_FACTOR self.hard_timeout *= GDB_TIMEOUT_FACTOR
self.timeout *= GDB_TIMEOUT_FACTOR self.timeout *= GDB_TIMEOUT_FACTOR
return ["gdb", "-ex", "run", "-ex", "backtrace", "-ex", "quit", "--args"] + command args = ["gdb"]
if self.options.gdb_non_stop:
args += ["-ex", "run", "-ex", "backtrace", "-ex", "quit"]
args += ["--args"] + command
return args
def use_valgrind(self, command, subenv): def use_valgrind(self, command, subenv):
vglogsfile = self.logfile + '.valgrind' vglogsfile = self.logfile + '.valgrind'

View file

@ -237,6 +237,9 @@ class LauncherConfig(Loggable):
else: else:
self.output_dir = os.path.abspath(self.output_dir) self.output_dir = os.path.abspath(self.output_dir)
if self.gdb_non_stop:
self.gdb = True
if self.gdb: if self.gdb:
self.logsdir = "stdout" self.logsdir = "stdout"
self.debug = True self.debug = True
@ -457,6 +460,9 @@ Note that all testsuite should be inside python modules, so the directory should
action="store_true", action="store_true",
help="Run the tests inside gdb (implies" help="Run the tests inside gdb (implies"
" --output-dir=stdout and --jobs=1)") " --output-dir=stdout and --jobs=1)")
parser.add_argument("--gdb-non-stop", dest="gdb_non_stop",
action="store_true",
help="Run the test automatically in gdb (implies --gdb)")
parser.add_argument("-nd", "--no-display", dest="no_display", parser.add_argument("-nd", "--no-display", dest="no_display",
action="store_true", action="store_true",
help="Run the tests without outputting graphics" help="Run the tests without outputting graphics"