annotate tests/test-fdutimensat.c @ 12496:a48d3d749ca5

Refactor common macros used in tests.
author Bruno Haible <bruno@clisp.org>
date Thu, 24 Dec 2009 21:01:42 +0100
parents e45d9bb2233e
children 013b270a78b9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
12193
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
1 /* Tests of fdutimensat.
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
2 Copyright (C) 2009 Free Software Foundation, Inc.
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
3
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
4 This program is free software: you can redistribute it and/or modify
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
6 the Free Software Foundation; either version 3 of the License, or
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
7 (at your option) any later version.
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
8
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
12 GNU General Public License for more details.
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
13
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
16
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
17 /* Written by Eric Blake <ebb9@byu.net>, 2009. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
18
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
19 #include <config.h>
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
20
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
21 #include "utimens.h"
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
22
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
23 #include <fcntl.h>
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
24 #include <stdbool.h>
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
25 #include <stdio.h>
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
26 #include <stdlib.h>
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
27
12496
a48d3d749ca5 Refactor common macros used in tests.
Bruno Haible <bruno@clisp.org>
parents: 12197
diff changeset
28 #include "macros.h"
12193
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
29
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
30 #define BASE "test-fdutimensat.t"
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
31
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
32 #include "test-futimens.h"
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
33 #include "test-lutimens.h"
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
34 #include "test-utimens.h"
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
35
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
36 static int dfd = AT_FDCWD;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
37
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
38 /* Wrap fdutimensat to behave like futimens. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
39 static int
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
40 do_futimens (int fd, struct timespec const times[2])
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
41 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
42 return fdutimensat (dfd, NULL, fd, times);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
43 }
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
44
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
45 /* Test the use of file descriptors alongside a name. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
46 static int
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
47 do_fdutimens (char const *name, struct timespec const times[2])
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
48 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
49 int result;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
50 int fd = openat (dfd, name, O_WRONLY);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
51 if (fd < 0)
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
52 fd = openat (dfd, name, O_RDONLY);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
53 errno = 0;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
54 result = fdutimensat (dfd, name, fd, times);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
55 if (0 <= fd)
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
56 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
57 int saved_errno = errno;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
58 close (fd);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
59 errno = saved_errno;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
60 }
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
61 return result;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
62 }
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
63
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
64 /* Wrap lutimensat to behave like lutimens. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
65 static int
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
66 do_lutimens (const char *name, struct timespec const times[2])
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
67 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
68 return lutimensat (dfd, name, times);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
69 }
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
70
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
71 /* Wrap fdutimensat to behave like utimens. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
72 static int
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
73 do_utimens (const char *name, struct timespec const times[2])
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
74 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
75 return fdutimensat (dfd, name, -1, times);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
76 }
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
77
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
78 int
12197
e45d9bb2233e tests: avoid several compiler warnings
Eric Blake <ebb9@byu.net>
parents: 12193
diff changeset
79 main (void)
12193
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
80 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
81 int result1; /* Skip because of no symlink support. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
82 int result2; /* Skip because of no futimens support. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
83 int result3; /* Skip because of no lutimens support. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
84 int fd;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
85
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
86 /* Clean up any trash from prior testsuite runs. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
87 ASSERT (system ("rm -rf " BASE "*") == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
88
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
89 /* Basic tests. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
90 result1 = test_utimens (do_utimens, true);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
91 ASSERT (test_utimens (do_fdutimens, false) == result1);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
92 result2 = test_futimens (do_futimens, result1 == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
93 result3 = test_lutimens (do_lutimens, (result1 + result2) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
94 /* We expect 0/0, 0/77, or 77/77, but not 77/0. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
95 ASSERT (result1 <= result3);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
96 dfd = open (".", O_RDONLY);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
97 ASSERT (0 <= dfd);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
98 ASSERT (test_utimens (do_utimens, false) == result1);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
99 ASSERT (test_utimens (do_fdutimens, false) == result1);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
100 ASSERT (test_futimens (do_futimens, false) == result2);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
101 ASSERT (test_lutimens (do_lutimens, false) == result3);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
102
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
103 /* Directory relative tests. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
104 ASSERT (mkdir (BASE "dir", 0700) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
105 ASSERT (chdir (BASE "dir") == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
106 fd = creat ("file", 0600);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
107 ASSERT (0 <= fd);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
108 errno = 0;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
109 ASSERT (fdutimensat (fd, ".", AT_FDCWD, NULL) == -1);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
110 ASSERT (errno == ENOTDIR);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
111 {
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
112 struct timespec ts[2] = { { Y2K, 0 }, { Y2K, 0 } };
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
113 struct stat st;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
114 ASSERT (fdutimensat (dfd, BASE "dir/file", fd, ts) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
115 ASSERT (stat ("file", &st) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
116 ASSERT (st.st_atime == Y2K);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
117 ASSERT (get_stat_atime_ns (&st) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
118 ASSERT (st.st_mtime == Y2K);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
119 ASSERT (get_stat_mtime_ns (&st) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
120 }
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
121 ASSERT (close (fd) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
122 ASSERT (close (dfd) == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
123 errno = 0;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
124 ASSERT (fdutimensat (dfd, ".", -1, NULL) == -1);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
125 ASSERT (errno == EBADF);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
126
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
127 /* Cleanup. */
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
128 ASSERT (chdir ("..") == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
129 ASSERT (unlink (BASE "dir/file") == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
130 ASSERT (rmdir (BASE "dir") == 0);
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
131 return result1 | result2 | result3;
d1ea4269ac6f fdutimensat: new module
Eric Blake <ebb9@byu.net>
parents:
diff changeset
132 }