shadow/tests/log/lastlog/01_lastlog_no_lastlog/lastlog.test
Serge Hallyn b999d48941 Add tests from the old svn tree
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>
2014-09-17 14:42:55 -05:00

52 lines
1.1 KiB
Bash
Executable File

#!/bin/sh
set -e
cd $(dirname $0)
. ../../../common/config.sh
. ../../../common/log.sh
log_start "$0" "lastlog detects missing /var/log/lastlog and does not create it"
save_config
# restore the files on exit
trap 'log_status "$0" "FAILURE"; restore_config; touch /var/log/lastlog' 0
change_config
echo -n "Remove /var/log/lastlog (it will not be restored)..."
rm -f /var/log/lastlog
echo "OK"
echo -n "Execute lastlog (lastlog)..."
lastlog 2>tmp/lastlog.err && exit 1 || {
status=$?
}
echo "OK"
echo -n "Check returned status ($status)..."
test "$status" = "1"
echo "OK"
echo "lastlog reported:"
echo "======================================================================="
cat tmp/lastlog.err
echo "======================================================================="
echo -n "Check the usage message..."
diff -au data/lastlog.err tmp/lastlog.err
echo "usage message OK."
rm -f tmp/lastlog.err
echo -n "Check that the /var/log/lastlog file was not created"...
test ! -f /var/log/lastlog
echo "OK"
touch /var/log/lastlog
log_status "$0" "SUCCESS"
restore_config
trap '' 0