gdb/testsuite: remove duplicate test names for gdb.cp/nsusing.exp

In trying to resolve the duplicate test names for the
gdb.cp/nsusing.exp script, I ended up giving the test script a serious
spring clean.

This reverts some of the changes introduced in commit df83a9bf8b,
but I don't think that we have lost any testing.

The test program is made of many functions, the test script wants to
stop in different functions and check which symbols are in scope.

Previously the test script would either restart GDB completely in
order to "progress" to the next function, or the script would restart
the test program using 'runto'.

In this commit I have reordered the steps of the test to correspond to
program order, I then progress through the test program once by just
placing a breakpoint and then continuing.  As I said, the test is
checking which symbols are in scope at each location, so the exact
order of the tests doesn't matter, so long as we check the correct
symbols at each location.

I have also given the comments capital letters and full stops, and
re-wrapped them to a more sensible line length.

There was a duplicate test block introduced in the df83a9bf8b
commit which I have removed in this commit, this duplicate code was
responsible for one of the duplicate test names.

The other duplicate test name was due to the same command being run at
different locations, in this case I just gave the two tests explicit,
unique, names.

gdb/testsuite/ChangeLog:

	* gdb.cp/nsusing.exp: Rewrite test, remove a duplicate test block.
	Avoid repeated uses of 'runto', and instread just progress once
	through the test stopping at different breakpoints.  Give comments
	a capital letter and full stop.  Give duplicate tests unique names.
This commit is contained in:
Andrew Burgess 2021-03-16 10:09:25 +00:00
parent c3344b626d
commit ac45a6ca51
2 changed files with 40 additions and 100 deletions

View File

@ -1,3 +1,10 @@
2021-03-26 Andrew Burgess <andrew.burgess@embecosm.com>
* gdb.cp/nsusing.exp: Rewrite test, remove a duplicate test block.
Avoid repeated uses of 'runto', and instread just progress once
through the test stopping at different breakpoints. Give comments
a capital letter and full stop. Give duplicate tests unique names.
2021-03-25 Pedro Alves <pedro@palves.net> 2021-03-25 Pedro Alves <pedro@palves.net>
* gdb.server/stop-reply-no-thread-multi.exp (run_test): Add * gdb.server/stop-reply-no-thread-multi.exp (run_test): Add

View File

@ -13,7 +13,6 @@
# You should have received a copy of the GNU General Public License # You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
standard_testfile .cc standard_testfile .cc
if [get_compiler_info] { if [get_compiler_info] {
@ -25,8 +24,7 @@ if {[prepare_for_testing "failed to prepare" $testfile $srcfile {debug c++}]} {
} }
############################################ ############################################
# test printing of namespace imported within # Test printing of namespace imported within the function.
# the function.
if ![runto_main] then { if ![runto_main] then {
perror "couldn't run to breakpoint main" perror "couldn't run to breakpoint main"
@ -35,69 +33,19 @@ if ![runto_main] then {
gdb_test "print _a" "= 1" gdb_test "print _a" "= 1"
# Test that names are not printed when they
# are not imported
gdb_breakpoint marker3
gdb_continue_to_breakpoint "marker3"
#send_gdb "break marker3\n"
#send_gdb "continue\n"
gdb_test "print _a" "No symbol \"_a\" in current context." \
"Print _a without import"
gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}
############################################ ############################################
# test printing of namespace imported into # Test printing of namespace imported into a scope containing the pc.
# a scope containing the pc.
if ![runto_main] then {
perror "couldn't run to breakpoint main"
continue
}
gdb_breakpoint [gdb_get_line_number "marker1 stop"] gdb_breakpoint [gdb_get_line_number "marker1 stop"]
gdb_continue_to_breakpoint "marker1 stop" gdb_continue_to_breakpoint "marker1 stop"
gdb_test "print _a" "= 1" "print _a in a nested scope" gdb_test "print _a" "= 1" "print _a in a nested scope"
gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}
############################################ ############################################
# test printing of namespace imported into # Test printing of namespace aliases.
# file scope.
gdb_breakpoint marker2
if ![runto marker5] then { gdb_continue_to_breakpoint "marker2"
perror "couldn't run to breakpoint marker5"
continue
}
gdb_test "print cc" "= 3"
gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}
############################################
# Test printing of namespace aliases
if ![runto marker2] then {
perror "couldn't run to breakpoint marker2"
continue
}
gdb_test "print B::_a" "= 1" gdb_test "print B::_a" "= 1"
@ -107,19 +55,12 @@ gdb_test "print _a" "No symbol \"_a\" in current context." \
gdb_test "print x" "No symbol \"x\" in current context." \ gdb_test "print x" "No symbol \"x\" in current context." \
"print x in namespace alias scope" "print x in namespace alias scope"
gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}
############################################ ############################################
# Test that names are not printed when they # Test that names are not printed when they
# are not imported # are not imported.
if {![runto marker3]} { gdb_breakpoint marker3
perror "couldn't run to breakpoint marker3" gdb_continue_to_breakpoint "marker3"
}
# gcc-4-3 puts import statements for aliases in # gcc-4-3 puts import statements for aliases in
# the global scope instead of the corresponding # the global scope instead of the corresponding
@ -128,70 +69,62 @@ if {![runto marker3]} {
if [test_compiler_info gcc-4-3-*] then { setup_xfail *-*-* } if [test_compiler_info gcc-4-3-*] then { setup_xfail *-*-* }
gdb_test "print _a" "No symbol \"_a\" in current context." \ gdb_test "print _a" "No symbol \"_a\" in current context." \
"Print _a without import" "Print _a without import at marker3"
############################################ ############################################
# Test printing of individually imported elements # Test printing of individually imported elements.
if ![runto marker4] then { gdb_breakpoint marker4
perror "couldn't run to breakpoint marker4" gdb_continue_to_breakpoint "marker4"
continue
}
gdb_test "print dx" "= 4" gdb_test "print dx" "= 4"
############################################ ############################################
# Test printing of namespace aliases # Test printing of namespace imported into file scope.
if ![runto marker5] then { gdb_breakpoint marker5
perror "couldn't run to marker5" gdb_continue_to_breakpoint "marker5"
continue
} gdb_test "print cc" "= 3"
# Also test printing of namespace aliases
gdb_test "print efx" "= 5" gdb_test "print efx" "= 5"
############################################ ############################################
# Test printing of variables imported from # Test printing of variables imported from nested namespaces.
# nested namespaces
if ![runto I::marker7] then { gdb_breakpoint I::marker7
perror "couldn't run to breakpoint I::marker7" gdb_continue_to_breakpoint "I::marker7"
continue
}
gdb_test "print ghx" "= 6" gdb_test "print ghx" "= 6"
############################################ ############################################
# Test that variables are not printed in a namespace # Test that variables are not printed in a namespace that is sibling
# that is sibling to the namespace containing an import # to the namespace containing an import.
if ![runto L::marker8] then { gdb_breakpoint L::marker8
perror "couldn't run to breakpoint L::marker8" gdb_continue_to_breakpoint "L::marker8"
continue
}
gdb_test "print jx" "= 44" gdb_test "print jx" "= 44" \
"print jx when the symbol is available"
gdb_breakpoint "K::marker9" gdb_breakpoint "K::marker9"
gdb_continue_to_breakpoint "K::marker9" gdb_continue_to_breakpoint "K::marker9"
gdb_test "print jx" "No symbol \"jx\" in current context." gdb_test "print jx" "No symbol \"jx\" in current context." \
"print jx when the symbol is not available"
############################################ ############################################
# Test that variables are only printed after the line # Test that variables are only printed after the line containing the
# containing the import # import.
if ![runto_main] then {
perror "couldn't run to breakpoint main"
continue
}
gdb_breakpoint [gdb_get_line_number "marker10 stop"] gdb_breakpoint [gdb_get_line_number "marker10 stop"]
gdb_continue_to_breakpoint "marker10 stop" gdb_continue_to_breakpoint "marker10 stop"
if { [test_compiler_info {gcc-[0-3]-*}] || if { [test_compiler_info {gcc-[0-3]-*}] ||
[test_compiler_info {gcc-4-[0-3]-*}]} { [test_compiler_info {gcc-4-[0-3]-*}]} {
setup_xfail *-*-* setup_xfail *-*-*
} }
# Assert that M::x is printed and not N::x # Assert that M::x is printed and not N::x