diff options
author | Pedro Alves <palves@redhat.com> | 2015-07-29 11:09:37 +0100 |
---|---|---|
committer | Pedro Alves <palves@redhat.com> | 2015-07-29 11:09:37 +0100 |
commit | 188a61b4404369ae30dce95ad4b05975a3609a33 (patch) | |
tree | ab9c24fc7591742604ac3326aab76796bb61917d /gdb/testsuite/lib | |
parent | 12264a451d993a0a8635be82bed15618e0f4645f (diff) | |
download | gdb-188a61b4404369ae30dce95ad4b05975a3609a33.zip gdb-188a61b4404369ae30dce95ad4b05975a3609a33.tar.gz gdb-188a61b4404369ae30dce95ad4b05975a3609a33.tar.bz2 |
Introduce gdb_test_stdio
This adds a new helper procedure to be used by tests that rely on
stdio.
gdb/testsuite/ChangeLog:
2015-07-29 Pedro Alves <palves@redhat.com>
* lib/gdb.exp (gdb_test_stdio): New procedure.
Diffstat (limited to 'gdb/testsuite/lib')
-rw-r--r-- | gdb/testsuite/lib/gdb.exp | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp index c5cfa4b..e3faf18 100644 --- a/gdb/testsuite/lib/gdb.exp +++ b/gdb/testsuite/lib/gdb.exp @@ -1230,6 +1230,73 @@ proc gdb_test_list_exact { cmd name elm_find_regexp elm_extract_regexp result_ma } } } + +# gdb_test_stdio COMMAND INFERIOR_PATTERN GDB_PATTERN MESSAGE +# Send a command to gdb; expect inferior and gdb output. +# +# See gdb_test_multiple for a description of the COMMAND and MESSAGE +# parameters. +# +# INFERIOR_PATTERN is the pattern to match against inferior output. +# +# GDB_PATTERN is the pattern to match against gdb output, and must NOT +# include the \r\n sequence immediately before the gdb prompt, nor the +# prompt. The default is empty. +# +# Both inferior and gdb patterns must match for a PASS. +# +# If MESSAGE is ommitted, then COMMAND will be used as the message. +# +# Returns: +# 1 if the test failed, +# 0 if the test passes, +# -1 if there was an internal error. +# + +proc gdb_test_stdio {command inferior_pattern {gdb_pattern ""} {message ""}} { + global inferior_spawn_id gdb_spawn_id + global gdb_prompt + + if {$message == ""} { + set message $command + } + + set inferior_matched 0 + set gdb_matched 0 + + # Use an indirect spawn id list, and remove the inferior spawn id + # from the expected output as soon as it matches, in case + # $inferior_pattern happens to be a prefix of the resulting full + # gdb pattern below (e.g., "\r\n"). + global gdb_test_stdio_spawn_id_list + set gdb_test_stdio_spawn_id_list "$inferior_spawn_id" + + # Note that if $inferior_spawn_id and $gdb_spawn_id are different, + # then we may see gdb's output arriving before the inferior's + # output. + set res [gdb_test_multiple $command $message { + -i gdb_test_stdio_spawn_id_list -re "$inferior_pattern" { + set inferior_matched 1 + if {!$gdb_matched} { + set gdb_test_stdio_spawn_id_list "" + exp_continue + } + } + -i $gdb_spawn_id -re "$gdb_pattern\r\n$gdb_prompt $" { + set gdb_matched 1 + if {!$inferior_matched} { + exp_continue + } + } + }] + if {$res == 0} { + pass $message + } else { + verbose -log "inferior_matched=$inferior_matched, gdb_matched=$gdb_matched" + } + return $res +} + # Issue a PASS and return true if evaluating CONDITION in the caller's |