2 Copyright (C) 2009-2020 Free Software Foundation, Inc.
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <https://www.gnu.org/licenses/>. */
17 /* Written by Eric Blake <ebb9@byu.net>, 2009. */
23 #include "signature.h"
24 SIGNATURE_CHECK (fchownat
, int, (int, char const *, uid_t
, gid_t
, int));
33 #include "mgetgroups.h"
35 #include "stat-time.h"
36 #include "ignore-value.h"
40 # define BASE "test-fchownat.t"
43 #include "test-chown.h"
44 #include "test-lchown.h"
46 static int dfd
= AT_FDCWD
;
48 /* Wrapper around fchownat to test chown behavior. */
50 do_chown (char const *name
, uid_t user
, gid_t group
)
53 return chownat (dfd
, name
, user
, group
);
55 return fchownat (dfd
, name
, user
, group
, 0);
59 /* Wrapper around fchownat to test lchown behavior. */
61 do_lchown (char const *name
, uid_t user
, gid_t group
)
64 return lchownat (dfd
, name
, user
, group
);
66 return fchownat (dfd
, name
, user
, group
, AT_SYMLINK_NOFOLLOW
);
71 main (int argc _GL_UNUSED
, char *argv
[])
73 int result1
; /* Skip because of no chown/symlink support. */
74 int result2
; /* Skip because of no lchown support. */
76 /* Clean up any trash from prior testsuite runs. */
77 ignore_value (system ("rm -rf " BASE
"*"));
79 /* Test behaviour for invalid file descriptors. */
82 ASSERT (fchownat (-1, "foo", getuid (), getgid (), 0) == -1);
83 ASSERT (errno
== EBADF
);
88 ASSERT (fchownat (99, "foo", getuid (), getgid (), 0) == -1);
89 ASSERT (errno
== EBADF
);
93 result1
= test_chown (do_chown
, true);
94 result2
= test_lchown (do_lchown
, result1
== 0);
95 dfd
= open (".", O_RDONLY
);
97 ASSERT (test_chown (do_chown
, false) == result1
);
98 ASSERT (test_lchown (do_lchown
, false) == result2
);
99 /* We expect 0/0, 0/77, or 77/77, but not 77/0. */
100 ASSERT (result1
<= result2
);
101 ASSERT (close (dfd
) == 0);
103 /* FIXME - add additional tests of dfd not at current directory. */
104 return result1
| result2
;