aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite
diff options
context:
space:
mode:
authorTom Tromey <tromey@adacore.com>2024-08-28 08:06:58 -0600
committerTom Tromey <tromey@adacore.com>2025-03-06 14:17:17 -0700
commit7253760b5a0116505a9b13c9f6cbaa457ec8b74f (patch)
tree44ef787d6f54ae5225b254577ed52d2a66fa8607 /gdb/testsuite
parent8b9041206f334835dae5a66801a0a7c8936a0714 (diff)
downloadbinutils-7253760b5a0116505a9b13c9f6cbaa457ec8b74f.zip
binutils-7253760b5a0116505a9b13c9f6cbaa457ec8b74f.tar.gz
binutils-7253760b5a0116505a9b13c9f6cbaa457ec8b74f.tar.bz2
Fixes to gdb.ada/fun_overload_menu.exp
This patch applies a few fixes to gdb.ada/fun_overload_menu.exp. It adds some comments to the source and uses this to extract line numbers. This is used to ensure that two otherwise-equivalent results are in fact different, so that the test really checks that the result is correct. It also changes the test_menu proc to accept a list of possible results. This lets the test work regardless of the order in which the menu items are presented by gdb. Finally, like an earlier patch, it changes the test to optionally accept unqualified names from gdb.
Diffstat (limited to 'gdb/testsuite')
-rw-r--r--gdb/testsuite/gdb.ada/fun_overload_menu.exp43
-rw-r--r--gdb/testsuite/gdb.ada/fun_overload_menu/foo.adb4
2 files changed, 28 insertions, 19 deletions
diff --git a/gdb/testsuite/gdb.ada/fun_overload_menu.exp b/gdb/testsuite/gdb.ada/fun_overload_menu.exp
index 8e7a3fb..1130d84 100644
--- a/gdb/testsuite/gdb.ada/fun_overload_menu.exp
+++ b/gdb/testsuite/gdb.ada/fun_overload_menu.exp
@@ -28,18 +28,30 @@ clean_restart ${testfile}
set bp_location [gdb_get_line_number "BREAK" ${testdir}/foo.adb]
runto "foo.adb:$bp_location"
+set line1 [gdb_get_line_number "LINE 1" ${testdir}/foo.adb]
+set line2 [gdb_get_line_number "LINE 2" ${testdir}/foo.adb]
-proc test_menu {expr function menu_entries selection output} {
- set menu [multi_line "Multiple matches for $function" \
- "\\\[0\\\] cancel" \
- "$menu_entries" \
- "> $"]
+proc test_menu {expr function first second selection output} {
+ set menu1 [multi_line "Multiple matches for $function" \
+ "\\\[0\\\] cancel" \
+ "\\\[1\\\] $first" \
+ "\\\[2\\\] $second" \
+ "> $"]
+ set menu2 [multi_line "Multiple matches for $function" \
+ "\\\[0\\\] cancel" \
+ "\\\[1\\\] $second" \
+ "\\\[2\\\] $first" \
+ "> $"]
set test_name "multiple matches for $function {$expr}"
- gdb_test_multiple "print $expr" "$test_name" \
- {
- -re "$menu" {
+ gdb_test_multiple "print $expr" "$test_name" {
+ -re "$menu1" {
pass "$test_name"
}
+ -re "$menu2" {
+ pass "$test_name"
+ # Make sure we pick the correct one.
+ set selection [expr {3 - $selection}]
+ }
default {
fail "$test_name"
}
@@ -53,18 +65,16 @@ proc test_menu {expr function menu_entries selection output} {
# 1. Test with overloaded functions
with_test_prefix "func" {
test_menu "f (1, null)" "f" \
- [multi_line \
- "\\\[1\\\] foo\\.f \\(integer; foo\\.integer_access\\) return boolean at .*foo.adb:.*" \
- "\\\[2\\\] foo\\.f \\(foo\\.new_integer; foo\\.integer_access\\) return boolean at .*foo.adb:.*"] \
+ "foo\\.f \\(integer; (foo\\.)?integer_access\\) return boolean at .*foo.adb:.*" \
+ "foo\\.f \\((foo\\.)?new_integer; (foo\\.)?integer_access\\) return boolean at .*foo.adb:.*" \
"1" "= true"
}
# 2. Test with overloaded procedures
with_test_prefix "proc" {
test_menu "p (1, null)" "p" \
- [multi_line \
- "\\\[1\\\] foo\\.p \\(integer; foo\\.integer_access\\) at .*foo.adb:.*" \
- "\\\[2\\\] foo\\.p \\(foo\\.new_integer; foo\\.integer_access\\) at .*foo.adb:.*" ] \
+ "foo\\.p \\(integer; (foo\\.)?integer_access\\) at .*foo.adb:.*" \
+ "foo\\.p \\((foo\\.)?new_integer; (foo\\.)?integer_access\\) at .*foo.adb:.*" \
"1" "= (void)"
}
@@ -72,8 +82,7 @@ with_test_prefix "proc" {
gdb_test "set ada print-signatures off" ""
with_test_prefix "signatures disabled" {
test_menu "f (1, null)" "f" \
- [multi_line \
- "\\\[1\\\] foo\\.f at .*foo.adb:.*" \
- "\\\[2\\\] foo\\.f at .*foo.adb:.*"] \
+ "foo\\.f at .*foo.adb:$line1.*" \
+ "foo\\.f at .*foo.adb:$line2.*" \
"1" "= true"
}
diff --git a/gdb/testsuite/gdb.ada/fun_overload_menu/foo.adb b/gdb/testsuite/gdb.ada/fun_overload_menu/foo.adb
index 0a2b21a..d866221 100644
--- a/gdb/testsuite/gdb.ada/fun_overload_menu/foo.adb
+++ b/gdb/testsuite/gdb.ada/fun_overload_menu/foo.adb
@@ -20,12 +20,12 @@ procedure Foo is
function F (I : Integer; A : Integer_Access) return Boolean is
begin
- return True;
+ return True; -- LINE 1
end F;
function F (I : New_Integer; A : Integer_Access) return Boolean is
begin
- return False;
+ return False; -- LINE 2
end F;
procedure P (I : Integer; A : Integer_Access) is