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
 | 
