gdb/testsuite/ada: Handle missing debug info case
authorAndrew Burgess <andrew.burgess@embecosm.com>
Mon, 7 Oct 2019 12:10:55 +0000 (13:10 +0100)
committerAndrew Burgess <andrew.burgess@embecosm.com>
Mon, 7 Oct 2019 12:17:49 +0000 (13:17 +0100)
Update a test script to handle the case where missing Ada debug
information means we can't catch exceptions.  This was discussed on
the list here:

  https://sourceware.org/ml/gdb-patches/2019-08/msg00607.html

And is similar to code that already exists in the test scripts
gdb.ada/catch_ex.exp and gdb.ada/mi_catch_ex.exp.

gdb/testsuite/ChangeLog:

* gdb.ada/catch_ex_std.exp: Handle being unabled to catch Ada
exceptions due to missing debug information.

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.ada/catch_ex_std.exp

index c3fc339a1910f005e633248655c1e70a352cbf50..4adf16af00c68077cefbba59a90c6789a7c6c4c2 100644 (file)
@@ -1,3 +1,8 @@
+2019-10-07  Andrew Burgess  <andrew.burgess@embecosm.com>
+
+       * gdb.ada/catch_ex_std.exp: Handle being unabled to catch Ada
+       exceptions due to missing debug information.
+
 2019-10-07  Tom de Vries  <tdevries@suse.de>
 
        * gdb.base/default.exp: Expect _gdb_major/_gdb_minor to be 9.1.
index 839d0bb092f81ad545d817715086e3cb93822b6e..f3a4e59d4b9108764cd11510506311a7af17d1c3 100644 (file)
@@ -95,12 +95,23 @@ if {![runto_main]} then {
    return 0
 }
 
-gdb_test "catch exception some_kind_of_error" \
-    "Catchpoint \[0-9\]+: `some_kind_of_error' Ada exception"
+set can_catch_exceptions 0
+gdb_test_multiple "catch exception some_kind_of_error" "" {
+    -re "Catchpoint \[0-9\]+: `some_kind_of_error' Ada exception\r\n$gdb_prompt $" {
+       pass $gdb_test_name
+       set can_catch_exceptions 1
+    }
 
-gdb_test "cont" \
-    "Catchpoint \[0-9\]+, .* at .*foo\.adb:\[0-9\]+.*" \
-    "caught the exception"
+    -re "Your Ada runtime appears to be missing some debugging information.\r\nCannot insert Ada exception catchpoint in this configuration.\r\n$gdb_prompt $" {
+           unsupported $gdb_test_name
+    }
+}
 
-gdb_test "print \$_ada_exception = some_package.some_kind_of_error'Address" \
-    " = true"
+if { $can_catch_exceptions } {
+    gdb_test "cont" \
+       "Catchpoint \[0-9\]+, .* at .*foo\.adb:\[0-9\]+.*" \
+       "caught the exception"
+
+    gdb_test "print \$_ada_exception = some_package.some_kind_of_error'Address" \
+       " = true"
+}