2020-03-04 10:35:06 +01:00
|
|
|
#!/usr/bin/env bash
|
2018-01-24 11:18:46 +01:00
|
|
|
set -e
|
|
|
|
TEST_DESCRIPTION="Sysuser-related tests"
|
|
|
|
|
|
|
|
. $TEST_BASE_DIR/test-functions
|
|
|
|
|
|
|
|
test_setup() {
|
scripts: use 4 space indentation
We had all kinds of indentation: 2 sp, 3 sp, 4 sp, 8 sp, and mixed.
4 sp was the most common, in particular the majority of scripts under test/
used that. Let's standarize on 4 sp, because many commandlines are long and
there's a lot of nesting, and with 8sp indentation less stuff fits. 4 sp
also seems to be the default indentation, so this will make it less likely
that people will mess up if they don't load the editor config. (I think people
often use vi, and vi has no support to load project-wide configuration
automatically. We distribute a .vimrc file, but it is not loaded by default,
and even the instructions in it seem to discourage its use for security
reasons.)
Also remove the few vim config lines that were left. We should either have them
on all files, or none.
Also remove some strange stuff like '#!/bin/env bash', yikes.
2019-04-04 14:10:42 +02:00
|
|
|
mkdir -p $TESTDIR/etc/sysusers.d $TESTDIR/usr/lib/sysusers.d $TESTDIR/tmp
|
2018-01-24 11:18:46 +01:00
|
|
|
}
|
|
|
|
|
2018-03-15 13:39:38 +01:00
|
|
|
prepare_testdir() {
|
scripts: use 4 space indentation
We had all kinds of indentation: 2 sp, 3 sp, 4 sp, 8 sp, and mixed.
4 sp was the most common, in particular the majority of scripts under test/
used that. Let's standarize on 4 sp, because many commandlines are long and
there's a lot of nesting, and with 8sp indentation less stuff fits. 4 sp
also seems to be the default indentation, so this will make it less likely
that people will mess up if they don't load the editor config. (I think people
often use vi, and vi has no support to load project-wide configuration
automatically. We distribute a .vimrc file, but it is not loaded by default,
and even the instructions in it seem to discourage its use for security
reasons.)
Also remove the few vim config lines that were left. We should either have them
on all files, or none.
Also remove some strange stuff like '#!/bin/env bash', yikes.
2019-04-04 14:10:42 +02:00
|
|
|
rm -f $TESTDIR/etc/*{passwd,group,shadow}
|
|
|
|
for i in $1.initial-{passwd,group,shadow}; do
|
|
|
|
test -f $i && cp $i $TESTDIR/etc/${i#*.initial-}
|
|
|
|
done
|
|
|
|
return 0
|
2018-03-15 13:39:38 +01:00
|
|
|
}
|
|
|
|
|
2018-02-01 05:47:50 +01:00
|
|
|
preprocess() {
|
|
|
|
in="$1"
|
|
|
|
|
|
|
|
# see meson.build how to extract this. gcc -E was used before to
|
|
|
|
# get this value from config.h, however the autopkgtest fails with
|
|
|
|
# it
|
|
|
|
SYSTEM_UID_MAX=$(awk 'BEGIN { uid=999 } /^\s*SYS_UID_MAX\s+/ { uid=$2 } END { print uid }' /etc/login.defs)
|
2020-01-30 20:04:14 +01:00
|
|
|
SYSTEM_GID_MAX=$(awk 'BEGIN { gid=999 } /^\s*SYS_GID_MAX\s+/ { gid=$2 } END { print gid }' /etc/login.defs)
|
2019-07-18 01:24:00 +02:00
|
|
|
|
|
|
|
# we can't rely on config.h to get the nologin path, as autopkgtest
|
|
|
|
# uses pre-compiled binaries, so extract it from the systemd-sysusers
|
|
|
|
# binary which we are about to execute
|
|
|
|
NOLOGIN=$(strings $(type -p systemd-sysusers) | grep nologin)
|
|
|
|
|
|
|
|
sed -e "s/SYSTEM_UID_MAX/${SYSTEM_UID_MAX}/g" \
|
2020-01-30 20:04:14 +01:00
|
|
|
-e "s/SYSTEM_GID_MAX/${SYSTEM_GID_MAX}/g" \
|
2019-07-18 01:24:00 +02:00
|
|
|
-e "s#NOLOGIN#${NOLOGIN}#g" "$in"
|
2018-02-01 05:47:50 +01:00
|
|
|
}
|
|
|
|
|
2018-02-02 08:53:47 +01:00
|
|
|
compare() {
|
|
|
|
if ! diff -u $TESTDIR/etc/passwd <(preprocess ${1%.*}.expected-passwd); then
|
scripts: use 4 space indentation
We had all kinds of indentation: 2 sp, 3 sp, 4 sp, 8 sp, and mixed.
4 sp was the most common, in particular the majority of scripts under test/
used that. Let's standarize on 4 sp, because many commandlines are long and
there's a lot of nesting, and with 8sp indentation less stuff fits. 4 sp
also seems to be the default indentation, so this will make it less likely
that people will mess up if they don't load the editor config. (I think people
often use vi, and vi has no support to load project-wide configuration
automatically. We distribute a .vimrc file, but it is not loaded by default,
and even the instructions in it seem to discourage its use for security
reasons.)
Also remove the few vim config lines that were left. We should either have them
on all files, or none.
Also remove some strange stuff like '#!/bin/env bash', yikes.
2019-04-04 14:10:42 +02:00
|
|
|
echo "**** Unexpected output for $f"
|
|
|
|
exit 1
|
2018-02-02 08:53:47 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
if ! diff -u $TESTDIR/etc/group <(preprocess ${1%.*}.expected-group); then
|
scripts: use 4 space indentation
We had all kinds of indentation: 2 sp, 3 sp, 4 sp, 8 sp, and mixed.
4 sp was the most common, in particular the majority of scripts under test/
used that. Let's standarize on 4 sp, because many commandlines are long and
there's a lot of nesting, and with 8sp indentation less stuff fits. 4 sp
also seems to be the default indentation, so this will make it less likely
that people will mess up if they don't load the editor config. (I think people
often use vi, and vi has no support to load project-wide configuration
automatically. We distribute a .vimrc file, but it is not loaded by default,
and even the instructions in it seem to discourage its use for security
reasons.)
Also remove the few vim config lines that were left. We should either have them
on all files, or none.
Also remove some strange stuff like '#!/bin/env bash', yikes.
2019-04-04 14:10:42 +02:00
|
|
|
echo "**** Unexpected output for $f $2"
|
|
|
|
exit 1
|
2018-02-02 08:53:47 +01:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2018-01-24 11:18:46 +01:00
|
|
|
test_run() {
|
scripts: use 4 space indentation
We had all kinds of indentation: 2 sp, 3 sp, 4 sp, 8 sp, and mixed.
4 sp was the most common, in particular the majority of scripts under test/
used that. Let's standarize on 4 sp, because many commandlines are long and
there's a lot of nesting, and with 8sp indentation less stuff fits. 4 sp
also seems to be the default indentation, so this will make it less likely
that people will mess up if they don't load the editor config. (I think people
often use vi, and vi has no support to load project-wide configuration
automatically. We distribute a .vimrc file, but it is not loaded by default,
and even the instructions in it seem to discourage its use for security
reasons.)
Also remove the few vim config lines that were left. We should either have them
on all files, or none.
Also remove some strange stuff like '#!/bin/env bash', yikes.
2019-04-04 14:10:42 +02:00
|
|
|
# ensure our build of systemd-sysusers is run
|
|
|
|
PATH=${BUILD_DIR}:$PATH
|
|
|
|
|
|
|
|
rm -f $TESTDIR/etc/sysusers.d/* $TESTDIR/usr/lib/sysusers.d/*
|
|
|
|
|
|
|
|
# happy tests
|
|
|
|
for f in test-*.input; do
|
|
|
|
echo "*** Running $f"
|
|
|
|
prepare_testdir ${f%.input}
|
|
|
|
cp $f $TESTDIR/usr/lib/sysusers.d/test.conf
|
|
|
|
systemd-sysusers --root=$TESTDIR
|
|
|
|
|
|
|
|
compare $f ""
|
|
|
|
done
|
|
|
|
|
|
|
|
for f in test-*.input; do
|
|
|
|
echo "*** Running $f on stdin"
|
|
|
|
prepare_testdir ${f%.input}
|
|
|
|
touch $TESTDIR/etc/sysusers.d/test.conf
|
|
|
|
cat $f | systemd-sysusers --root=$TESTDIR -
|
|
|
|
|
|
|
|
compare $f "on stdin"
|
|
|
|
done
|
|
|
|
|
|
|
|
for f in test-*.input; do
|
|
|
|
echo "*** Running $f on stdin with --replace"
|
|
|
|
prepare_testdir ${f%.input}
|
|
|
|
touch $TESTDIR/etc/sysusers.d/test.conf
|
|
|
|
# this overrides test.conf which is masked on disk
|
|
|
|
cat $f | systemd-sysusers --root=$TESTDIR --replace=/etc/sysusers.d/test.conf -
|
|
|
|
# this should be ignored
|
|
|
|
cat test-1.input | systemd-sysusers --root=$TESTDIR --replace=/usr/lib/sysusers.d/test.conf -
|
|
|
|
|
|
|
|
compare $f "on stdin with --replace"
|
|
|
|
done
|
|
|
|
|
|
|
|
# test --inline
|
|
|
|
echo "*** Testing --inline"
|
|
|
|
prepare_testdir
|
|
|
|
# copy a random file to make sure it is ignored
|
|
|
|
cp $f $TESTDIR/etc/sysusers.d/confuse.conf
|
|
|
|
systemd-sysusers --root=$TESTDIR --inline \
|
|
|
|
"u u1 222 - - /bin/zsh" \
|
|
|
|
"g g1 111"
|
|
|
|
|
|
|
|
compare inline "(--inline)"
|
|
|
|
|
|
|
|
# test --replace
|
|
|
|
echo "*** Testing --inline with --replace"
|
|
|
|
prepare_testdir
|
|
|
|
# copy a random file to make sure it is ignored
|
|
|
|
cp $f $TESTDIR/etc/sysusers.d/confuse.conf
|
|
|
|
systemd-sysusers --root=$TESTDIR \
|
|
|
|
--inline \
|
|
|
|
--replace=/etc/sysusers.d/confuse.conf \
|
|
|
|
"u u1 222 - - /bin/zsh" \
|
|
|
|
"g g1 111"
|
|
|
|
|
|
|
|
compare inline "(--inline --replace=…)"
|
|
|
|
|
|
|
|
rm -f $TESTDIR/etc/sysusers.d/* $TESTDIR/usr/lib/sysusers.d/*
|
|
|
|
|
|
|
|
# tests for error conditions
|
|
|
|
for f in unhappy-*.input; do
|
|
|
|
echo "*** Running test $f"
|
|
|
|
prepare_testdir ${f%.input}
|
|
|
|
cp $f $TESTDIR/usr/lib/sysusers.d/test.conf
|
|
|
|
systemd-sysusers --root=$TESTDIR 2> /dev/null
|
2020-01-28 02:45:17 +01:00
|
|
|
journalctl --sync
|
scripts: use 4 space indentation
We had all kinds of indentation: 2 sp, 3 sp, 4 sp, 8 sp, and mixed.
4 sp was the most common, in particular the majority of scripts under test/
used that. Let's standarize on 4 sp, because many commandlines are long and
there's a lot of nesting, and with 8sp indentation less stuff fits. 4 sp
also seems to be the default indentation, so this will make it less likely
that people will mess up if they don't load the editor config. (I think people
often use vi, and vi has no support to load project-wide configuration
automatically. We distribute a .vimrc file, but it is not loaded by default,
and even the instructions in it seem to discourage its use for security
reasons.)
Also remove the few vim config lines that were left. We should either have them
on all files, or none.
Also remove some strange stuff like '#!/bin/env bash', yikes.
2019-04-04 14:10:42 +02:00
|
|
|
journalctl -t systemd-sysusers -o cat | tail -n1 > $TESTDIR/tmp/err
|
|
|
|
if ! diff -u $TESTDIR/tmp/err ${f%.*}.expected-err; then
|
|
|
|
echo "**** Unexpected error output for $f"
|
|
|
|
cat $TESTDIR/tmp/err
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
done
|
2018-01-24 11:18:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
do_test "$@"
|