#!/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