#!/bin/sh set -e cd $(dirname $0) # Rational: # Test that usermod can change the group of an user # (-g with non-numerical GID) save() { [ ! -d tmp ] && mkdir tmp for i in passwd group shadow gshadow do [ -f /etc/$i ] && cp /etc/$i tmp/$i done true } restore() { for i in passwd group shadow gshadow do [ -f tmp/$i ] && cp tmp/$i /etc/$i && rm tmp/$i done rmdir tmp } save # restore the files on exit trap 'restore' 0 cp data/{passwd,shadow,group,gshadow} /etc/ lines_passwd=$(wc -l /etc/passwd | cut -f1 -d" ") lines_shadow=$(wc -l /etc/shadow | cut -f1 -d" ") lines_group=$(wc -l /etc/group | cut -f1 -d" ") lines_gshadow=$(wc -l /etc/gshadow | cut -f1 -d" ") echo -n "Create user test1..." useradd test1 echo "OK" uid=$(getent passwd test1|sed -ne "s/test1:x:\([0-9]*\):.*/\\1/p") echo -n "Change user test1..." usermod -g bin test1 echo "OK" echo "test if the user was changed" echo -n " passwd..." getent passwd test1 | egrep "^test1:x:$uid:2::/home/test1:/bin/sh$" echo " OK" echo -n " group..." getent group test1 | egrep "^test1:x:$uid:$" echo " OK" echo -n " shadow..." getent shadow test1 | egrep "^test1:!:[0-9]+:0:99999:7:::$" echo " OK" echo -n " gshadow..." egrep "^test1:!::$" /etc/gshadow echo " OK" # the home directory should not exist echo -n " no homedir..." test -d /home/test1 && exit 1 || true echo " OK" echo -n " number of lines" test $(( lines_passwd + 1 )) = $(wc -l /etc/passwd | cut -f1 -d" ") echo -n "." test $(( lines_group + 1 )) = $(wc -l /etc/group | cut -f1 -d" ") echo -n "." test $(( lines_shadow + 1 )) = $(wc -l /etc/shadow | cut -f1 -d" ") echo -n "." test $(( lines_gshadow + 1 )) = $(wc -l /etc/gshadow | cut -f1 -d" ") echo -n "." echo " OK"