#!/bin/sh

set -e

cd $(dirname $0)

# Rational:
# Test that usermod can change the informations on an user

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 1 --comment "comment" -e 2000-01-01 -f 17 -s /bin/bash -d /tmp test1
echo "OK"

echo "test if the user was changed"
echo -n "  passwd..."
getent passwd test1 |
	egrep "^test1:x:$uid:1:comment:/tmp:/bin/bash$"
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:17:10957:$"
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"

