[gdb/testsuite] Fix internal buffer full error in gdb.base/info-types.exp
authorTom de Vries <tdevries@suse.de>
Thu, 12 Mar 2020 13:58:57 +0000 (14:58 +0100)
committerTom de Vries <tdevries@suse.de>
Thu, 12 Mar 2020 13:58:57 +0000 (14:58 +0100)
With test-case gdb.base/info-types.exp, I run into:
...
ERROR: internal buffer is full.
UNRESOLVED: gdb.base/info-types.exp: l=c: info types
ERROR: internal buffer is full.
UNRESOLVED: gdb.base/info-types.exp: l=c++: info types
...

Fix this by using exp_continue while matching the output of "info types".

Tested on x86_64-linux, using make targets check and check-read1.

gdb/testsuite/ChangeLog:

2020-03-12  Tom de Vries  <tdevries@suse.de>

* gdb.base/info-types.exp: Use exp_continue during matching of output
of "info types".

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.base/info-types.exp

index 6fc24e19c2c06d70f29ca66eba0cfa108798d33b..5c5576ed1e9b10113fda75e95f0df3feeb8509df 100644 (file)
@@ -1,3 +1,8 @@
+2020-03-12  Tom de Vries  <tdevries@suse.de>
+
+       * gdb.base/info-types.exp: Use exp_continue during matching of output
+       of "info types".
+
 2020-03-12  Tom de Vries  <tdevries@suse.de>
 
        * gdb.threads/execl.exp: Delete breakpoint after hitting it.
index a69620af7af0029dc654769b0906bb665d435f44..7cce756e92d033a3d605c10490cec18c18813d72 100644 (file)
@@ -54,9 +54,6 @@ proc run_test { lang } {
     if { $lang == "c++" } {
        set output_re \
            [multi_line \
-                "All defined types:" \
-                "" \
-                "File .*:" \
                 "98:\[\t \]+CL;" \
                 "42:\[\t \]+anon_struct_t;" \
                 "65:\[\t \]+anon_union_t;" \
@@ -86,15 +83,10 @@ proc run_test { lang } {
                 "19:\[\t \]+typedef float nested_float_t;" \
                 "18:\[\t \]+typedef int nested_int_t;" \
                 "62:\[\t \]+typedef union_t nested_union_t;(" \
-                "\[\t \]+unsigned int)?(" \
-                "" \
-                "File .*:.*)?" ]
+                "\[\t \]+unsigned int)?"]
     } else {
        set output_re \
            [multi_line \
-                "All defined types:" \
-                "" \
-                "File .*:" \
                 "52:\[\t \]+typedef enum {\\.\\.\\.} anon_enum_t;" \
                 "45:\[\t \]+typedef struct {\\.\\.\\.} anon_struct_t;" \
                 "68:\[\t \]+typedef union {\\.\\.\\.} anon_union_t;" \
@@ -118,12 +110,34 @@ proc run_test { lang } {
                 "18:\[\t \]+typedef int nested_int_t;" \
                 "62:\[\t \]+typedef union union_t nested_union_t;" \
                 "56:\[\t \]+union union_t;(" \
-                "\[\t \]+unsigned int)?(" \
-                "" \
-                "File .*:.*)?" ]
+                "\[\t \]+unsigned int)?"]
     }
 
-    gdb_test "info types" $output_re
+    set state 0
+    gdb_test_multiple "info types" "" {
+       -re "\r\nAll defined types:" {
+           if { $state == 0 } { set state 1 }
+           exp_continue
+       }
+       -re "\r\n\r\nFile .*[string_to_regexp $srcfile]:" {
+           if { $state == 1 } { set state 2 }
+           exp_continue
+       }
+       -re $output_re {
+           if { $state == 2 } { set state 3 }
+           exp_continue
+       }
+       -re "\r\n\r\nFile \[^\r\n\]*:" {
+           exp_continue
+       }
+       -re -wrap "" {
+           if { $state == 3} {
+               pass $gdb_test_name
+           } else {
+               fail $gdb_test_name
+           }
+       }
+    }
 }
 
 foreach_with_prefix l $lang {