2 # Make sure chmod gives the right diagnostic for a readable,
3 # but inaccessible directory.
5 if test "$VERBOSE" = yes; then
10 . $srcdir/../lang-default
11 PRIV_CHECK_ARG=require-non-root . $srcdir/../priv-check
14 t0=`echo "$0"|sed 's,.*/,,'`.tmp; tmp=$t0/$$
15 trap 'status=$?; cd $pwd; chmod -R u+rwx $t0; rm -rf $t0 && exit $status' 0
16 trap '(exit $?); exit $?' 1 2 13 15
19 mkdir -p $tmp || framework_failure=1
20 cd $tmp || framework_failure=1
21 mkdir -p d/no-x/y || framework_failure=1
22 chmod u=rw d/no-x || framework_failure=1
24 if test $framework_failure = 1; then
25 echo "$0: failure in testing framework" 1>&2
31 # This must exit nonzero.
32 chmod -R o=r d >/dev/null 2>out && fail=1
35 chmod: `d/no-x': Permission denied
38 # With native fdopendir, du uses a different code path.
39 cat <<\EOF > exp-native-fdopendir
40 chmod: cannot access `d/no-x/y': Permission denied
41 chmod: fts_read failed: Permission denied
44 if cmp out exp >/dev/null 2>&1; then
47 if cmp out exp-native-fdopendir; then
54 test $fail = 1 && diff out exp 2> /dev/null
58 # This will fail with ``chmod: fts_read failed: Permission denied''
59 chmod a-x . b 2> /dev/null && fail=1
60 # chmod must exit with status 1.
61 # Due to a bug in coreutils-5.93's fts.c, chmod would provoke
62 # an abort (exit with status 134) on recent glibc-based systems.
65 (exit $fail); exit $fail