summaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.base
diff options
context:
space:
mode:
authorAndrew Cagney <cagney@redhat.com>2003-11-23 01:09:19 +0000
committerAndrew Cagney <cagney@redhat.com>2003-11-23 01:09:19 +0000
commita20a5aa7be631a64193890631c5664b95580e4e7 (patch)
treed6bdd78cc4e9e96685739e91a1ec7ee2478e43cc /gdb/testsuite/gdb.base
parent65882b6ad257d352698610aa88fe1721e6ea2903 (diff)
downloadgdb-a20a5aa7be631a64193890631c5664b95580e4e7.tar.gz
2003-11-22 Andrew Cagney <cagney@redhat.com>
* lib/gdb.exp (gdb_test_multiple): Add simple example. * gdb.base/structs.exp: Use gdb_test_multiple.
Diffstat (limited to 'gdb/testsuite/gdb.base')
-rw-r--r--gdb/testsuite/gdb.base/structs.exp68
1 files changed, 5 insertions, 63 deletions
diff --git a/gdb/testsuite/gdb.base/structs.exp b/gdb/testsuite/gdb.base/structs.exp
index 0fbdc073890..7d399fd37ea 100644
--- a/gdb/testsuite/gdb.base/structs.exp
+++ b/gdb/testsuite/gdb.base/structs.exp
@@ -294,10 +294,9 @@ proc test_struct_returns { n } {
# "return_value_unknown", if non-empty, records why GDB realised
# that it didn't know where the return value was.
- send_gdb "return foo${n}\n"
set test "return foo<n>; ${tests}"
set return_value_unknown 0
- gdb_expect {
+ gdb_test_multiple "return foo${n}" "${test}" {
-re "The location" {
# Ulgh, a struct return, remember this (still need prompt).
set return_value_unknown 1
@@ -312,8 +311,7 @@ proc test_struct_returns { n } {
exp_continue
}
-re "Make fun${n} return now.*y or n. $" {
- send_gdb "y\n"
- gdb_expect {
+ gdb_test_multiple "y" "${test}" {
-re "L${n} *= fun${n}.*${gdb_prompt} $" {
# Need to step off the function call
gdb_test "next" "L.* *= fun.*" "${test}"
@@ -321,38 +319,17 @@ proc test_struct_returns { n } {
-re "L[expr ${n} + 1] *= fun[expr ${n} + 1].*${gdb_prompt} $" {
pass "${test}"
}
- -re "A problem internal to GDB has been detected" {
- fail "${test} (GDB internal error 2)"
- gdb_internal_error_resync
- }
- -re "${gdb_prompt} $" {
- fail "${test} (wrong line info)"
- }
- timeout {
- fail "${test} (timeout 2)"
- }
}
}
- -re "A problem internal to GDB has been detected" {
- fail "${test} (GDB internal error 1)"
- gdb_internal_error_resync
- }
- -re "${gdb_prompt} $" {
- fail "${test} (no query)"
- }
- timeout {
- fail "${test} (timeout 1)"
- }
}
# Check that the return-value is as expected. At this stage we're
# just checking that GDB has returned a value consistent with
# "return_value_unknown" set above.
- send_gdb "p/c L${n}\n"
set test "value foo<n> returned; ${tests}"
setup_kfails structs-*tld* i686-*-* gdb/1447
- gdb_expect {
+ gdb_test_multiple "p/c L${n}" "${test}" {
-re " = [foo ${n}].*${gdb_prompt} $" {
if $return_value_unknown {
# This contradicts the above claim that GDB didn't
@@ -375,17 +352,6 @@ proc test_struct_returns { n } {
fail "${test}"
}
}
- -re "A problem internal to GDB has been detected" {
- fail "${test} (GDB internal error)"
- gdb_internal_error_resync
- }
- -re "${gdb_prompt} $" {
- # Garbage returned, garbage printed
- fail "${test}"
- }
- timeout {
- fail "${test} (timeout)"
- }
}
# Check that a "finish" works.
@@ -409,10 +375,9 @@ proc test_struct_returns { n } {
# Finish the function, set 'finish_value_unknown" to non-empty if the
# return-value was not found.
- send_gdb "finish\n"
set test "finish foo<n>; ${tests}"
set finish_value_unknown 0
- gdb_expect {
+ gdb_test_multiple "finish" "${test}" {
-re "Value returned is .*${gdb_prompt} $" {
pass "${test}"
}
@@ -421,26 +386,14 @@ proc test_struct_returns { n } {
set finish_value_unknown 1
pass "${test}"
}
- -re "A problem internal to GDB has been detected" {
- fail "${test} (GDB internal error)"
- gdb_internal_error_resync
- }
- -re ".*${gdb_prompt} $" {
- # Garbage returned
- fail "${test}"
- }
- timeout {
- fail "${test} (timeout)"
- }
}
# Re-print the last (return-value) using the more robust
# "p/c". If no return value was found, the 'Z' from the previous
# check that the variable was cleared, is printed.
- send_gdb "p/c\n"
set test "value foo<n> finished; ${tests}"
setup_kfails structs-*tld* i686-*-* gdb/1447
- gdb_expect {
+ gdb_test_multiple "p/c" "${test}" {
-re "[foo ${n}]\[\r\n\]+${gdb_prompt} $" {
if $finish_value_unknown {
# This contradicts the above claim that GDB didn't
@@ -460,17 +413,6 @@ proc test_struct_returns { n } {
fail "${test}"
}
}
- -re "A problem internal to GDB has been detected" {
- fail "${test} (GDB internal error)"
- gdb_internal_error_resync
- }
- -re ".*${gdb_prompt} $" {
- # Garbage returned
- fail "${test}"
- }
- timeout {
- fail "${test} (timeout)"
- }
}
# Finally, check that "return" and finish" have consistent