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

74 lines
1.6 KiB
Bash
Executable File

#!/bin/sh
set -e
cd $(dirname $0)
. ../../../common/config.sh
. ../../../common/log.sh
log_start "$0" "reports all entry from /var/log/faillog"
save_config
# restore the files on exit
trap 'log_status "$0" "FAILURE"; restore_config' 0
change_config
echo -n "Create an empty /var/log/faillog (it will not be restored)..."
> /var/log/faillog
echo "OK"
echo -n "Trigger a connection as foo..."
./login.exp foo
echo "OK"
sleep 1
echo -n "Trigger a connection as bar..."
./login.exp bar
echo "OK"
echo -n "Trigger a connection as baz..."
./login.exp baz
echo "OK"
echo -n "Remove users foo, bar, baz from passwd and shadow..."
cp /etc/passwd /etc/shadow tmp/
sed -e '/^(foo|bar|baz):/d' -i /etc/passwd
sed -e '/^(foo|bar|baz):/d' -i /etc/shadow
echo "OK"
echo -n "reset baz (faillog -l 10 -a -u 1000-1001)..."
faillog -l 10 -a -u 1000-1001
echo "OK"
echo -n "Restore user foo..."
mv tmp/passwd tmp/shadow /etc/
echo "OK"
echo -n "faillog..."
faillog > tmp/faillog.out
echo "OK."
echo "faillog :"
echo "======================================================================="
cat tmp/faillog.out
echo "======================================================================="
echo -n "Check the list of users with failures..."
cut -c-28 tmp/faillog.out > tmp/faillog.list
diff -au data/faillog.list tmp/faillog.list
echo "OK"
echo "There should be between 2 and 4 secondes remaining for bar..."
grep "^bar .* \[[2-4]s left\]$" tmp/faillog.out
echo "OK"
echo "The lock is displayed as 10s for foo..."
grep "^foo .* \[10s lock\]$" tmp/faillog.out
echo "OK."
rm -f tmp/faillog.out tmp/faillog.list
log_status "$0" "SUCCESS"
restore_config
trap '' 0