aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>2010-03-01 12:25:34 +0000
committerRainer Orth <ro@gcc.gnu.org>2010-03-01 12:25:34 +0000
commit1069f584a7256529d7f5637939118994effd865a (patch)
tree5ffe7c3cd480fb2665ff821f869281c68d03de1a /gcc
parent894e2652e19f83190daab172efb846d568fb5e11 (diff)
downloadgcc-1069f584a7256529d7f5637939118994effd865a.zip
gcc-1069f584a7256529d7f5637939118994effd865a.tar.gz
gcc-1069f584a7256529d7f5637939118994effd865a.tar.bz2
re PR fortran/42900 (gfortran.dg/stat_[12].f90 may fail on NFS filesystems)
PR fortran/42900 * gfortran.dg/stat_1.f90: Accept 'testfile' gid == parent dir gid. Explain this. * gfortran.dg/stat_2.f90: Likewise. From-SVN: r157135
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gfortran.dg/stat_1.f9010
-rw-r--r--gcc/testsuite/gfortran.dg/stat_2.f9010
3 files changed, 21 insertions, 6 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 4bb68cc..ab52ef5 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2010-03-01 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ PR fortran/42900
+ * gfortran.dg/stat_1.f90: Accept 'testfile' gid == parent dir gid.
+ Explain this.
+ * gfortran.dg/stat_2.f90: Likewise.
+
2010-03-01 Tobias Burnus <burnus@net-b.de>
PR fortran/43199
diff --git a/gcc/testsuite/gfortran.dg/stat_1.f90 b/gcc/testsuite/gfortran.dg/stat_1.f90
index f3c185a..95ad66a 100644
--- a/gcc/testsuite/gfortran.dg/stat_1.f90
+++ b/gcc/testsuite/gfortran.dg/stat_1.f90
@@ -2,7 +2,7 @@
! { dg-skip-if "" { *-*-mingw* spu-*-* } { "*" } { "" } }
! { dg-options "-std=gnu" }
character(len=*), parameter :: f = "testfile"
- integer :: s1(13), r1, s2(13), r2, s3(13), r3
+ integer :: s1(13), r1, s2(13), r2, s3(13), r3, d(13), rd
open (10,file=f)
write (10,"(A)") "foo"
@@ -12,11 +12,15 @@
call lstat (f, s1, r1)
call stat (f, s2, r2)
call fstat (10, s3, r3)
+ call stat (".", d, rd)
- if (r1 /= 0 .or. r2 /= 0 .or. r3 /= 0) call abort
+ if (r1 /= 0 .or. r2 /= 0 .or. r3 /= 0 .or. rd /= 0) call abort
if (any (s1 /= s2) .or. any (s1 /= s3)) call abort
if (s1(5) /= getuid()) call abort
- if (s1(6) /= getgid() .and. getgid() /= 0) call abort
+! If the test is run in a directory with the sgid bit set or on a filesystem
+! mounted with the grpid option, new files are created with the directory's
+! gid instead of the user's primary gid, so allow for that.
+ if (s1(6) /= getgid() .and. s1(6) /= d(6) .and. getgid() /= 0) call abort
if (s1(8) < 3 .or. s1(8) > 5) call abort
close (10,status="delete")
diff --git a/gcc/testsuite/gfortran.dg/stat_2.f90 b/gcc/testsuite/gfortran.dg/stat_2.f90
index 3c4b252..a530ec3 100644
--- a/gcc/testsuite/gfortran.dg/stat_2.f90
+++ b/gcc/testsuite/gfortran.dg/stat_2.f90
@@ -2,7 +2,7 @@
! { dg-skip-if "" { *-*-mingw* spu-*-* } { "*" } { "" } }
! { dg-options "-std=gnu" }
character(len=*), parameter :: f = "testfile"
- integer :: s1(13), r1, s2(13), r2, s3(13), r3
+ integer :: s1(13), r1, s2(13), r2, s3(13), r3, d(13), rd
open (10,file=f)
write (10,"(A)") "foo"
@@ -12,11 +12,15 @@
r1 = lstat (f, s1)
r2 = stat (f, s2)
r3 = fstat (10, s3)
+ rd = stat (".", d)
- if (r1 /= 0 .or. r2 /= 0 .or. r3 /= 0) call abort
+ if (r1 /= 0 .or. r2 /= 0 .or. r3 /= 0 .or. rd /= 0) call abort
if (any (s1 /= s2) .or. any (s1 /= s3)) call abort
if (s1(5) /= getuid()) call abort
- if (s1(6) /= getgid() .and. getgid() /= 0) call abort
+! If the test is run in a directory with the sgid bit set or on a filesystem
+! mounted with the grpid option, new files are created with the directory's
+! gid instead of the user's primary gid, so allow for that.
+ if (s1(6) /= getgid() .and. s1(6) /= d(6) .and. getgid() /= 0) call abort
if (s1(8) < 3 .or. s1(8) > 5) call abort
close (10,status="delete")