diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2004-08-19 20:04:21 +0000 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2004-08-19 20:04:21 +0000 |
commit | 7c308093f3e3564f86816e8bdbdfc6458cdd5166 (patch) | |
tree | b3315157d0ab1810b2c7c0914844c789dccc22d6 /tests/chown | |
parent | d3771df301a0367b5dc448ca065150caafd2cc19 (diff) | |
download | coreutils-7c308093f3e3564f86816e8bdbdfc6458cdd5166.tar.xz |
New file, partly taken from
Dmitry V. Levin's suggestion in
<http://lists.gnu.org/archive/html/bug-coreutils/2004-08/msg00102.html>
Diffstat (limited to 'tests/chown')
-rwxr-xr-x | tests/chown/separator | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/chown/separator b/tests/chown/separator new file mode 100755 index 000000000..fec1b5827 --- /dev/null +++ b/tests/chown/separator @@ -0,0 +1,55 @@ +#!/bin/sh +# Make sure "chown USER:GROUP FILE" works, and similar tests with separators. + +if test "$VERBOSE" = yes; then + set -x + chown --version +fi + +pwd=`pwd` +t0=`echo "$0" |sed 's,.*/,,'`.tmp; tmp=$t0/$$ +trap 'status=$?; cd $pwd; chmod -R u+rwx $t0; rm -rf $t0 && exit $status' 0 +trap 'status=$?; (exit $status); exit $status' 1 2 13 15 + +framework_failure=0 + +mkdir -p $tmp || framework_failure=1 +cd $tmp || framework_failure=1 + +id_u=`id -u` || framework_failure=1 +test -n "$id_u" || framework_failure=1 + +id_un=`id -un` || framework_failure=1 +test -n "$id_un" || framework_failure=1 + +id_g=`id -g` || framework_failure=1 +test -n "$id_g" || framework_failure=1 + +id_gn=`id -gn` || framework_failure=1 +test -n "$id_gn" || framework_failure=1 + +if test $framework_failure = 1; then + echo "$0: failure in testing framework" 1>&2 + (exit 1); exit 1 +fi + +fail=0 + +chown '' . || fail=1 + +for u in $id_u $id_un ''; do + for g in $id_g $id_gn ''; do + case $u$g in + *.*) seps=':' ;; + *) seps=': .' ;; + esac + for sep in $seps; do + case $u$sep$g in + [0-9]*$sep) chown "$u$sep$g" . 2> /dev/null && fail=1 ;; + *) chown "$u$sep$g" . || fail=1 ;; + esac + done + done +done + +(exit $fail); exit $fail |