diff options
author | Jim Meyering <jim@meyering.net> | 2006-12-20 19:56:20 +0100 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2006-12-21 08:58:11 +0100 |
commit | c8ef95eaed944ec70ccd70c077cf465c6311c1b6 (patch) | |
tree | 5c83a1915419c58457fff59afe894abf3e00471c | |
parent | d69fc66d81c7166fe689418f42b7cb900d2a1433 (diff) | |
download | coreutils-c8ef95eaed944ec70ccd70c077cf465c6311c1b6.tar.xz |
"rm -rf /etc/motd" (run by non-root) now prints a diagnostic.
* src/remove.c (remove_entry): Handle EACCES for a non-directory, too.
Karl Berry reported that a cross-partition "mv /etc/issue ~"
failed with the um,... suboptimal diagnostic,
"mv: cannot remove `/etc/issue': Not a directory".
* tests/rm/Makefile.am (TESTS): Add fail-eacces.
* tests/rm/fail-eacces: New file.
* NEWS: Mention that both mv and rm are affected.
-rw-r--r-- | ChangeLog | 12 | ||||
-rw-r--r-- | NEWS | 7 | ||||
-rw-r--r-- | src/remove.c | 4 | ||||
-rw-r--r-- | tests/rm/Makefile.am | 1 | ||||
-rwxr-xr-x | tests/rm/fail-eacces | 53 |
5 files changed, 75 insertions, 2 deletions
@@ -1,5 +1,17 @@ 2006-12-20 Jim Meyering <jim@meyering.net> + "rm -rf /etc/motd" (run by non-root) now prints a diagnostic. + * src/remove.c (remove_entry): Handle EACCES for a non-directory, too. + Don't let a non-directory get by with errno == EPERM, either. + Check the file type directly (using cached stat value), rather + than trying to guess it from errno values. + Karl Berry reported that a cross-partition "mv /etc/issue ~" + failed with the um,... suboptimal diagnostic, + "mv: cannot remove `/etc/issue': Not a directory". + * tests/rm/Makefile.am (TESTS): Add fail-eacces. + * tests/rm/fail-eacces: New file. + * NEWS: Mention that both mv and rm are affected. + "cut -f 2- A B" no longer triggers a double-free bug * src/cut.c (cut_fields): Set file-scoped global to NULL after freeing it. This avoids a double-free (and core dump on some systems) @@ -14,6 +14,13 @@ GNU coreutils NEWS -*- outline -*- more file arguments. This was due to a double-free bug, introduced in coreutils-5.3.0. + A cross-partition "mv /etc/passwd ~" (by non-root) now prints + a reasonable diagnostic. Before, it would print this: + "mv: cannot remove `/etc/passwd': Not a directory". + + "rm -rf /etc/passwd" (run by non-root) now prints a diagnostic. + Before it would print nothing. + * Noteworthy changes in release 6.7 (2006-12-08) [stable] ** Bug fixes diff --git a/src/remove.c b/src/remove.c index 3dc692947..f6d3f0c67 100644 --- a/src/remove.c +++ b/src/remove.c @@ -1016,8 +1016,7 @@ remove_entry (int fd_cwd, Dirstack_state const *ds, char const *filename, errno = EISDIR; if (! x->recursive - || errno == ENOENT || errno == ENOTDIR - || errno == ELOOP || errno == ENAMETOOLONG) + || (cache_stat_ok (st) && !S_ISDIR (st->st_mode))) { if (ignorable_missing (x, errno)) return RM_OK; @@ -1028,6 +1027,7 @@ remove_entry (int fd_cwd, Dirstack_state const *ds, char const *filename, quote (full_filename (filename))); return RM_ERROR; } + assert (!cache_stat_ok (st) || S_ISDIR (st->st_mode)); } else { diff --git a/tests/rm/Makefile.am b/tests/rm/Makefile.am index 6670307e8..f63210025 100644 --- a/tests/rm/Makefile.am +++ b/tests/rm/Makefile.am @@ -21,6 +21,7 @@ AUTOMAKE_OPTIONS = 1.1 gnits TESTS = \ + fail-eacces \ one-file-system \ ignorable \ readdir-bug \ diff --git a/tests/rm/fail-eacces b/tests/rm/fail-eacces new file mode 100755 index 000000000..29bc91154 --- /dev/null +++ b/tests/rm/fail-eacces @@ -0,0 +1,53 @@ +#!/bin/sh +# Ensure that rm -rf unremovable-non-dir gives a diagnostic. + +# Copyright (C) 2006 Free Software Foundation, Inc. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301, USA. + +if test "$VERBOSE" = yes; then + set -x + rm --version +fi + +. $srcdir/../lang-default + +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 d && touch d/f && chmod a-w d || framework_failure=1 + +if test $framework_failure = 1; then + echo "$0: failure in testing framework" 1>&2 + (exit 1); exit 1 +fi + +fail=0 + +rm -rf d/f 2> out && fail=1 +cat <<\EOF > exp +rm: cannot remove `d/f': Permission denied +EOF + +cmp out exp || fail=1 +test $fail = 1 && diff out exp 2> /dev/null + +(exit $fail); exit $fail |