| Index: gdb/testsuite/gdb.gdb/observer.exp
|
| diff --git a/gdb/testsuite/gdb.gdb/observer.exp b/gdb/testsuite/gdb.gdb/observer.exp
|
| index 47a4a113cd8e377641b74d29401e2526486f2d27..b70c2b117063c5400cc06b62970097bd14a58a76 100644
|
| --- a/gdb/testsuite/gdb.gdb/observer.exp
|
| +++ b/gdb/testsuite/gdb.gdb/observer.exp
|
| @@ -1,4 +1,4 @@
|
| -# Copyright 2003-2004, 2007-2012 Free Software Foundation, Inc.
|
| +# Copyright 2003-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,83 +16,7 @@
|
| # This file was written by Joel Brobecker (brobecker@gnat.com), derived
|
| # from xfullpath.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
|
| -}
|
| +load_lib selftest-support.exp
|
|
|
| proc attach_first_observer { message } {
|
| gdb_test_no_output "set \$first_obs = observer_attach_test_notification (&observer_test_first_notification_function)" \
|
| @@ -159,13 +83,7 @@ proc test_notifications { first second third message args } {
|
| check_counters $first $second $third $message
|
| }
|
|
|
| -proc test_observer { executable } {
|
| -
|
| - set setup_result [setup_test $executable]
|
| - if {$setup_result <0} then {
|
| - return -1
|
| - }
|
| -
|
| +proc test_observer {} {
|
| # First, try sending a notification without any observer attached.
|
| test_notifications 0 0 0 "no observer attached"
|
|
|
| @@ -222,45 +140,4 @@ proc test_observer { executable } {
|
| 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_observer $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_observer
|
|
|