[gdb/testsuite] Catch condition evaluation errors in gdb_assert
authorTom de Vries <tdevries@suse.de>
Wed, 16 Sep 2020 11:27:32 +0000 (13:27 +0200)
committerTom de Vries <tdevries@suse.de>
Wed, 16 Sep 2020 11:27:32 +0000 (13:27 +0200)
When running test-case gdb.base/watchpoint-stops-at-right-insn.exp, we may run
into a tcl error, which can be reproduced reliably using this trigger patch:
...
+       set hw_watch_pc ""
        gdb_assert {$sw_watch_pc == $hw_watch_pc} \
  "hw watchpoint stops at right instruction"
...
such that we have:
...
ERROR: tcl error sourcing watchpoint-stops-at-right-insn.exp.
ERROR: missing operand at _@_
in expression "0x4004b7 == _@_"
    (parsing expression "0x4004b7 == ")
    invoked from within
"expr $sw_watch_pc == $hw_watch_pc"
    ("uplevel" body line 1)
    invoked from within
"uplevel 1 expr $condition"
    (procedure "gdb_assert" line 6)
    invoked from within
"gdb_assert {$sw_watch_pc == $hw_watch_pc} \
  "hw watchpoint stops at right instruction""
...

A similar problem was fixed in commit 5f0e2eb79e "GDB/testsuite: Fix a
catastrophic step-over-no-symbols.exp failure", by making the assert condition
more robust:
...
-    gdb_assert {$before_addr != $after_addr} "advanced"
+    gdb_assert {{[string is integer -strict $before_addr] \
+                && [string is integer -strict $after_addr] \
+                && $before_addr != $after_addr}} "advanced"
...

Fix this instead in gdb_assert, by catching errors while evaluating the assert
condition.

Tested on x86_64-linux.

gdb/testsuite/ChangeLog:

2020-09-16  Tom de Vries  <tdevries@suse.de>

PR testsuite/26624
* lib/gdb.exp (gdb_assert): Catch errors in condition evaluation.

gdb/testsuite/ChangeLog
gdb/testsuite/lib/gdb.exp

index 5e3125cdd45c6d8dddb5b438ec16944bca59b146..481d18a32177e14e7f8b0decf4c40143192ad5d2 100644 (file)
@@ -1,3 +1,8 @@
+2020-09-16  Tom de Vries  <tdevries@suse.de>
+
+       PR testsuite/26624
+       * lib/gdb.exp (gdb_assert): Catch errors in condition evaluation.
+
 2020-09-16  Tom de Vries  <tdevries@suse.de>
 
        PR testsuite/26618
index 653f145c1ce96843ebcc7d9661c16216c2946f82..59439f8e37975acffb006e07e738ab73ec2183e1 100644 (file)
@@ -1689,8 +1689,8 @@ proc gdb_assert { condition {message ""} } {
        set message $condition
     }
 
-    set res [uplevel 1 expr $condition]
-    if {!$res} {
+    set code [catch {uplevel 1 expr $condition} res]
+    if {$code != 0 || !$res} {
        fail $message
     } else {
        pass $message