Rather than simply using the first non-root
authorJim Meyering <jim@meyering.net>
Sat, 8 Mar 2003 16:43:43 +0000 (16:43 +0000)
committerJim Meyering <jim@meyering.net>
Sat, 8 Mar 2003 16:43:43 +0000 (16:43 +0000)
username, make sure that the selected user name has a usable shell.

tests/rm/fail-2eperm

index d2a20026277641700ed58bdbcb69a8ad96ff6df4..18662e3f507fd06ecb6dc5383ad4374edba1ac1c 100755 (executable)
@@ -15,14 +15,18 @@ t0=`echo "$0"|sed 's,.*/,,'`.tmp; tmp=$t0/$$
 trap 'status=$?; cd $pwd; chmod -R u+rwx $t0; rm -rf $t0 && exit $status' 0
 trap '(exit $?); exit $?' 1 2 13 15
 
-# Find a username with UID != 0.
-non_root_username=`grep -v '[^:]*:[^:]*:0:' /etc/passwd| sed -n '1s/:.*//p'`
-test "x$non_root_username" = x && framework_failure=1
-
 framework_failure=0
 mkdir -p $tmp || framework_failure=1
 cd $tmp || framework_failure=1
 
+# Find a username with UID != 0, and a valid shell.
+non_root_username=
+names=`grep -v '[^:]*:[^:]*:0:' /etc/passwd| sed 's/:.*//'`
+for name in $names; do
+  su -c ':' $name && { non_root_username=$name; break; }
+done
+test "x$non_root_username" = x && framework_failure=1
+
 # The containing directory must be owned by the user who eventually runs rm.
 chown $non_root_username .