mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-02-05 12:53:16 +08:00
gdb/testsuite: gdb.base/args.exp: use save_vars
Use save_vars instead of manually saving/restoring. This ensures that if anything throws an error, GDBFLAGS will be correctly restored. Remove the global GDBFLAGS declaration at the top, it's not necessary. gdb/testsuite/ChangeLog: * gdb.base/args.exp: Use save_vars. Change-Id: I3a45e4fc1635ec0212de2415040f91eecaf4a057
This commit is contained in:
parent
82a5082ed3
commit
18b5aadea2
@ -1,3 +1,7 @@
|
||||
2021-06-17 Simon Marchi <simon.marchi@efficios.com>
|
||||
|
||||
* gdb.base/args.exp: Use save_vars.
|
||||
|
||||
2021-06-14 Pedro Alves <pedro@palves.net>
|
||||
|
||||
* gdb.base/annota1.exp: Build list using [list] instead of {}.
|
||||
|
@ -15,9 +15,6 @@
|
||||
|
||||
# This is a test for the gdb invocation option --args.
|
||||
|
||||
|
||||
global GDBFLAGS
|
||||
|
||||
# Skip test if target does not support argument passing.
|
||||
if [target_info exists noargs] {
|
||||
return
|
||||
@ -64,39 +61,40 @@ proc args_test { name arglist } {
|
||||
#
|
||||
# Test that the --args are processed correctly.
|
||||
#
|
||||
set old_gdbflags $GDBFLAGS
|
||||
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 3"
|
||||
args_test basic {{1} {3}}
|
||||
save_vars { GDBFLAGS } {
|
||||
set old_gdbflags $GDBFLAGS
|
||||
|
||||
#
|
||||
# Test that the --args are processed correctly even if one of them is empty.
|
||||
# The syntax needed is a little peculiar; DejaGNU treats the arguments as a
|
||||
# list and expands them itself, since no shell redirection is involved.
|
||||
#
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 {} 3"
|
||||
args_test "one empty" {{1} {} {3}}
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 3"
|
||||
args_test basic {{1} {3}}
|
||||
|
||||
#
|
||||
# try with 2 empty args
|
||||
#
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 {} {} 3"
|
||||
args_test "two empty" {{1} {} {} 3}
|
||||
#
|
||||
# Test that the --args are processed correctly even if one of them is empty.
|
||||
# The syntax needed is a little peculiar; DejaGNU treats the arguments as a
|
||||
# list and expands them itself, since no shell redirection is involved.
|
||||
#
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 {} 3"
|
||||
args_test "one empty" {{1} {} {3}}
|
||||
|
||||
# Try with arguments containing literal single quotes.
|
||||
#
|
||||
# try with 2 empty args
|
||||
#
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 {} {} 3"
|
||||
args_test "two empty" {{1} {} {} 3}
|
||||
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 '' 3"
|
||||
args_test "one empty (with single quotes)" {{1} {''} {3}}
|
||||
# Try with arguments containing literal single quotes.
|
||||
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 '' '' 3"
|
||||
args_test "two empty (with single quotes)" {{1} {''} {''} {3}}
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 '' 3"
|
||||
args_test "one empty (with single quotes)" {{1} {''} {3}}
|
||||
|
||||
# try with arguments containing literal newlines.
|
||||
set GDBFLAGS "$old_gdbflags --args $binfile 1 '' '' 3"
|
||||
args_test "two empty (with single quotes)" {{1} {''} {''} {3}}
|
||||
|
||||
set GDBFLAGS "-nx --args $binfile 1 {\n} 3"
|
||||
args_test "one newline" {{1} {\\n} {3}}
|
||||
# try with arguments containing literal newlines.
|
||||
|
||||
set GDBFLAGS "-nx --args $binfile 1 {\n} {\n} 3"
|
||||
args_test "two newlines" {{1} {\\n} {\\n} {3}}
|
||||
set GDBFLAGS "-nx --args $binfile 1 {\n} 3"
|
||||
args_test "one newline" {{1} {\\n} {3}}
|
||||
|
||||
set GDBFLAGS $old_gdbflags
|
||||
set GDBFLAGS "-nx --args $binfile 1 {\n} {\n} 3"
|
||||
args_test "two newlines" {{1} {\\n} {\\n} {3}}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user