summaryrefslogtreecommitdiff
path: root/tests/chgrp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/chgrp')
-rwxr-xr-xtests/chgrp/basic77
1 files changed, 77 insertions, 0 deletions
diff --git a/tests/chgrp/basic b/tests/chgrp/basic
new file mode 100755
index 000000000..274b7aaf8
--- /dev/null
+++ b/tests/chgrp/basic
@@ -0,0 +1,77 @@
+#!/bin/sh
+# make sure chgrp is reasonable
+
+if test "$VERBOSE" = yes; then
+ set -x
+ chgrp --version
+fi
+
+pwd=`pwd`
+tmp=basic.$$
+trap 'status=$?; cd $pwd; rm -rf $tmp && exit $status' 0
+trap '(exit $?); exit' 1 2 13 15
+
+framework_failure=0
+mkdir $tmp || framework_failure=1
+cd $tmp || framework_failure=1
+
+if test $framework_failure = 1; then
+ echo 'failure in testing framework' 1>&2
+ (exit 1); exit
+fi
+
+fail=0
+
+groups=`id -nG 2>/dev/null`
+case "$groups" in
+ *' '*) ;;
+ *) cat <<EOF 1>&2
+$0: this test requires that you be a member of more than one group,
+but running \`id -nG' either failed or found just one.
+EOF
+ (exit 77); exit
+ ;;
+esac
+
+set _ $groups; shift
+g1=$1
+g2=$2
+mkdir d
+touch f f2 d/f3
+chgrp $g1 f || fail=1
+chgrp $g2 f || fail=1
+chgrp $g2 f2 || fail=1
+
+(
+ chgrp -c $g1 f
+ chgrp -c $g2 f
+ chgrp -c $g2 f
+ chgrp --verbose $g1 f
+ chgrp --verbose $g1 f
+ chgrp --verbose --reference=f2 f
+ chgrp -R --verbose $g2 d
+ chgrp -R --verbose $g1 d
+ chgrp -R -c $g2 d
+ chgrp -R -c $g1 d
+) 2>&1 | sed "s/ $g1$/ G1/;s/ $g2$/ G2/" > actual
+
+cat <<\EOF > expected
+group of `f' changed to G1
+group of `f' changed to G2
+group of `f' changed to G1
+group of `f' retained as G1
+group of `f' changed to XXX
+group of `d' changed to G2
+group of `d/f3' changed to G2
+group of `d' changed to G1
+group of `d/f3' changed to G1
+group of `d' changed to G2
+group of `d/f3' changed to G2
+group of `d' changed to G1
+group of `d/f3' changed to G1
+EOF
+
+cmp expected actual \
+ || { diff -c expected actual 1>&2; fail=1; }
+
+(exit $fail); exit