Index: gdb/testsuite/gdb.gdb/xfullpath.exp |
diff --git a/gdb/testsuite/gdb.gdb/xfullpath.exp b/gdb/testsuite/gdb.gdb/xfullpath.exp |
index 0ebf824687b8903e1aa5d23bc7a88b3d9aea2172..d758a18c8800ca22c3651594c25ed884ea8553ae 100644 |
--- a/gdb/testsuite/gdb.gdb/xfullpath.exp |
+++ b/gdb/testsuite/gdb.gdb/xfullpath.exp |
@@ -1,4 +1,4 @@ |
-# Copyright 2002-2004, 2007-2012 Free Software Foundation, Inc. |
+# Copyright 2002-2013 Free Software Foundation, Inc. |
# This program is free software; you can redistribute it and/or modify |
# it under the terms of the GNU General Public License as published by |
@@ -16,168 +16,45 @@ |
# This file was written by Joel Brobecker. (brobecker@gnat.com), derived |
# from selftest.exp, written by Rob Savoye. |
+load_lib selftest-support.exp |
-# are we on a target board |
-if { [is_remote target] || ![isnative] } then { |
- return |
-} |
- |
-proc setup_test { executable } { |
- global gdb_prompt |
- global timeout |
- |
- # load yourself into the debugger |
- # This can take a relatively long time, particularly for testing where |
- # the executable is being accessed over a network, or where gdb does not |
- # support partial symbols for a particular target and has to load the |
- # entire symbol table. Set the timeout to 10 minutes, which should be |
- # adequate for most environments (it *has* timed out with 5 min on a |
- # SPARCstation SLC under moderate load, so this isn't unreasonable). |
- # After gdb is started, set the timeout to 30 seconds for the duration |
- # of this test, and then back to the original value. |
- |
- set oldtimeout $timeout |
- set timeout 600 |
- verbose "Timeout is now $timeout seconds" 2 |
- |
- global gdb_file_cmd_debug_info |
- set gdb_file_cmd_debug_info "unset" |
- |
- set result [gdb_load $executable] |
- set timeout $oldtimeout |
- verbose "Timeout is now $timeout seconds" 2 |
- |
- if { $result != 0 } then { |
- return -1 |
- } |
- |
- if { $gdb_file_cmd_debug_info != "debug" } then { |
- untested "No debug information, skipping testcase." |
- return -1 |
- } |
- |
- # Set a breakpoint at main |
- gdb_test "break captured_main" \ |
- "Breakpoint.*at.* file.*, line.*" \ |
- "breakpoint in captured_main" |
- |
- # run yourself |
- # It may take a very long time for the inferior gdb to start (lynx), |
- # so we bump it back up for the duration of this command. |
- set timeout 600 |
- |
- set description "run until breakpoint at captured_main" |
- gdb_test_multiple "run -nw" "$description" { |
- -re "Starting program.*Breakpoint \[0-9\]+,.*captured_main .data.* at .*main.c:.*$gdb_prompt $" { |
- pass "$description" |
- } |
- -re "Starting program.*Breakpoint \[0-9\]+,.*captured_main .data.*$gdb_prompt $" { |
- xfail "$description (line numbers scrambled?)" |
- } |
- -re "vfork: No more processes.*$gdb_prompt $" { |
- fail "$description (out of virtual memory)" |
- set timeout $oldtimeout |
- verbose "Timeout is now $timeout seconds" 2 |
- return -1 |
- } |
- -re ".*$gdb_prompt $" { |
- fail "$description" |
- set timeout $oldtimeout |
- verbose "Timeout is now $timeout seconds" 2 |
- return -1 |
- } |
- } |
- |
- set timeout $oldtimeout |
- verbose "Timeout is now $timeout seconds" 2 |
- |
- return 0 |
-} |
- |
-proc test_with_self { executable } { |
- |
- set setup_result [setup_test $executable] |
- if {$setup_result <0} then { |
- return -1 |
- } |
- |
+proc test_with_self {} { |
# A file which contains a directory prefix |
- gdb_test "print xfullpath (\"./xfullpath.exp\")" \ |
+ gdb_test "print gdb_realpath (\"./xfullpath.exp\")" \ |
".\[0-9\]+ =.*\".*/xfullpath.exp\"" \ |
"A filename with ./ as the directory prefix" |
# A file which contains a directory prefix |
- gdb_test "print xfullpath (\"../../defs.h\")" \ |
+ gdb_test "print gdb_realpath (\"../../defs.h\")" \ |
".\[0-9\]+ =.*\".*/defs.h\"" \ |
"A filename with ../ in the directory prefix" |
# A one-character filename |
- gdb_test "print xfullpath (\"./a\")" \ |
+ gdb_test "print gdb_realpath (\"./a\")" \ |
".\[0-9\]+ =.*\".*/a\"" \ |
"A one-char filename in the current directory" |
# A file in the root directory |
- gdb_test "print xfullpath (\"/root_file_which_should_exist\")" \ |
+ gdb_test "print gdb_realpath (\"/root_file_which_should_exist\")" \ |
".\[0-9\]+ =.*\"/root_file_which_should_exist\"" \ |
"A filename in the root directory" |
# A file which does not have a directory prefix |
- gdb_test "print xfullpath (\"xfullpath.exp\")" \ |
+ gdb_test "print gdb_realpath (\"xfullpath.exp\")" \ |
".\[0-9\]+ =.*\"xfullpath.exp\"" \ |
"A filename without any directory prefix" |
# A one-char filename without any directory prefix |
- gdb_test "print xfullpath (\"a\")" \ |
+ gdb_test "print gdb_realpath (\"a\")" \ |
".\[0-9\]+ =.*\"a\"" \ |
"A one-char filename without any directory prefix" |
# An empty filename |
- gdb_test "print xfullpath (\"\")" \ |
+ gdb_test "print gdb_realpath (\"\")" \ |
".\[0-9\]+ =.*\"\"" \ |
"An empty filename" |
return 0 |
} |
-# Find a pathname to a file that we would execute if the shell was asked |
-# to run $arg using the current PATH. |
- |
-proc find_gdb { arg } { |
- |
- # If the arg directly specifies an existing executable file, then |
- # simply use it. |
- |
- if [file executable $arg] then { |
- return $arg |
- } |
- |
- set result [which $arg] |
- if [string match "/" [ string range $result 0 0 ]] then { |
- return $result |
- } |
- |
- # If everything fails, just return the unqualified pathname as default |
- # and hope for best. |
- |
- return $arg |
-} |
- |
-# Run the test with self. |
-# Copy the file executable file in case this OS doesn't like to edit its own |
-# text space. |
- |
-set GDB_FULLPATH [find_gdb $GDB] |
- |
-# Remove any old copy lying around. |
-remote_file host delete x$tool |
- |
-gdb_start |
-set file [remote_download host $GDB_FULLPATH x$tool] |
-set result [test_with_self $file]; |
-gdb_exit; |
-catch "remote_file host delete $file"; |
- |
-if {$result <0} then { |
- warning "Couldn't test self" |
- return -1 |
-} |
+do_self_tests captured_main test_with_self |