#!/bin/sh set -e cd $(dirname $0) . ../../../common/config.sh . ../../../common/log.sh log_start "$0" "chpasswd can use create SHA512 passwords and use at least 1000 rounds" save_config # restore the files on exit trap 'log_status "$0" "FAILURE"; restore_config' 0 change_config echo -n "Change nobody and lp's password (chpasswd --crypt-method SHA512 -s 900)..." echo 'nobody:test lp:test2' | chpasswd --crypt-method SHA512 -s 900 echo "OK" 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 data/shadow /etc/shadow grep nobody /etc/shadow | grep -q ':\$6\$rounds=1000\$' 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