Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* 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-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 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
* 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-27 14:41 gdb.c++ testsuite 2.1: try_catch.exp Michael Elizabeth Chastain
  -- strict thread matches above, loose matches on Subject: below --
2002-05-29  3:00 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