From 2f28897780ae0f6f8d341bfd91f33a9fce0875d9 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Fri, 17 Oct 2003 13:31:36 +0000 Subject: [PATCH] *** empty log message *** --- ChangeLog | 5 +++++ tests/chgrp/no-x | 45 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 50 insertions(+) create mode 100755 tests/chgrp/no-x diff --git a/ChangeLog b/ChangeLog index eccee6f623..4f2adfaaa3 100644 --- a/ChangeLog +++ b/ChangeLog @@ -2,6 +2,11 @@ * Version 5.1.0. + * tests/chmod/no-x: New file. + * tests/chgrp/no-x: New file. + * tests/chmod/Makefile.am (TESTS): Add no-x. + * tests/chgrp/Makefile.am (TESTS): Likewise. + * src/du.c: Include "xfts.h". (du_files): Use xfts_open, rather than fts_open. * src/chown-core.c (chown_files): Likewise. diff --git a/tests/chgrp/no-x b/tests/chgrp/no-x new file mode 100755 index 0000000000..d58fe8a1fe --- /dev/null +++ b/tests/chgrp/no-x @@ -0,0 +1,45 @@ +#!/bin/sh +# Make sure chgrp gives the right diagnostic for a readable, +# but inaccessible directory. + +if test "$VERBOSE" = yes; then + set -x + chgrp --version +fi + +. $srcdir/../group-names +set _ $groups; shift +g1=$1 +g2=$2 + +. $srcdir/../lang-default +PRIV_CHECK_ARG=require-non-root . $srcdir/../priv-check + +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 '(exit $?); exit $?' 1 2 13 15 + +framework_failure=0 +mkdir -p $tmp || framework_failure=1 +cd $tmp || framework_failure=1 +mkdir -p d/no-x/y || framework_failure=1 +chmod u=rw d/no-x || framework_failure=1 + +if test $framework_failure = 1; then + echo "$0: failure in testing framework" 1>&2 + (exit 1); exit 1 +fi + +fail=0 + +# This must exit nonzero. +chgrp -R $g2 d >/dev/null 2>out && fail=1 +cat <<\EOF > exp +chgrp: `d/no-x': Permission denied +EOF + +cmp out exp || fail=1 +test $fail = 1 && diff out exp 2> /dev/null + +(exit $fail); exit $fail -- 2.47.2