* Re: gdb.c++ testsuite 2.1: try_catch.exp
@ 2002-05-29 3:00 Michael Elizabeth Chastain
0 siblings, 0 replies; 7+ messages in thread
From: Michael Elizabeth Chastain @ 2002-05-29 3:00 UTC (permalink / raw)
To: ac131313, bkoz; +Cc: gdb-patches
Andrew Cagney writes:
> Try it using HP'x C++ compiler. The re-vamped mechanism came in as part
> of the HP merge so should have at least worked there.
I'm not sure if there is a spot of confusion here. The new try_catch.exp test
PASSes all its tests with all the compilers I tested (g++ v2 and g++ v3).
In the long run, I'd like to get access to an hpux machine for my testing
project, but that's not even on my TODO list yet.
Michael C
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: gdb.c++ testsuite 2.1: try_catch.exp
@ 2002-05-27 14:41 Michael Elizabeth Chastain
0 siblings, 0 replies; 7+ messages in thread
From: Michael Elizabeth Chastain @ 2002-05-27 14:41 UTC (permalink / raw)
To: bkoz, gdb-patches
Committed.
Next, I will do member_data.exp and member_data_static.exp.
Michael C
2002-05-27 Michael Chastain <mec@shout.net>
From Benjamin Kosnik <bkoz@redhat.com>
* gdb.c++/try_catch.cc: New file.
* gdb.c++/try_catch.exp: New file.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: gdb.c++ testsuite 2.1: try_catch.exp
@ 2002-05-27 12:34 Michael Elizabeth Chastain
2002-05-28 8:59 ` Benjamin Kosnik
0 siblings, 1 reply; 7+ messages in thread
From: Michael Elizabeth Chastain @ 2002-05-27 12:34 UTC (permalink / raw)
To: bkoz, gdb-patches
There was a cut-and-paste error here (line 122 versus line 118):
send_gdb "break 122\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 118\\.\r\n$gdb_prompt $" {
...
I rewrote all the send_gdb/gdb_expect pairs to gdb_test.
This simplifies the test script a lot:
gdb_test "break 61" "Breakpoint \[0-9\]*.*line 61\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:61\r\n.*" "continue to 61"
As a side note, all test names within a test script must be unique to
facilitate comparing test runs against each other. That's why gdb_test
"continue" has a third argument, so that I don't get a bunch of tests
all named "continue". Your original script does this correctly; I'm
just mentioning it.
The actual tests are very simple. They don't test any of the try/catch
functionality in gdb, just the control flow of the target program.
A simple test is better than no test; someone can add more tests to
this later.
All the tests pass in all the configurations that I tested:
target = native
host = i686-pc-linux-gnu%rh-7.2
gdb = 5.2, gdb_5_2-branch%20020526, HEAD
gcc = 2.95.3, 2.96-rh, 3.0.4, 3.1, gcc-3_1-branch%20020526, HEAD%20020526
glibc = vendor
goption = -gdwarf2, -gstabs+
I build all my gcc's with --disable-shared. So if there is a bug with
shared gcc libraries, then I won't see it.
Here is the revised version of try_catch.exp. I will commit this shortly.
Michael C
===
# Copyright 2002 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Tests for member data
# 2002-05-27 Benjamin Kosnik <bkoz@redhat.com>
# This file is part of the gdb testsuite
if $tracelevel then {
strace $tracelevel
}
if { [skip_cplus_tests] } { continue }
#
# test running programs
#
set prms_id 0
set bug_id 0
set testfile "try_catch"
set srcfile ${testfile}.cc
set binfile ${objdir}/${subdir}/${testfile}
if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug c++}] != "" } {
gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
}
if [get_compiler_info ${binfile} "c++"] {
return -1
}
gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}
if ![runto_main] then {
perror "couldn't run to breakpoint"
continue
}
# One.
gdb_test "break 61" "Breakpoint \[0-9\]*.*line 61\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:61\r\n.*" "continue to 61"
gdb_test "break 66" "Breakpoint \[0-9\]*.*line 66\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:66\r\n.*" "continue to 66"
gdb_test "break 80" "Breakpoint \[0-9\]*.*line 80\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:80\r\n.*" "continue to 80"
gdb_test "break 83" "Breakpoint \[0-9\]*.*line 83\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:83\r\n.*" "continue to 83"
gdb_test "break 87" "Breakpoint \[0-9\]*.*line 87\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:87\r\n.*" "continue to 87"
gdb_test "break 92" "Breakpoint \[0-9\]*.*line 92\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:92\r\n.*" "continue to 92"
gdb_test "break 118" "Breakpoint \[0-9\]*.*line 118\\."
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:118\r\n.*" "continue to 118"
gdb_test "break 122" "Breakpoint \[0-9\]*.*line 122\\."
gdb_test "continue\n" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:122\r\n.*" "continue to 122"
gdb_exit
return 0
^ permalink raw reply [flat|nested] 7+ messages in thread* Re: gdb.c++ testsuite 2.1: try_catch.exp
2002-05-27 12:34 Michael Elizabeth Chastain
@ 2002-05-28 8:59 ` Benjamin Kosnik
2002-05-28 18:05 ` Andrew Cagney
0 siblings, 1 reply; 7+ messages in thread
From: Benjamin Kosnik @ 2002-05-28 8:59 UTC (permalink / raw)
To: Michael Elizabeth Chastain; +Cc: gdb-patches
> There was a cut-and-paste error here (line 122 versus line 118):
>
> send_gdb "break 122\n"
> gdb_expect {
> -re "Breakpoint \[0-9\]*.*line 118\\.\r\n$gdb_prompt $" {
> ...
>
> I rewrote all the send_gdb/gdb_expect pairs to gdb_test.
> This simplifies the test script a lot:
>
> gdb_test "break 61" "Breakpoint \[0-9\]*.*line 61\\."
> gdb_test "continue"
> "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:61\r\n.*"
> "continue to 61"
Looks good, thanks for your additions.
> The actual tests are very simple. They don't test any of the
> try/catch functionality in gdb, just the control flow of the target
> program. A simple test is better than no test; someone can add more
> tests to this later.
Right. Actually, this has not worked in the past, so I thought it'd be
best to start with the basics.
> All the tests pass in all the configurations that I tested:
Great.
^ permalink raw reply [flat|nested] 7+ messages in thread* Re: gdb.c++ testsuite 2.1: try_catch.exp
2002-05-28 8:59 ` Benjamin Kosnik
@ 2002-05-28 18:05 ` Andrew Cagney
2002-05-28 18:49 ` Daniel Jacobowitz
0 siblings, 1 reply; 7+ messages in thread
From: Andrew Cagney @ 2002-05-28 18:05 UTC (permalink / raw)
To: bkoz; +Cc: Michael Elizabeth Chastain, gdb-patches
> The actual tests are very simple. They don't test any of the
>> try/catch functionality in gdb, just the control flow of the target
>> program. A simple test is better than no test; someone can add more
>> tests to this later.
>
>
> Right. Actually, this has not worked in the past, so I thought it'd be
> best to start with the basics.
Try it using HP'x C++ compiler. The re-vamped mechanism came in as part
of the HP merge so should have at least worked there.
enjoy,
Andrew
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: gdb.c++ testsuite 2.1: try_catch.exp
2002-05-28 18:05 ` Andrew Cagney
@ 2002-05-28 18:49 ` Daniel Jacobowitz
0 siblings, 0 replies; 7+ messages in thread
From: Daniel Jacobowitz @ 2002-05-28 18:49 UTC (permalink / raw)
To: Andrew Cagney; +Cc: bkoz, Michael Elizabeth Chastain, gdb-patches
On Tue, May 28, 2002 at 06:58:06PM -0400, Andrew Cagney wrote:
> >The actual tests are very simple. They don't test any of the
> >>try/catch functionality in gdb, just the control flow of the target
> >>program. A simple test is better than no test; someone can add more
> >>tests to this later.
> >
> >
> >Right. Actually, this has not worked in the past, so I thought it'd be
> >best to start with the basics.
>
> Try it using HP'x C++ compiler. The re-vamped mechanism came in as part
> of the HP merge so should have at least worked there.
If anything still works there. No one's tested aCC for quite a long
time now, and I still haven't found access to a version of HP/UX that
has aCC and GDB can handle.
--
Daniel Jacobowitz Carnegie Mellon University
MontaVista Software Debian GNU/Linux Developer
^ permalink raw reply [flat|nested] 7+ messages in thread
* gdb.c++ testsuite 2.1: try_catch.exp
@ 2002-05-27 6:20 Benjamin Kosnik
0 siblings, 0 replies; 7+ messages in thread
From: Benjamin Kosnik @ 2002-05-27 6:20 UTC (permalink / raw)
To: gdb-patches, mec
tested x86/linux. This test also current fails for shared builds,
although stepping through it with the static binary seems fine.
-benjamin
-----
# Copyright 2002 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Tests for member data
# 2002-05-27 Benjamin Kosnik <bkoz@redhat.com>
# This file is part of the gdb testsuite
if $tracelevel then {
strace $tracelevel
}
if { [skip_cplus_tests] } { continue }
#
# test running programs
#
set prms_id 0
set bug_id 0
set testfile "try_catch"
set srcfile ${testfile}.cc
set binfile ${objdir}/${subdir}/${testfile}
if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug c++}] != "" } {
gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
}
if [get_compiler_info ${binfile} "c++"] {
return -1
}
gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}
if ![runto_main] then {
perror "couldn't run to breakpoint"
continue
}
# One.
send_gdb "break 61\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 61\\.\r\n$gdb_prompt $" {
pass "set break at 61"
}
-re ".*$gdb_prompt $" { fail "set break at 61" }
timeout { fail "(timeout) set break at 61" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:61\r\n.*$gdb_prompt $" {
pass "continue to 61"
}
-re ".*$gdb_prompt $" { fail "continue to 61" }
timeout { fail "(timeout) continue to 61" }
}
send_gdb "break 66\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 66\\.\r\n$gdb_prompt $" {
pass "set break at 66"
}
-re ".*$gdb_prompt $" { fail "set break at 66" }
timeout { fail "(timeout) set break at 66" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:66\r\n.*$gdb_prompt $" {
pass "continue to 66"
}
-re ".*$gdb_prompt $" { fail "continue to 66" }
timeout { fail "(timeout) continue to 66" }
}
send_gdb "break 80\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 80\\.\r\n$gdb_prompt $" {
pass "set break at 80"
}
-re ".*$gdb_prompt $" { fail "set break at 80" }
timeout { fail "(timeout) set break at 80" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:80\r\n.*$gdb_prompt $" {
pass "continue to 80"
}
-re ".*$gdb_prompt $" { fail "continue to 80" }
timeout { fail "(timeout) continue to 80" }
}
send_gdb "break 83\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 83\\.\r\n$gdb_prompt $" {
pass "set break at 83"
}
-re ".*$gdb_prompt $" { fail "set break at 83" }
timeout { fail "(timeout) set break at 83" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:83\r\n.*$gdb_prompt $" {
pass "continue to 83"
}
-re ".*$gdb_prompt $" { fail "continue to 83" }
timeout { fail "(timeout) continue to 83" }
}
send_gdb "break 87\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 87\\.\r\n$gdb_prompt $" {
pass "set break at 87"
}
-re ".*$gdb_prompt $" { fail "set break at 87" }
timeout { fail "(timeout) set break at 87" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:87\r\n.*$gdb_prompt $" {
pass "continue to 87"
}
-re ".*$gdb_prompt $" { fail "continue to 87" }
timeout { fail "(timeout) continue to 87" }
}
send_gdb "break 92\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 92\\.\r\n$gdb_prompt $" {
pass "set break at 92"
}
-re ".*$gdb_prompt $" { fail "set break at 92" }
timeout { fail "(timeout) set break at 92" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:92\r\n.*$gdb_prompt $" {
pass "continue to 92"
}
-re ".*$gdb_prompt $" { fail "continue to 92" }
timeout { fail "(timeout) continue to 92" }
}
send_gdb "break 118\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 118\\.\r\n$gdb_prompt $" {
pass "set break at 118"
}
-re ".*$gdb_prompt $" { fail "set break at 118" }
timeout { fail "(timeout) set break at 118" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:118\r\n.*$gdb_prompt $" {
pass "continue to 118"
}
-re ".*$gdb_prompt $" { fail "continue to 118" }
timeout { fail "(timeout) continue to 118" }
}
send_gdb "break 122\n"
gdb_expect {
-re "Breakpoint \[0-9\]*.*line 118\\.\r\n$gdb_prompt $" {
pass "set break at 122"
}
-re ".*$gdb_prompt $" { fail "set break at 122" }
timeout { fail "(timeout) set break at 122" }
}
send_gdb "continue\n"
gdb_expect {
-re "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:122\r\n.*$gdb_prompt $" {
pass "continue to 122"
}
-re ".*$gdb_prompt $" { fail "continue to 122" }
timeout { fail "(timeout) continue to 122" }
}
gdb_exit
return 0
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2002-05-29 3:14 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2002-05-29 3:00 gdb.c++ testsuite 2.1: try_catch.exp Michael Elizabeth Chastain
-- strict thread matches above, loose matches on Subject: below --
2002-05-27 14:41 Michael Elizabeth Chastain
2002-05-27 12:34 Michael Elizabeth Chastain
2002-05-28 8:59 ` Benjamin Kosnik
2002-05-28 18:05 ` Andrew Cagney
2002-05-28 18:49 ` Daniel Jacobowitz
2002-05-27 6:20 Benjamin Kosnik
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox