b999d48941
We're losing the svn history (which we could probably keep if we tried hard enough) but don't consider that worthwhile. Note these tests are destructive, so run them only in a throwaway environment like a chroot, container, or vm. The tests/run.all script should be the one which launches all the tests. Signed-off-by: Serge Hallyn <serge.hallyn@ubuntu.com>
62 lines
1.6 KiB
Bash
Executable File
62 lines
1.6 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
set -e
|
|
|
|
cd $(dirname $0)
|
|
|
|
. ../../../common/config.sh
|
|
. ../../../common/log.sh
|
|
|
|
log_start "$0" "useradd can list defaults from a chroot"
|
|
|
|
save_config
|
|
|
|
# restore the files on exit
|
|
trap 'log_status "$0" "FAILURE"; clean_chroot; restore_config' 0
|
|
|
|
change_config
|
|
|
|
prepare_chroot
|
|
|
|
echo -n "List defaults in chroot (useradd --root $PWD/tmp/root foo)..."
|
|
useradd -D --root $PWD/tmp/root > tmp/useradd.out
|
|
echo "OK"
|
|
|
|
echo "useradd reported:"
|
|
echo "======================================================================="
|
|
cat tmp/useradd.out
|
|
echo "======================================================================="
|
|
echo -n "Check the usage message..."
|
|
diff -au data/useradd.out tmp/useradd.out
|
|
echo "OK."
|
|
rm -f tmp/useradd.out
|
|
|
|
echo -n "Check the passwd file..."
|
|
../../../common/compare_file.pl config/etc/passwd /etc/passwd
|
|
../../../common/compare_file.pl config_chroot/etc/passwd tmp/root/etc/passwd
|
|
echo "OK"
|
|
echo -n "Check the group file..."
|
|
../../../common/compare_file.pl config/etc/group /etc/group
|
|
../../../common/compare_file.pl config_chroot/etc//group tmp/root/etc/group
|
|
echo "OK"
|
|
echo -n "Check the shadow file..."
|
|
../../../common/compare_file.pl config/etc/shadow /etc/shadow
|
|
../../../common/compare_file.pl config_chroot/etc/shadow tmp/root/etc/shadow
|
|
echo "OK"
|
|
echo -n "Check the gshadow file..."
|
|
../../../common/compare_file.pl config/etc/gshadow /etc/gshadow
|
|
../../../common/compare_file.pl config_chroot/etc/gshadow tmp/root/etc/gshadow
|
|
echo "OK"
|
|
|
|
rm -f tmp/root/etc/.pwd.lock
|
|
rm -f tmp/root/etc/passwd-
|
|
rm -f tmp/root/etc/group-
|
|
rm -f tmp/root/etc/shadow-
|
|
rm -f tmp/root/etc/gshadow-
|
|
clean_chroot
|
|
|
|
log_status "$0" "SUCCESS"
|
|
restore_config
|
|
trap '' 0
|
|
|