2 Copyright (C) 2000-2018 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
4 Contributed by Ulrich Drepper <drepper@cygnus.com>, 2000.
6 The GNU C Library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with the GNU C Library; if not, see
18 <http://www.gnu.org/licenses/>. */
28 /* Prototype for our test function. */
29 extern void do_prepare (int argc
, char *argv
[]);
30 extern int do_test (int argc
, char *argv
[]);
32 /* We have a preparation function. */
33 #define PREPARE do_prepare
35 #include "../test-skeleton.c"
38 /* Name of the temporary files. */
41 /* File descriptor to temporary file. */
45 do_prepare (int argc
, char *argv
[])
49 name_len
= strlen (test_dir
);
50 name
= xmalloc (name_len
+ sizeof ("/fcntlXXXXXX"));
51 mempcpy (mempcpy (name
, test_dir
, name_len
),
52 "/fcntlXXXXXX", sizeof ("/fcntlXXXXXX"));
53 /* Create the temporary file. */
57 printf ("cannot open temporary file: %m\n");
65 do_test (int argc
, char *argv
[])
73 if (fstat64 (fd
, &st
) != 0)
75 printf ("cannot stat test file: %m\n");
78 if (! S_ISREG (st
.st_mode
) || st
.st_size
!= 0)
80 puts ("file not created correctly");
84 /* Get the flags with fcntl(). */
85 val
= fcntl (fd
, F_GETFL
);
88 printf ("fcntl(fd, F_GETFL) failed: %m\n");
91 else if ((val
& O_ACCMODE
) != O_RDWR
)
93 puts ("temporary file not opened for read and write");
97 /* Set the flags to something else. */
98 if (fcntl (fd
, F_SETFL
, O_RDONLY
) == -1)
100 printf ("fcntl(fd, F_SETFL, O_RDONLY) failed: %m\n");
104 val
= fcntl (fd
, F_GETFL
);
107 printf ("fcntl(fd, F_GETFL) after F_SETFL failed: %m\n");
110 else if ((val
& O_ACCMODE
) != O_RDWR
)
112 puts ("temporary file access mode changed");
116 /* Set the flags to something else. */
117 if (fcntl (fd
, F_SETFL
, O_APPEND
) == -1)
119 printf ("fcntl(fd, F_SETFL, O_APPEND) failed: %m\n");
123 val
= fcntl (fd
, F_GETFL
);
126 printf ("fcntl(fd, F_GETFL) after second F_SETFL failed: %m\n");
129 else if ((val
& O_APPEND
) == 0)
131 puts ("O_APPEND not set");
135 val
= fcntl (fd
, F_GETFD
);
138 printf ("fcntl(fd, F_GETFD) failed: %m\n");
141 else if (fcntl (fd
, F_SETFD
, val
| FD_CLOEXEC
) == -1)
143 printf ("fcntl(fd, F_SETFD, FD_CLOEXEC) failed: %m\n");
148 val
= fcntl (fd
, F_GETFD
);
151 printf ("fcntl(fd, F_GETFD) after F_SETFD failed: %m\n");
154 else if ((val
& FD_CLOEXEC
) == 0)
156 puts ("FD_CLOEXEC not set");
161 /* Get a number of a free descriptor. If /dev/null is not available
162 don't continue testing. */
163 fd2
= open (_PATH_DEVNULL
, O_RDWR
);
168 fd3
= fcntl (fd
, F_DUPFD
, fd2
+ 1);
171 printf ("fcntl(fd, F_DUPFD, %d) failed: %m\n", fd2
+ 1);
176 printf ("F_DUPFD returned %d which is not larger than %d\n", fd3
, fd2
);
182 val
= fcntl (fd3
, F_GETFD
);
185 printf ("fcntl(fd3, F_GETFD) after F_DUPFD failed: %m\n");
188 else if ((val
& FD_CLOEXEC
) != 0)
190 puts ("FD_CLOEXEC still set");