PR inline-asm/84742
[official-gcc.git] / gcc / testsuite / gfortran.dg / chmod_2.f90
blob176879dfb1399ee1e6ad1b5efad54591440472d9
1 ! { dg-do run { target { ! { *-*-mingw* *-*-cygwin* spu-*-* } } } }
2 ! { dg-options "-std=gnu" }
3 ! See PR38956. Test fails on cygwin when user has Administrator rights
4 implicit none
5 character(len=*), parameter :: n = "foobar_file_chmod_2"
6 integer :: i
8 open (10,file=n)
9 close (10,status="delete")
11 open (10,file=n)
12 close (10,status="keep")
14 if (access(n,"") /= 0 .or. access(n," ") /= 0 .or. access(n,"r") /= 0 .or. &
15 access(n,"R") /= 0 .or. access(n,"w") /= 0 .or. access(n,"W") /= 0) &
16 STOP 1
18 i = chmod (n, "a+x")
19 if (i == 0) then
20 if (access(n,"x") /= 0 .or. access(n,"X") /= 0) STOP 2
21 end if
23 i = chmod (n, "a-w")
24 if (i == 0 .and. getuid() /= 0) then
25 if (access(n,"w") == 0 .or. access(n,"W") == 0) STOP 3
26 end if
28 open (10,file=n)
29 close (10,status="delete")
31 if (access(n,"") == 0 .or. access(n," ") == 0 .or. access(n,"r") == 0 .or. &
32 access(n,"R") == 0 .or. access(n,"w") == 0 .or. access(n,"W") == 0) &
33 STOP 4
35 end