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>
55 lines
1.3 KiB
Bash
Executable File
55 lines
1.3 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
set -e
|
|
|
|
cd $(dirname $0)
|
|
|
|
. ../../../common/config.sh
|
|
. ../../../common/log.sh
|
|
|
|
log_start "$0" "gpasswd -M fails if an user does not exist"
|
|
|
|
save_config
|
|
|
|
# restore the files on exit
|
|
trap 'log_status "$0" "FAILURE"; restore_config' 0
|
|
|
|
change_config
|
|
|
|
echo -n "Set members of users to root,foooo,bin (gpasswd -M root,foooo,bin users)..."
|
|
gpasswd -M root,foooo,bin users 2>tmp/gpasswd.err && exit 1 || {
|
|
status=$?
|
|
}
|
|
echo "OK"
|
|
|
|
echo -n "Check returned status ($status)..."
|
|
test "$status" = "3" # E_BAD_ARG
|
|
echo "OK"
|
|
|
|
echo "gpasswd reported:"
|
|
echo "======================================================================="
|
|
cat tmp/gpasswd.err
|
|
echo "======================================================================="
|
|
echo -n "Check that there were a failure message..."
|
|
diff -au data/gpasswd.err tmp/gpasswd.err
|
|
echo "error message OK."
|
|
rm -f tmp/gpasswd.err
|
|
|
|
echo -n "Check the passwd file..."
|
|
../../../common/compare_file.pl config/etc/passwd /etc/passwd
|
|
echo "OK"
|
|
echo -n "Check the group file..."
|
|
../../../common/compare_file.pl config/etc/group /etc/group
|
|
echo "OK"
|
|
echo -n "Check the shadow file..."
|
|
../../../common/compare_file.pl config/etc/shadow /etc/shadow
|
|
echo "OK"
|
|
echo -n "Check the gshadow file..."
|
|
../../../common/compare_file.pl config/etc/gshadow /etc/gshadow
|
|
echo "OK"
|
|
|
|
log_status "$0" "SUCCESS"
|
|
restore_config
|
|
trap '' 0
|
|
|