annotate tests/test-dup3.c @ 14350:4cf3b58aaf12

Don't interfere with a program's definition of __attribute__. * lib/argp.h (__attribute__): Remove definition. (_GL_ATTRIBUTE_FORMAT): New macro. (argp_error, __argp_error, argp_failure, __argp_failure): Use it. * lib/argp-fmtstream.h (__attribute__): Remove definition. (_GL_ATTRIBUTE_FORMAT): New macro. (__argp_fmtstream_printf, argp_fmtstream_printf): Use it. * lib/argp-help.c (hol_entry_long_iterate): Use __attribute__ only for GCC 3 or newer. * lib/error.h (__attribute__): Remove definition. (_GL_ATTRIBUTE_FORMAT): New macro. (error, error_at_line): Use it. * lib/hash.h (__attribute__): Remove definition. (ATTRIBUTE_WUR): Update definition. Define always. * lib/openat.h (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. * lib/sigpipe-die.h (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. * lib/vasnprintf.h (__attribute__): Remove definition. (_GL_ATTRIBUTE_FORMAT): New macro. (asnprintf, vasnprintf): Use it. * lib/xalloc.h (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. (ATTRIBUTE_MALLOC, ATTRIBUTE_ALLOC_SIZE): Define always. * lib/xmemdup0.h (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. * lib/xprintf.h (__attribute__): Remove definition. (_GL_ATTRIBUTE_FORMAT): New macro. (xprintf, xvprintf, xfprintf, xvfprintf): Use it. * lib/xstrtol.h (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. * lib/xvasprintf.h (__attribute__): Remove definition. (_GL_ATTRIBUTE_FORMAT): New macro. (xasprintf, xvasprintf): Use it. * tests/test-argmatch.c (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. * tests/test-exclude.c (__attribute__): Remove definition. (ATTRIBUTE_NORETURN): Update definition. Define always. Reported by Paul Eggert.
author Bruno Haible <bruno@clisp.org>
date Sun, 13 Feb 2011 23:21:20 +0100
parents 97fc9a21a8fb
children b86e9061a6d0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
1 /* Test duplicating file descriptors.
14079
97fc9a21a8fb maint: update almost all copyright ranges to include 2011
Jim Meyering <meyering@redhat.com>
parents: 13664
diff changeset
2 Copyright (C) 2009-2011 Free Software Foundation, Inc.
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
3
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
4 This program is free software: you can redistribute it and/or modify
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
6 the Free Software Foundation; either version 3 of the License, or
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
7 (at your option) any later version.
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
8
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
12 GNU General Public License for more details.
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
13
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
16
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
17 /* Written by Eric Blake <ebb9@byu.net>, 2009,
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
18 and Bruno Haible <bruno@clisp.org>, 2009. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
19
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
20 #include <config.h>
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
21
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
22 #include <unistd.h>
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
23
12489
33ab12a7cea2 tests: add signature checks
Eric Blake <ebb9@byu.net>
parents: 12421
diff changeset
24 #include "signature.h"
33ab12a7cea2 tests: add signature checks
Eric Blake <ebb9@byu.net>
parents: 12421
diff changeset
25 SIGNATURE_CHECK (dup3, int, (int, int, int));
33ab12a7cea2 tests: add signature checks
Eric Blake <ebb9@byu.net>
parents: 12421
diff changeset
26
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
27 #include <errno.h>
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
28 #include <fcntl.h>
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
29 #include <stdbool.h>
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
30
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
31 #if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
32 /* Get declarations of the Win32 API functions. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
33 # define WIN32_LEAN_AND_MEAN
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
34 # include <windows.h>
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
35 #endif
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
36
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
37 #include "binary-io.h"
12496
a48d3d749ca5 Refactor common macros used in tests.
Bruno Haible <bruno@clisp.org>
parents: 12489
diff changeset
38 #include "macros.h"
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
39
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
40 /* Return true if FD is open. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
41 static bool
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
42 is_open (int fd)
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
43 {
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
44 #if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
45 /* On Win32, the initial state of unassigned standard file
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
46 descriptors is that they are open but point to an
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
47 INVALID_HANDLE_VALUE, and there is no fcntl. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
48 return (HANDLE) _get_osfhandle (fd) != INVALID_HANDLE_VALUE;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
49 #else
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
50 # ifndef F_GETFL
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
51 # error Please port fcntl to your platform
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
52 # endif
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
53 return 0 <= fcntl (fd, F_GETFL);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
54 #endif
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
55 }
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
56
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
57 /* Return true if FD is not inherited to child processes. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
58 static bool
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
59 is_cloexec (int fd)
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
60 {
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
61 #if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
62 HANDLE h = (HANDLE) _get_osfhandle (fd);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
63 DWORD flags;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
64 ASSERT (GetHandleInformation (h, &flags));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
65 return (flags & HANDLE_FLAG_INHERIT) == 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
66 #else
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
67 int flags;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
68 ASSERT ((flags = fcntl (fd, F_GETFD)) >= 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
69 return (flags & FD_CLOEXEC) != 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
70 #endif
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
71 }
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
72
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
73 int
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
74 main ()
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
75 {
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
76 int use_cloexec;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
77
13664
241057e2e60f fcntl-h: define O_CLOEXEC and O_EXEC if not defined; use new defines
Paul Eggert <eggert@cs.ucla.edu>
parents: 12559
diff changeset
78 #if O_CLOEXEC
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
79 for (use_cloexec = 0; use_cloexec <= 1; use_cloexec++)
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
80 #else
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
81 use_cloexec = 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
82 #endif
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
83 {
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
84 const char *file = "test-dup3.tmp";
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
85 int fd = open (file, O_CREAT | O_TRUNC | O_RDWR, 0600);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
86 int o_flags;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
87 char buffer[1];
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
88
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
89 o_flags = 0;
13664
241057e2e60f fcntl-h: define O_CLOEXEC and O_EXEC if not defined; use new defines
Paul Eggert <eggert@cs.ucla.edu>
parents: 12559
diff changeset
90 #if O_CLOEXEC
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
91 if (use_cloexec)
12421
e8d2c6fc33ad Use spaces for indentation, not tabs.
Bruno Haible <bruno@clisp.org>
parents: 11887
diff changeset
92 o_flags |= O_CLOEXEC;
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
93 #endif
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
94
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
95 /* Assume std descriptors were provided by invoker. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
96 ASSERT (STDERR_FILENO < fd);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
97 ASSERT (is_open (fd));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
98 /* Ignore any other fd's leaked into this process. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
99 close (fd + 1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
100 close (fd + 2);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
101 ASSERT (!is_open (fd + 1));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
102 ASSERT (!is_open (fd + 2));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
103
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
104 /* Assigning to self is invalid. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
105 errno = 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
106 ASSERT (dup3 (fd, fd, o_flags) == -1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
107 ASSERT (errno == EINVAL);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
108 ASSERT (is_open (fd));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
109
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
110 /* If the source is not open, then the destination is unaffected. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
111 errno = 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
112 ASSERT (dup3 (fd + 1, fd + 2, o_flags) == -1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
113 ASSERT (errno == EBADF);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
114 ASSERT (!is_open (fd + 2));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
115 errno = 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
116 ASSERT (dup3 (fd + 1, fd, o_flags) == -1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
117 ASSERT (errno == EBADF);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
118 ASSERT (is_open (fd));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
119
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
120 /* The destination must be valid. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
121 errno = 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
122 ASSERT (dup3 (fd, -2, o_flags) == -1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
123 ASSERT (errno == EBADF);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
124 errno = 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
125 ASSERT (dup3 (fd, 10000000, o_flags) == -1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
126 ASSERT (errno == EBADF);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
127
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
128 /* Using dup3 can skip fds. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
129 ASSERT (dup3 (fd, fd + 2, o_flags) == fd + 2);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
130 ASSERT (is_open (fd));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
131 ASSERT (!is_open (fd + 1));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
132 ASSERT (is_open (fd + 2));
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
133 if (use_cloexec)
12421
e8d2c6fc33ad Use spaces for indentation, not tabs.
Bruno Haible <bruno@clisp.org>
parents: 11887
diff changeset
134 ASSERT (is_cloexec (fd + 2));
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
135 else
12421
e8d2c6fc33ad Use spaces for indentation, not tabs.
Bruno Haible <bruno@clisp.org>
parents: 11887
diff changeset
136 ASSERT (!is_cloexec (fd + 2));
11887
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
137
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
138 /* Verify that dup3 closes the previous occupant of a fd. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
139 ASSERT (open ("/dev/null", O_WRONLY, 0600) == fd + 1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
140 ASSERT (dup3 (fd + 1, fd, o_flags) == fd);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
141 ASSERT (close (fd + 1) == 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
142 ASSERT (write (fd, "1", 1) == 1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
143 ASSERT (dup3 (fd + 2, fd, o_flags) == fd);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
144 ASSERT (lseek (fd, 0, SEEK_END) == 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
145 ASSERT (write (fd + 2, "2", 1) == 1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
146 ASSERT (lseek (fd, 0, SEEK_SET) == 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
147 ASSERT (read (fd, buffer, 1) == 1);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
148 ASSERT (*buffer == '2');
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
149
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
150 /* Clean up. */
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
151 ASSERT (close (fd + 2) == 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
152 ASSERT (close (fd) == 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
153 ASSERT (unlink (file) == 0);
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
154 }
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
155
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
156 return 0;
ce99ebbf27a3 Tests for module 'dup3'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
157 }