binutils-gdb/gdb/testsuite/gdb.linespec/linespec.exp
Pedro Alves 121b3efd49 Add "info connections" command, "info inferiors" connection number/string
This commit extends the CLI a bit for multi-target, in three ways.

#1 - New "info connections" command.

This is a new command that lists the open connections (process_stratum
targets).  For example, if you're debugging two remote connections, a
couple local/native processes, and a core dump, all at the same time,
you might see something like this:

 (gdb) info connections
   Num  What                     Description
   1    remote 192.168.0.1:9999  Remote serial target in gdb-specific protocol
   2    remote 192.168.0.2:9998  Remote serial target in gdb-specific protocol
 * 3    native                   Native process
   4    core                     Local core dump file

#2 - New "info inferiors" "Connection" column

You'll also see a new matching "Connection" column in "info
inferiors", showing you which connection an inferior is bound to:

 (gdb) info inferiors
   Num  Description       Connection                   Executable
   1    process 18526     1 (remote 192.168.0.1:9999)  target:/tmp/a.out
   2    process 18531     2 (remote 192.168.0.2:9998)  target:/tmp/a.out
   3    process 19115     3 (native)                   /tmp/prog1
   4    process 6286      4 (core)                     myprogram
 * 5    process 19122     3 (native)                   /bin/hello

#3 - Makes "add-inferior" show the inferior's target connection

"add-inferior" now shows you the connection you've just bound the
inferior to, which is the current process_stratum target:

 (gdb) add-inferior
 [New inferior 2]
 Added inferior 2 on connection 1 (extended-remote localhost:2346)

gdb/ChangeLog:
2020-01-10  Pedro Alves  <palves@redhat.com>

	* Makefile.in (COMMON_SFILES): Add target-connection.c.
	* inferior.c (uiout_field_connection): New function.
	(print_inferior): Add new "connection-id" column.
	(add_inferior_command): Show connection number/string of added
	inferior.
	* process-stratum-target.h
	(process_stratum_target::connection_string): New virtual method.
	(process_stratum_target::connection_number): New field.
	* remote.c (remote_target::connection_string): New override.
	* target-connection.c: New file.
	* target-connection.h: New file.
	* target.c (decref_target): Remove process_stratum targets from
	the connection list.
	(target_stack::push): Add process_stratum targets to the
	connection list.

gdb/testsuite/ChangeLog:
2020-01-10  Pedro Alves  <palves@redhat.com>

	* gdb.base/kill-detach-inferiors-cmd.exp: Adjust expected output
	of "add-inferior".
	* gdb.base/quit-live.exp: Likewise.
	* gdb.base/remote-exec-file.exp: Likewise.
	* gdb.guile/scm-progspace.exp: Likewise.
	* gdb.linespec/linespec.exp: Likewise.
	* gdb.mi/new-ui-mi-sync.exp: Likewise.
	* gdb.mi/user-selected-context-sync.exp: Likewise.
	* gdb.multi/multi-target.exp (setup): Add "info connection" and
	"info inferiors" tests.
	* gdb.multi/remove-inferiors.exp: Adjust expected output of
	"add-inferior".
	* gdb.multi/watchpoint-multi.exp: Likewise.
	* gdb.python/py-inferior.exp: Likewise.
	* gdb.server/extended-remote-restart.exp: Likewise.
	* gdb.threads/fork-plus-threads.exp: Adjust expected output of
	"info inferiors".
	* gdb.threads/forking-threads-plus-breakpoint.exp: Likewise.
	* gdb.trace/report.exp: Likewise.
2020-01-10 20:06:14 +00:00

219 lines
7.2 KiB
Plaintext

# Copyright 2011-2020 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
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# Tests of ambiguous linespecs.
standard_testfile lspec.cc
set exefile $testfile
set baseone base/one/thefile.cc
set basetwo base/two/thefile.cc
if {[skip_cplus_tests]} {
unsupported "skipping c++ tests"
return
}
if {[prepare_for_testing "failed to prepare" $exefile \
[list $srcfile $baseone $basetwo] \
{debug nowarnings c++}]} {
return -1
}
gdb_test_no_output "set multiple-symbols all" \
"set multiple-symbols to all for linespec tests"
set l1 [gdb_get_line_number "thefile breakpoint" $baseone]
set l2 [gdb_get_line_number "thefile breakpoint" $basetwo]
if {$l1 != $l2} {
error "somebody incompatibly modified the source files needed by linespec.exp"
}
gdb_test_no_output "set breakpoint pending off" \
"disable pending breakpoints for linespec tests"
# Copying files to a remote host loses the directory prefix during
# compilation.
if { [is_remote host] } {
untested "breakpoints using dir/file:line"
} else {
gdb_test "break one/thefile.cc:$l1" \
"Breakpoint $decimal at $hex: file .*thefile.cc, line $l1." \
"single-location break using dir/file:line"
gdb_test "clear one/thefile.cc:$l1" \
"Deleted breakpoint $decimal *" \
"clear breakpoint using dir/file:line"
if { [readline_is_used] } {
# There are functions named 'twodup' in both source files.
# Both should be found if we restrict the linespec to the
# ambiguous "thefile.cc" source filename. Check both
# completion and setting the breakpoint.
set tst "complete unique function name in two source files"
send_gdb "break thefile.cc:t\t"
gdb_test_multiple "" $tst {
-re "break thefile.cc:twodup\\(\\) " {
pass $tst
send_gdb "\n"
gdb_test "" \
"Breakpoint $decimal at $hex: thefile.cc:twodup\\(\\). \[(\]2 locations\[)\]" \
"set break at unique function name in two source files"
}
}
# Check both completing and setting a breakpoint on a linespec
# with a source component, where there's more than one source
# file with the same basename. We should find the functions
# in all matching sources -- one/thefile.cc and
# two/thefile.cc. The "one" file has "z1()", while the "two"
# file has "z2()".
set tst "complete non-unique function name in two source files"
send_gdb "break thefile.cc:z\t"
gdb_test_multiple "" $tst {
-re "break thefile.cc:z\\\x07" {
send_gdb "\t"
gdb_test_multiple "" $tst {
-re "\r\nz1\\(\\)\[ \t\]+z2\\(\\)\[ \t\]+\r\n$gdb_prompt " {
pass $tst
send_gdb "\n"
gdb_test "" \
"Function \"z\" not defined in \"thefile.cc\"." \
"set break at non-unique function name in two source files"
}
}
}
}
# Now check that disambiguating the source path makes GDB only
# match the symbols in that file. "z" should now have a
# unique completion to "z1()", and setting the breakpoint
# should find only one location.
set tst "complete unique function name in disambiguated source file"
send_gdb "break one/thefile.cc:z\t"
gdb_test_multiple "" $tst {
-re "break one/thefile.cc:z1\\(\\) " {
pass $tst
send_gdb "\n"
gdb_test "" \
"Breakpoint $decimal at $hex: file .*thefile.cc, line \[^\r\n\]*" \
"set break at unique function name in disambiguated source file"
}
}
# Check that using a non-existing source path does not confuse
# GDB. It should not match any symbol.
set dir_file "one/thefile.cc"
set non_existing "/some/non-existing/absolute/path/prefix/$dir_file"
set non_existing_re [string_to_regexp $non_existing]
set tst "complete functions in non-existing absolute path"
send_gdb "break $non_existing:\t"
gdb_test_multiple "" $tst {
-re "break $non_existing_re:\\\x07" {
send_gdb "\t\t"
gdb_test_multiple "" $tst {
-re "^\\\x07\\\x07" {
pass $tst
# There's a function called 'twodup' in each
# of the thefile.cc files. Make sure none is
# picked.
send_gdb "twodup\n"
gdb_test "" \
"No source file named $non_existing_re." \
"set break in function in non-existing absolute path"
}
}
}
}
}
}
gdb_test "break thefile.cc:$l1" \
"Breakpoint $decimal at $hex: thefile.cc:$l1. \[(\]2 locations\[)\]" \
"multi-location break using file:line"
gdb_test "break dupname" \
"Breakpoint $decimal at $hex: dupname. \[(\]2 locations\[)\]" \
"multi-location break using duplicate function name"
gdb_test "break dupname:label" \
"Breakpoint $decimal at $hex: dupname:label. \[(\]2 locations\[)\]" \
"multi-location break using duplicate function name and label"
# Testing if the "condition" command completes only the breakpoints,
# not the locations.
gdb_test "complete condition " "condition $decimal\r\ncondition $decimal\r\ncondition $decimal"
# This is PR breakpoints/12856.
gdb_test "break lspec.cc:nosuchfunction" \
"Function \"nosuchfunction\" not defined in \"lspec.cc\"." \
"set breakpoint on non-existent function"
gdb_test "break NameSpace::overload" \
"Breakpoint \[0-9\]+ at $hex: NameSpace::overload. \[(\]3 locations\[)\]" \
"set breakpoint at all instances of NameSpace::overload"
gdb_test "break lspec.cc:NameSpace::overload" \
"Breakpoint \[0-9\]+ at $hex: file .*lspec.cc, line 7." \
"set breakpoint at lspec.cc instance of NameSpace::overload"
gdb_test "break lspec.cc:NameSpace::overload(double)" \
"Function \"NameSpace::overload\\(double\\)\" not defined in \"lspec.cc\"." \
"set breakpoint at non-existent lspec.cc instance of NameSpace::overload"
gdb_test "break NameSpace::overload()" \
"Breakpoint \[0-9\]+ at $hex: file .*lspec.cc, line 7." \
"set breakpoint at specific instance of NameSpace::overload"
# This should manage to set a breakpoint even though body.h does not
# include all of the function in question.
set line [gdb_get_line_number "body breakpoint no code" body.h]
gdb_test "break body.h:$line" \
"Breakpoint \[0-9\]+.*" \
"set breakpoint in body.h"
# This should only have a single location -- in f1.
set line [gdb_get_line_number "f1 breakpoint" lspec.h]
gdb_test "break lspec.h:$line" \
"Breakpoint \[0-9\]+ at $hex: file .*lspec.h, line $line." \
"set breakpoint in f1"
#
# Multi-inferior tests.
#
gdb_test "add-inferior" "Added inferior 2.*" \
"add inferior for linespec tests"
gdb_test "inferior 2" "Switching to inferior 2 .*" \
"switch to inferior 2 for linespec tests"
# Note that in particular this should not cause errors when re-setting
# breakpoints.
gdb_test "file $binfile" \
"Reading symbols from .*" \
"set the new inferior file for linespec tests"
gdb_test "break main" \
"Breakpoint \[0-9\]+ at $hex: main. .2 locations." \
"set breakpoint at main in both inferiors"