245 lines
5.9 KiB
Bash
Executable File
245 lines
5.9 KiB
Bash
Executable File
#!/bin/bash
|
|
# Test script for busybox id vs. coreutils id.
|
|
# Needs root privileges for some tests.
|
|
|
|
cp /usr/bin/id .
|
|
BUSYBOX=./busybox
|
|
ID=./id
|
|
LIST=`awk -F: '{ printf "%s\n", $1 }' /etc/passwd`
|
|
FLAG_USER_EXISTS="no"
|
|
TEST_USER="f583ca884c1d93458fb61ed137ff44f6"
|
|
|
|
echo "test 1: id [options] nousername"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
$BUSYBOX id $OPTIONS >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
|
|
echo "test 2: id [options] username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
for i in $LIST ; do
|
|
if test "$i" = "$TEST_USER"; then
|
|
FLAG_USER_EXISTS="yes"
|
|
fi
|
|
$BUSYBOX id $OPTIONS $i >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS $i >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
done
|
|
|
|
if test $FLAG_USER_EXISTS = "yes"; then
|
|
echo "test 3,4,5,6,7,8,9,10,11,12 skipped because test user $TEST_USER already exists"
|
|
rm -f foo bar
|
|
exit 1
|
|
fi
|
|
|
|
adduser -s /bin/true -g "" -H -D "$TEST_USER" || exit 1
|
|
|
|
chown $TEST_USER.$TEST_USER $BUSYBOX
|
|
chmod u+s $BUSYBOX 2>&1 /dev/null
|
|
chown $TEST_USER.$TEST_USER $ID
|
|
chmod u+s $ID 2>&1 /dev/null
|
|
|
|
echo "test 3 setuid, existing user: id [options] no username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
$BUSYBOX id $OPTIONS >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
#done
|
|
done
|
|
|
|
echo "test 4 setuid, existing user: id [options] username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
for i in $LIST ; do
|
|
$BUSYBOX id $OPTIONS $i >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS $i >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
done
|
|
|
|
chown $TEST_USER.$TEST_USER $BUSYBOX
|
|
chmod g+s $BUSYBOX 2>&1 /dev/null
|
|
chown $TEST_USER.$TEST_USER $ID
|
|
chmod g+s $ID 2>&1 /dev/null
|
|
|
|
echo "test 5 setgid, existing user: id [options] no username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
$BUSYBOX id $OPTIONS >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
#done
|
|
done
|
|
|
|
echo "test 6 setgid, existing user: id [options] username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
for i in $LIST ; do
|
|
$BUSYBOX id $OPTIONS $i >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS $i >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
done
|
|
|
|
chown $TEST_USER.$TEST_USER $BUSYBOX
|
|
chmod u+s,g+s $BUSYBOX 2>&1 /dev/null
|
|
chown $TEST_USER.$TEST_USER $ID
|
|
chmod u+s,g+s $ID 2>&1 /dev/null
|
|
|
|
echo "test 7 setuid, setgid, existing user: id [options] no username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
$BUSYBOX id $OPTIONS >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
#done
|
|
done
|
|
|
|
echo "test 8 setuid, setgid, existing user: id [options] username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
for i in $LIST ; do
|
|
$BUSYBOX id $OPTIONS $i >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS $i >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
done
|
|
|
|
deluser $TEST_USER || exit 1
|
|
|
|
echo "test 9 setuid, setgid, not existing user: id [options] no username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
$BUSYBOX id $OPTIONS >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
|
|
echo "test 10 setuid, setgid, not existing user: id [options] username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
for i in $LIST ; do
|
|
$BUSYBOX id $OPTIONS $i >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS $i >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
done
|
|
|
|
chown .root $BUSYBOX 2>&1 /dev/null
|
|
chown .root $ID 2>&1 /dev/null
|
|
chmod g+s $BUSYBOX 2>&1 /dev/null
|
|
chmod g+s $ID 2>&1 /dev/null
|
|
|
|
echo "test 11 setgid, not existing group: id [options] no username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
$BUSYBOX id $OPTIONS >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
#done
|
|
done
|
|
|
|
echo "test 12 setgid, not existing group: id [options] username"
|
|
rm -f foo bar
|
|
for OPTIONS in "" "-u" "-un" "-unr" "-g" "-gn" "-gnr" "-G" "-Gn" "-Gnr"
|
|
do
|
|
#echo "$OPTIONS"
|
|
for i in $LIST ; do
|
|
$BUSYBOX id $OPTIONS $i >foo 2>/dev/null
|
|
RET1=$?
|
|
$ID $OPTIONS $i >bar 2>/dev/null
|
|
RET2=$?
|
|
if test "$RET1" != "$RET2"; then
|
|
echo "Return Values differ ($RET1 != $RET2): options $OPTIONS"
|
|
fi
|
|
diff foo bar
|
|
done
|
|
done
|
|
|
|
chown root.root $BUSYBOX 2>&1 /dev/null
|
|
chown root.root $ID 2>&1 /dev/null
|
|
rm -f $ID
|
|
rm -f foo bar
|