2009-05-01 23:50:11 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
# Verify that the credentials are changed correctly.
|
|
|
|
|
|
2026-01-01 10:56:16 -08:00
|
|
|
# Copyright (C) 2009-2026 Free Software Foundation, Inc.
|
2009-05-01 23:50:11 +02:00
|
|
|
|
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
# (at your option) any later version.
|
|
|
|
|
|
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
# You should have received a copy of the GNU General Public License
|
2017-09-19 01:13:23 -07:00
|
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2009-05-01 23:50:11 +02:00
|
|
|
|
|
|
|
|
|
2012-09-02 21:55:12 +02:00
|
|
|
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
|
2010-11-17 21:35:31 +01:00
|
|
|
print_ver_ chroot
|
2009-05-01 23:50:11 +02:00
|
|
|
|
|
|
|
|
require_root_
|
|
|
|
|
|
2015-01-13 03:30:33 +00:00
|
|
|
EXIT_CANCELED=125
|
|
|
|
|
|
2014-03-03 01:54:36 +00:00
|
|
|
grep '^#define HAVE_SETGROUPS 1' "$CONFIG_HEADER" >/dev/null \
|
|
|
|
|
&& HAVE_SETGROUPS=1
|
|
|
|
|
|
|
|
|
|
root=$(id -nu 0) || skip_ "Couldn't look up root username"
|
2009-05-01 23:50:11 +02:00
|
|
|
|
2014-05-16 09:50:24 +01:00
|
|
|
# verify numeric IDs looked up similarly to names
|
|
|
|
|
NON_ROOT_UID=$(id -u $NON_ROOT_USERNAME)
|
2014-06-26 12:41:01 +01:00
|
|
|
NON_ROOT_GROUP=$NON_ROOT_GID # Used where we want name lookups to occur
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# "uid:" is supported (unlike chown etc.) since we treat it like "uid"
|
|
|
|
|
chroot --userspec=$NON_ROOT_UID: / true || fail=1
|
|
|
|
|
|
|
|
|
|
# verify that invalid groups are diagnosed
|
|
|
|
|
for g in ' ' ',' '0trail'; do
|
2015-01-13 03:30:33 +00:00
|
|
|
returns_ $EXIT_CANCELED chroot --groups="$g" / id -G >invalid || fail=1
|
|
|
|
|
compare /dev/null invalid || fail=1
|
2014-05-16 09:50:24 +01:00
|
|
|
done
|
|
|
|
|
|
2009-05-01 23:50:11 +02:00
|
|
|
# Verify that root credentials are kept.
|
2013-09-22 03:59:58 +01:00
|
|
|
test $(chroot / whoami) = "$root" || fail=1
|
2009-05-01 23:50:11 +02:00
|
|
|
test "$(groups)" = "$(chroot / groups)" || fail=1
|
|
|
|
|
|
|
|
|
|
# Verify that credentials are changed correctly.
|
coreutils: keep lines within 80-column limits
* cfg.mk (LINE_LEN_MAX, FILTER_LONG_LINES): New macros.
(sc_long_lines): New rule.
* HACKING: Use shorter URLs to the same material.
* doc/Makefile.am, doc/coreutils.texi, m4/boottime.m4:
* man/help2man, man/stdbuf.x, src/Makefile.am, src/cat.c, src/copy.c:
* src/cp.c, src/dd.c, src/df.c, src/du.c, src/groups.c, src/install.c:
* src/ls.c, src/md5sum.c, src/mv.c, src/od.c, src/pinky.c, src/ptx.c:
* src/readlink.c, src/remove.c, src/rmdir.c, src/setuidgid.c:
* src/sort.c, src/tail.c, src/touch.c, tests/Coreutils.pm:
* tests/cp/existing-perm-race, tests/cp/perm, tests/cp/preserve-gid:
* tests/du/2g, tests/du/long-from-unreadable, tests/init.sh:
* tests/install/basic-1, tests/ls/nameless-uid:
* tests/ls/readdir-mountpoint-inode, tests/misc/chroot-credentials:
* tests/misc/cut, tests/misc/date, tests/misc/join, tests/misc/md5sum:
* tests/misc/sha1sum, tests/misc/sha224sum, tests/misc/sort:
* tests/misc/sort-continue, tests/misc/sort-files0-from:
* tests/misc/sort-rand, tests/misc/stdbuf, tests/misc/tr:
* tests/misc/uniq, tests/mv/atomic, tests/mv/part-fail:
* tests/mv/part-symlink, tests/mv/sticky-to-xpart, tests/pr/pr-tests:
* tests/rm/fail-2eperm, tests/rm/interactive-always:
Reformat to fit within 80 columns.
* doc/Makefile.am (BAD_POSIX_PERL): New macro.
* doc/coreutils.texi: Reword slightly, to make menus and
index lines shorter.
* src/md5sum.c: Redo --help output so that it fits within 79
columns, since that's a bit more portable and all the other --help
strings fit in 79 columns.
2010-12-28 12:28:48 -08:00
|
|
|
whoami_after_chroot=$(
|
|
|
|
|
chroot --userspec=$NON_ROOT_USERNAME:$NON_ROOT_GROUP / whoami
|
|
|
|
|
)
|
2013-09-22 03:59:58 +01:00
|
|
|
test "$whoami_after_chroot" != "$root" || fail=1
|
2009-05-01 23:50:11 +02:00
|
|
|
|
2014-05-16 09:50:24 +01:00
|
|
|
# Verify that when specifying only a group we don't change the
|
|
|
|
|
# list of supplemental groups
|
|
|
|
|
test "$(chroot --userspec=:$NON_ROOT_GROUP / id -G)" = \
|
|
|
|
|
"$NON_ROOT_GID $(id -G)" || fail=1
|
|
|
|
|
|
|
|
|
|
if ! test "$HAVE_SETGROUPS"; then
|
|
|
|
|
Exit $fail
|
2014-03-03 01:54:36 +00:00
|
|
|
fi
|
2009-05-01 23:50:11 +02:00
|
|
|
|
2018-10-20 02:00:11 +02:00
|
|
|
# Change all whitespaces to newlines, then sort the input.
|
|
|
|
|
# Use for tests with more groups in 'id' output.
|
|
|
|
|
num_sort() { tr -s ' ' '\n' | sort -n; }
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# Verify that there are no additional groups.
|
|
|
|
|
id_G_after_chroot=$(
|
|
|
|
|
chroot --userspec=$NON_ROOT_USERNAME:$NON_ROOT_GROUP \
|
|
|
|
|
--groups=$NON_ROOT_GROUP / id -G
|
|
|
|
|
)
|
2014-06-26 12:41:01 +01:00
|
|
|
test "$id_G_after_chroot" = $NON_ROOT_GID || fail=1
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# Verify that when specifying only the user name we get all their groups
|
2018-10-20 02:00:11 +02:00
|
|
|
test "$(chroot --userspec=$NON_ROOT_USERNAME / id -G | num_sort)" = \
|
|
|
|
|
"$(id -G $NON_ROOT_USERNAME | num_sort)" || fail=1
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# Ditto with trailing : on the user name.
|
2018-10-20 02:00:11 +02:00
|
|
|
test "$(chroot --userspec=$NON_ROOT_USERNAME: / id -G | num_sort)" = \
|
|
|
|
|
"$(id -G $NON_ROOT_USERNAME | num_sort)" || fail=1
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# Verify that when specifying only the user and clearing supplemental groups
|
|
|
|
|
# that we only get the primary group
|
|
|
|
|
test "$(chroot --userspec=$NON_ROOT_USERNAME --groups='' / id -G)" = \
|
2014-06-26 12:41:01 +01:00
|
|
|
$NON_ROOT_GID || fail=1
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# Verify that when specifying only the UID we get all their groups
|
2018-10-20 02:00:11 +02:00
|
|
|
test "$(chroot --userspec=$NON_ROOT_UID / id -G | num_sort)" = \
|
|
|
|
|
"$(id -G $NON_ROOT_USERNAME | num_sort)" || fail=1
|
2014-05-16 09:50:24 +01:00
|
|
|
|
|
|
|
|
# Verify that when specifying only the user and clearing supplemental groups
|
|
|
|
|
# that we only get the primary group. Note this variant with prepended '+'
|
|
|
|
|
# results in no lookups in the name database which could be useful depending
|
|
|
|
|
# on your chroot setup.
|
|
|
|
|
test "$(chroot --userspec=+$NON_ROOT_UID:+$NON_ROOT_GID --groups='' / id -G)" =\
|
2014-06-26 12:41:01 +01:00
|
|
|
$NON_ROOT_GID || fail=1
|
2009-05-27 23:06:15 +02:00
|
|
|
|
|
|
|
|
# Verify that when specifying only a group we get the current user ID
|
|
|
|
|
test "$(chroot --userspec=:$NON_ROOT_GROUP / id -u)" = "$(id -u)" \
|
2014-03-03 01:54:36 +00:00
|
|
|
|| fail=1
|
|
|
|
|
|
2014-05-16 09:50:24 +01:00
|
|
|
# verify that arbitrary numeric IDs are supported
|
|
|
|
|
test "$(chroot --userspec=1234:+5678 --groups=' +8765,4321' / id -G)" \
|
|
|
|
|
|| fail=1
|
2014-03-03 01:54:36 +00:00
|
|
|
|
2014-05-16 09:50:24 +01:00
|
|
|
# demonstrate that extraneous commas are supported
|
|
|
|
|
test "$(chroot --userspec=1234:+5678 --groups=',8765,,4321,' / id -G)" \
|
|
|
|
|
|| fail=1
|
|
|
|
|
|
|
|
|
|
# demonstrate that --groups is not cumulative
|
|
|
|
|
test "$(chroot --groups='invalid ignored' --groups='' / id -G)" \
|
|
|
|
|
|| fail=1
|
2014-03-03 01:54:36 +00:00
|
|
|
|
2014-05-16 09:50:24 +01:00
|
|
|
if ! id -u +12342; then
|
|
|
|
|
# Ensure supplemental groups cleared from some arbitrary unknown ID
|
|
|
|
|
test "$(chroot --userspec=+12342:+5678 / id -G)" = '5678' || fail=1
|
2014-03-03 01:54:36 +00:00
|
|
|
|
2014-05-16 09:50:24 +01:00
|
|
|
# Ensure we fail when we don't know what groups to set for an unknown ID
|
2015-01-13 03:30:33 +00:00
|
|
|
returns_ $EXIT_CANCELED chroot --userspec=+12342 / true || fail=1
|
2014-03-03 01:54:36 +00:00
|
|
|
fi
|
2009-05-27 23:06:15 +02:00
|
|
|
|
2009-05-01 23:50:11 +02:00
|
|
|
Exit $fail
|