Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element
@ 2005-06-10  8:45 Wu Zhou
  2005-06-13  2:55 ` Daniel Jacobowitz
  0 siblings, 1 reply; 5+ messages in thread
From: Wu Zhou @ 2005-06-10  8:45 UTC (permalink / raw)
  To: gdb-patches

Daniel and all,

This is the testcase associated with the following patch:

   http://sources.redhat.com/ml/gdb-patches/2005-06/msg00090.html	

Without the patch above, the last three tests fail. With the patch, all
tests pass.  It is tested on ppc64 with g77-3.3.3 and g77-3.4.3.

It is my first attempt to add a new testcase into GDB testsuite. So if 
there is any errors or missings, please feel free to tell me. Thanks a 
lot!

2005-06-10  Wu Zhou  <woodzltc@cn.ibm.com>

	* gdb.fortran/array_element.f: New file.
	* gdb.fortran/array_element.exp: New testcase.

array_element.f
======================================
        dimension a(10)
        write(*,*)'This is a test.'
        call sub(a,10)
        write(*,*) a
        stop
        end

        subroutine sub(a,n)
        dimension a(n)
        do 100 i=1, n 
          a(i)=i
100     continue
        return
        end

array_element.exp
=====================================
# Copyright 2005 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.  

# This file is part of the gdb testsuite.

if $tracelevel then {
	strace $tracelevel
}

#
# test running programs
#
set prms_id 0
set bug_id 0

set testfile "array_element"
set srcfile ${testfile}.f
set binfile ${objdir}/${subdir}/${testfile}

if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77}] != "" } {
    gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
}

if [get_compiler_info ${binfile} "f77"] {
    return -1
}

gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}

if ![runto sub_] then {
    perror "couldn't run to breakpoint"
    continue
}

set bp_location [gdb_get_line_number "continue"]
gdb_test "break $bp_location" \
    "Breakpoint.*at.* file .*$srcfile, line $bp_location\\." \
    "brealpoint at continue"

gdb_test "continue" \
    "Continuing\\..*Breakpoint.*" \
    "continue to breakpoint"
gdb_test "print a(1)" "= 1.*" "print the first element of array a"

gdb_test "continue" \
    "Continuing\\..*Breakpoint.*" \
    "continue to breakpoint once again"
gdb_test "print a(2)" "= 2.*" "print the first element of array a"


gdb_exit
return 0


Cheers
- Wu Zhou


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element
  2005-06-10  8:45 [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element Wu Zhou
@ 2005-06-13  2:55 ` Daniel Jacobowitz
  2005-06-15  5:29   ` Wu Zhou
  0 siblings, 1 reply; 5+ messages in thread
From: Daniel Jacobowitz @ 2005-06-13  2:55 UTC (permalink / raw)
  To: Wu Zhou; +Cc: gdb-patches

On Fri, Jun 10, 2005 at 04:41:02PM +0800, Wu Zhou wrote:
> Daniel and all,
> 
> This is the testcase associated with the following patch:
> 
>    http://sources.redhat.com/ml/gdb-patches/2005-06/msg00090.html	
> 
> Without the patch above, the last three tests fail. With the patch, all
> tests pass.  It is tested on ppc64 with g77-3.3.3 and g77-3.4.3.
> 
> It is my first attempt to add a new testcase into GDB testsuite. So if 
> there is any errors or missings, please feel free to tell me. Thanks a 
> lot!

Thanks.  It does need some changes, but not big ones.

I'd appreciated it if you could provide new files as diffs.  The normal
way to do this is by diffing them against /dev/null, with the
appropriate relative path to the new file.  That way, I can save your
message and apply it as a patch.

Let's use hyphens instead of underscores in file names; there's already
a lot of hyphenated test cases.  So array-element.exp.

> array_element.f
> ======================================

We're trying to add copyright notices to all new tests; please add one
here.

>         dimension a(10)
>         write(*,*)'This is a test.'
>         call sub(a,10)
>         write(*,*) a
>         stop
>         end
> 
>         subroutine sub(a,n)
>         dimension a(n)
>         do 100 i=1, n 
>           a(i)=i
> 100     continue
>         return
>         end
> 


> array_element.exp
> =====================================

> if $tracelevel then {
> 	strace $tracelevel
> }
> 
> #
> # test running programs
> #
> set prms_id 0
> set bug_id 0

This bit is not necessary.

> set testfile "array_element"
> set srcfile ${testfile}.f
> set binfile ${objdir}/${subdir}/${testfile}
> 
> if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77}] != "" } {
>     gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
> }

Please don't use gdb_suppress_entire_file; use "untested" and then
"return".  See the Java tests for an example.  You can see what will
happen when no Fortran compiler is installed by running
"runtest array-element.exp F77_FOR_TARGET=false"; compare with
"runtest jprint.exp GCJ_UNDER_TEST=false".

You can get the right result by also adding "quiet" to the last
argument of gdb_compile, and using untested/return.

> if [get_compiler_info ${binfile} "f77"] {
>     return -1
> }

What's this needed for?  Also, get_compiler_info does not take a second
argument.

> gdb_exit
> gdb_start
> gdb_reinitialize_dir $srcdir/$subdir
> gdb_load ${binfile}
> 
> if ![runto sub_] then {
>     perror "couldn't run to breakpoint"
>     continue
> }
> 
> set bp_location [gdb_get_line_number "continue"]
> gdb_test "break $bp_location" \
>     "Breakpoint.*at.* file .*$srcfile, line $bp_location\\." \
>     "brealpoint at continue"

Typo there.

> gdb_test "continue" \
>     "Continuing\\..*Breakpoint.*" \
>     "continue to breakpoint"
> gdb_test "print a(1)" "= 1.*" "print the first element of array a"
> 
> gdb_test "continue" \
>     "Continuing\\..*Breakpoint.*" \
>     "continue to breakpoint once again"
> gdb_test "print a(2)" "= 2.*" "print the first element of array a"

> gdb_exit
> return 0

This bit isn't actually necessary.

-- 
Daniel Jacobowitz
CodeSourcery, LLC


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element
  2005-06-13  2:55 ` Daniel Jacobowitz
@ 2005-06-15  5:29   ` Wu Zhou
  2005-06-17  1:48     ` Daniel Jacobowitz
  0 siblings, 1 reply; 5+ messages in thread
From: Wu Zhou @ 2005-06-15  5:29 UTC (permalink / raw)
  To: gdb-patches

Hi Daniel,

Thanks a lot for pointing out these problems.  The re-worked patch is as 
follows.  I had tested it on g77-3.2.3 (on Fedora Core 4 for i386), 
g77-3.3.3 and g77-3.4.3 (on SLES9 and RHEL4 for ppc64).  Please review and 
comment.  Thanks!

array-element.f
====================================================
*** /dev/null	2005-06-14 07:40:50.585435768 +0800
--- gdb.fortran/array-element.f	2005-06-15 11:30:20.000000000 +0800
***************
*** 0 ****
--- 1,32 ----
+ c Copyright 2005 Free Software Foundation, Inc.
+ 
+ c This program is free software; you can redistribute it and/or modify
+ c it under the terms of the GNU General Public License as published by
+ c the Free Software Foundation; either version 2 of the License, or
+ c (at your option) any later version.
+ c 
+ c This program is distributed in the hope that it will be useful,
+ c but WITHOUT ANY WARRANTY; without even the implied warranty of
+ c MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ c GNU General Public License for more details.
+ c 
+ c You should have received a copy of the GNU General Public License
+ c along with this program; if not, write to the Free Software
+ c Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  
+ 
+ c This file is the F77 source for array-element.exp.  It was written
+ c by Wu Zhou. (woodzltc@cn.ibm.com)
+ 
+         dimension a(10)
+         call sub(a,10)
+         write(*,*) a
+         stop
+         end
+ 
+         subroutine sub(a,n)
+         dimension a(n)
+         do 100 i = 1, n 
+           a(i) = i
+ 100     continue
+         return
+         end

array-element.exp
=====================================================
*** /dev/null	2005-06-14 07:40:50.585435768 +0800
--- gdb.fortran/array-element.exp	2005-06-15 11:32:26.000000000 +0800
***************
*** 0 ****
--- 1,60 ----
+ # Copyright 2005 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.  
+ 
+ # This file was written by Wu Zhou. (woodzltc@cn.ibm.com)
+ 
+ # This file is part of the gdb testsuite.  It contains test for printing
+ # the elements of an array which is passed as pointer to a subroutine.
+ 
+ if $tracelevel then {
+ 	strace $tracelevel
+ }
+ 
+ set testfile "array-element"
+ set srcfile ${testfile}.f
+ set binfile ${objdir}/${subdir}/${testfile}
+ 
+ if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77}] != "" } {
+     untested "Couldn't compile ${srcfile}"
+     return -1
+ }
+ 
+ gdb_exit
+ gdb_start
+ gdb_reinitialize_dir $srcdir/$subdir
+ gdb_load ${binfile}
+ 
+ if ![runto sub_] then {
+     perror "couldn't run to breakpoint sub_"
+     continue
+ }
+ 
+ set bp_location [gdb_get_line_number "continue"]
+ gdb_test "break $bp_location" \
+     "Breakpoint.*at.* file .*$srcfile, line $bp_location\\." \
+     "breakpoint at continue"
+ 
+ # Run to continue for the first time and print a(1)
+ gdb_test "continue" \
+     "Continuing\\..*Breakpoint.*" \
+     "continue to breakpoint"
+ gdb_test "print a(1)" ".*1 = 1.*" "print the first element of array a"
+ 
+ # Run to continue for the second time and print a(2)
+ gdb_test "continue" \
+     "Continuing\\..*Breakpoint.*" \
+     "continue to breakpoint once again"
+ gdb_test "print a(2)" ".*2 = 2.*" "print the second element of array a"

Cheers
- Wu Zhou

> Thanks.  It does need some changes, but not big ones.
> 
> I'd appreciated it if you could provide new files as diffs.  The normal
> way to do this is by diffing them against /dev/null, with the
> appropriate relative path to the new file.  That way, I can save your
> message and apply it as a patch.
> 
> Let's use hyphens instead of underscores in file names; there's already
> a lot of hyphenated test cases.  So array-element.exp.
> 


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element
  2005-06-15  5:29   ` Wu Zhou
@ 2005-06-17  1:48     ` Daniel Jacobowitz
  2005-06-17  5:26       ` Wu Zhou
  0 siblings, 1 reply; 5+ messages in thread
From: Daniel Jacobowitz @ 2005-06-17  1:48 UTC (permalink / raw)
  To: Wu Zhou; +Cc: gdb-patches

On Wed, Jun 15, 2005 at 11:39:14AM +0800, Wu Zhou wrote:
> + if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77}] != "" } {
> +     untested "Couldn't compile ${srcfile}"
> +     return -1
> + }

Please use {debug f77 quiet} to be nice to people without an F77
compiler.  Otherwise, this is OK.


-- 
Daniel Jacobowitz
CodeSourcery, LLC


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element
  2005-06-17  1:48     ` Daniel Jacobowitz
@ 2005-06-17  5:26       ` Wu Zhou
  0 siblings, 0 replies; 5+ messages in thread
From: Wu Zhou @ 2005-06-17  5:26 UTC (permalink / raw)
  To: gdb-patches

On Thu, 16 Jun 2005, Daniel Jacobowitz wrote:

> On Wed, Jun 15, 2005 at 11:39:14AM +0800, Wu Zhou wrote:
> > + if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77}] != "" } {
> > +     untested "Couldn't compile ${srcfile}"
> > +     return -1
> > + }
> 
> Please use {debug f77 quiet} to be nice to people without an F77
> compiler.  Otherwise, this is OK.

OK.  Patch is commited after adding the "quiet" option.  Thanks.

Cheers
- Wu Zhou


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2005-06-17  5:26 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-06-10  8:45 [RFC]: Add test for verifying the fix to the SEGV error when printing F77 array element Wu Zhou
2005-06-13  2:55 ` Daniel Jacobowitz
2005-06-15  5:29   ` Wu Zhou
2005-06-17  1:48     ` Daniel Jacobowitz
2005-06-17  5:26       ` Wu Zhou

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox