From: David Blaikie <dblaikie@gmail.com>
To: gdb-patches <gdb-patches@sourceware.org>
Subject: [patch] [gdb/testsuite] XFAIL under Clang tests using label debug info
Date: Sun, 13 Apr 2014 23:26:00 -0000 [thread overview]
Message-ID: <CAENS6EtFF4hPJe3uqJBkPf4q8c0n4RvV1_jO=6mWWEp=X2HbnA@mail.gmail.com> (raw)
[-- Attachment #1: Type: text/plain, Size: 464 bytes --]
Clang doesn't emit debug info for labels (Clang PR14500). XFAIL a
bunch of GDB tests that rely on debug info for labels.
For some reason gdb.linespec/ls-expr.exp gathered all tests into a
dictionary and then ran them. This made it hard to XFAIL just the
right tests. I refactored this to execute the tests directly, removing
the dictionary so I could XFAIL the right tests. Is there a reason it
would've been written that way? Does my patch break it in some way?
[-- Attachment #2: labels.diff --]
[-- Type: text/plain, Size: 9960 bytes --]
commit c438cb16b63292e415330f289616c4e4ecece63c
Author: David Blaikie <dblaikie@gmail.com>
Date: Sun Apr 13 11:42:02 2014 -0700
XFAIL under Clang tests using labels
gdb/testsuite/
* gdb.base/label.exp: XFAIL label related tests under Clang.
* gdb.cp/cplabel.exp: Ditto.
* gdb.linespec/ls-errs.exp: Refactor tests to execute directly
and XFAIL under Clang those using labels.
diff --git gdb/testsuite/ChangeLog gdb/testsuite/ChangeLog
index 730c116..b04b940 100644
--- gdb/testsuite/ChangeLog
+++ gdb/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2014-04-12 David Blaikie <dblaikie@gmail.com>
+
+ * gdb.base/label.exp: XFAIL label related tests under Clang.
+ * gdb.cp/cplabel.exp: Ditto.
+ * gdb.linespec/ls-errs.exp: Refactor tests to execute directly and XFAIL under Clang those using labels.
+
2014-04-12 Siva Chandra Reddy <sivachandra@google.com>
Doug Evans <xdje42@gmail.com>
diff --git gdb/testsuite/gdb.base/label.exp gdb/testsuite/gdb.base/label.exp
index 87f8623..3345a98 100644
--- gdb/testsuite/gdb.base/label.exp
+++ gdb/testsuite/gdb.base/label.exp
@@ -36,24 +36,29 @@ if {![runto_main]} {
return -1
}
+if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
gdb_test "break here" \
"Breakpoint.*at.*" \
"breakpoint here"
+if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
gdb_test "break main:there" \
"Breakpoint.*at.*" \
"breakpoint there"
+if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
gdb_test "cont" \
"Breakpoint 3,.*" \
"continue to 'there'"
+if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
gdb_test "cont" \
"Breakpoint 2,.*" \
"continue to 'here'"
rerun_to_main
+if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
gdb_test "cont" \
"Breakpoint 3,.*" \
"continue to 'there' after re-run"
diff --git gdb/testsuite/gdb.cp/cplabel.exp gdb/testsuite/gdb.cp/cplabel.exp
index a9cbfec..9c0e7fe 100644
--- gdb/testsuite/gdb.cp/cplabel.exp
+++ gdb/testsuite/gdb.cp/cplabel.exp
@@ -34,6 +34,7 @@ set labels {"to_the_top" "get_out_of_here"}
foreach m $methods {
foreach l $labels {
set line [gdb_get_line_number "$m:$l"]
+ if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
gdb_test "break foo::$m:$l" \
"Breakpoint $decimal at $hex: file .*$srcfile, line $line\."
}
diff --git gdb/testsuite/gdb.linespec/ls-errs.exp gdb/testsuite/gdb.linespec/ls-errs.exp
index dbff230..86056c5 100644
--- gdb/testsuite/gdb.linespec/ls-errs.exp
+++ gdb/testsuite/gdb.linespec/ls-errs.exp
@@ -28,16 +28,12 @@ gdb_test_no_output "set breakpoint pending off"
# We intentionally do not use gdb_breakpoint for these tests.
-# Add the (invalid) LINESPEC to the test array named in ARRAY_NAME.
-# Use the index into ::error_messages MSG_ID and ARGS to create
-# an error message which is the expect result of attempting to
-# break on the given LINESPEC.
-proc add {array_name linespec msg_id args} {
+# Break at 'linespec' and expect the message in ::error_messages indexed by
+# msg_id with the associated args.
+proc test_break {linespec msg_id args} {
global error_messages
- upvar $array_name tests
- lappend tests(linespecs) $linespec
- set tests("$linespec") [string_to_regexp \
+ gdb_test "break $linespec" [string_to_regexp \
[eval format \$error_messages($msg_id) $args]]
}
@@ -64,15 +60,9 @@ set spaces [list ":" ": " " :" " : " "\t: " " :\t" "\t:\t" " \t:\t " \
# A list of invalid offsets.
set invalid_offsets [list -100 +500 1000]
-# THE_TESTS will hold all of our test information. Array index
-# "linespecs" will contain the complete list of all linespecs
-# to be tested. An array index of \"$linespec\" will contain
-# the expected result.
-set the_tests(linespecs) {}
-
# Try some simple, invalid linespecs involving spaces.
foreach x $spaces {
- add the_tests $x unexpected "colon"
+ test_break $x unexpected "colon"
}
# Test invalid filespecs starting with offset. This is done
@@ -86,25 +76,25 @@ foreach x $invalid_offsets {
[string index $x 0] == "-"} {
incr offset 16
}
- add the_tests $x invalid_offset $offset
+ test_break $x invalid_offset $offset
}
# Test offsets with trailing tokens w/ and w/o spaces.
foreach x $spaces {
- add the_tests "3$x" unexpected "colon"
- add the_tests "+10$x" unexpected "colon"
- add the_tests "-10$x" unexpected "colon"
+ test_break "3$x" unexpected "colon"
+ test_break "+10$x" unexpected "colon"
+ test_break "-10$x" unexpected "colon"
}
foreach x {1 +1 +100 -10} {
- add the_tests "3 $x" unexpected_opt "number" $x
- add the_tests "+10 $x" unexpected_opt "number" $x
- add the_tests "-10 $x" unexpected_opt "number" $x
+ test_break "3 $x" unexpected_opt "number" $x
+ test_break "+10 $x" unexpected_opt "number" $x
+ test_break "-10 $x" unexpected_opt "number" $x
}
-add the_tests "3 foo" unexpected_opt "string" "foo"
-add the_tests "+10 foo" unexpected_opt "string" "foo"
-add the_tests "-10 foo" unexpected_opt "string" "foo"
+test_break "3 foo" unexpected_opt "string" "foo"
+test_break "+10 foo" unexpected_opt "string" "foo"
+test_break "-10 foo" unexpected_opt "string" "foo"
# Test invalid linespecs starting with filename.
foreach x [list "this_file_doesn't_exist.c" \
@@ -118,74 +108,70 @@ foreach x [list "this_file_doesn't_exist.c" \
"\"spaces: and :colons.c\"" \
"'more: :spaces: :and colons::.c'"] {
# Remove any quoting from FILENAME for the error message.
- add the_tests "$x:3" invalid_file [string trim $x \"']
+ test_break "$x:3" invalid_file [string trim $x \"']
}
# Test unmatched quotes.
foreach x {"\"src-file.c'" "'src-file.c"} {
- add the_tests "$x:3" unmatched_quote
+ test_break "$x:3" unmatched_quote
}
-add the_tests $srcfile invalid_function $srcfile
+test_break $srcfile invalid_function $srcfile
foreach x {"foo" " foo" " foo "} {
# Trim any leading/trailing whitespace for error messages.
- add the_tests "$srcfile:$x" invalid_function_f [string trim $x] $srcfile
- add the_tests "$srcfile:main:$x" invalid_label [string trim $x] "main"
+ test_break "$srcfile:$x" invalid_function_f [string trim $x] $srcfile
+ test_break "$srcfile:main:$x" invalid_label [string trim $x] "main"
}
foreach x $spaces {
- add the_tests "$srcfile$x" unexpected "end of input"
- add the_tests "$srcfile:main$x" unexpected "end of input"
+ test_break "$srcfile$x" unexpected "end of input"
+ test_break "$srcfile:main$x" unexpected "end of input"
}
-add the_tests "${srcfile}::" invalid_function "${srcfile}::"
-add the_tests "$srcfile:3 1" unexpected_opt "number" "1"
-add the_tests "$srcfile:3 +100" unexpected_opt "number" "+100"
-add the_tests "$srcfile:3 -100" unexpected_opt "number" "-100"
-add the_tests "$srcfile:3 foo" unexpected_opt "string" "foo"
+test_break "${srcfile}::" invalid_function "${srcfile}::"
+test_break "$srcfile:3 1" unexpected_opt "number" "1"
+test_break "$srcfile:3 +100" unexpected_opt "number" "+100"
+test_break "$srcfile:3 -100" unexpected_opt "number" "-100"
+test_break "$srcfile:3 foo" unexpected_opt "string" "foo"
foreach x $invalid_offsets {
- add the_tests "$srcfile:$x" invalid_offset_f $x $srcfile
- add the_tests "\"$srcfile:$x\"" invalid_offset_f $x $srcfile
- add the_tests "'$srcfile:$x'" invalid_offset_f $x $srcfile
+ test_break "$srcfile:$x" invalid_offset_f $x $srcfile
+ test_break "\"$srcfile:$x\"" invalid_offset_f $x $srcfile
+ test_break "'$srcfile:$x'" invalid_offset_f $x $srcfile
}
# Test invalid filespecs starting with function.
foreach x {"foobar" "foo::bar" "foo.bar" "foo ." "foo bar" "foo 1" \
"foo 0" "foo +10" "foo -10" "foo +100" "foo -100"} {
- add the_tests $x invalid_function $x
+ test_break $x invalid_function $x
}
foreach x $spaces {
- add the_tests "main${x}there" invalid_label "there" "main"
- add the_tests "main:here${x}" unexpected "end of input"
+ test_break "main${x}there" invalid_label "there" "main"
+ if {[test_compiler_info {clang-*-*}]} { setup_xfail clang/14500 *-*-* }
+ test_break "main:here${x}" unexpected "end of input"
}
-add the_tests "main 3" invalid_function "main 3"
-add the_tests "main +100" invalid_function "main +100"
-add the_tests "main -100" invalid_function "main -100"
-add the_tests "main foo" invalid_function "main foo"
+test_break "main 3" invalid_function "main 3"
+test_break "main +100" invalid_function "main +100"
+test_break "main -100" invalid_function "main -100"
+test_break "main foo" invalid_function "main foo"
foreach x {"3" "+100" "-100" "foo"} {
- add the_tests "main:here $x" invalid_label "here $x" "main"
+ test_break "main:here $x" invalid_label "here $x" "main"
}
foreach x {"if" "task" "thread"} {
- add the_tests $x invalid_function $x
+ test_break $x invalid_function $x
}
-add the_tests "'main.c'flubber" unexpected_opt "string" "flubber"
-add the_tests "'main.c',21" invalid_function "main.c"
-add the_tests "'main.c' " invalid_function "main.c"
-add the_tests "'main.c'3" unexpected_opt "number" "3"
-add the_tests "'main.c'+3" unexpected_opt "number" "+3"
+test_break "'main.c'flubber" unexpected_opt "string" "flubber"
+test_break "'main.c',21" invalid_function "main.c"
+test_break "'main.c' " invalid_function "main.c"
+test_break "'main.c'3" unexpected_opt "number" "3"
+test_break "'main.c'+3" unexpected_opt "number" "+3"
# Test undefined convenience variables.
set x {$zippo}
-add the_tests $x invalid_var_or_func $x
-add the_tests "$srcfile:$x" invalid_var_or_func_f $x $srcfile
-
-# Run the tests
-foreach linespec $the_tests(linespecs) {
- gdb_test "break $linespec" $the_tests("$linespec")
-}
+test_break $x invalid_var_or_func $x
+test_break "$srcfile:$x" invalid_var_or_func_f $x $srcfile
next reply other threads:[~2014-04-13 23:26 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-13 23:26 David Blaikie [this message]
2014-04-23 22:03 ` Doug Evans
2014-04-25 3:23 ` David Blaikie
2019-09-05 22:12 ` David Blaikie
2019-09-06 2:48 ` Christian Biesinger via gdb-patches
2019-09-06 4:17 ` Eric Christopher
2019-09-06 17:26 ` Christian Biesinger via gdb-patches
2019-09-06 20:23 ` David Blaikie
2019-09-06 20:25 ` Christian Biesinger via gdb-patches
[not found] ` <CADPb22Svrkdy6eOmcY2CxYAHfmaz_vRPE8sLDrujJCjbXCFMNg@mail.gmail.com>
2019-09-06 21:19 ` David Blaikie
2014-04-24 10:42 ` Pedro Alves
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='CAENS6EtFF4hPJe3uqJBkPf4q8c0n4RvV1_jO=6mWWEp=X2HbnA@mail.gmail.com' \
--to=dblaikie@gmail.com \
--cc=gdb-patches@sourceware.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox