2
# Like fail-eperm, but the failure must be for a file encountered
3
# while trying to remove the containing directory with the sticky bit set.
5
# Copyright (C) 2003, 2006-2011 Free Software Foundation, Inc.
7
# This program is free software: you can redistribute it and/or modify
8
# it under the terms of the GNU General Public License as published by
9
# the Free Software Foundation, either version 3 of the License, or
10
# (at your option) any later version.
12
# This program is distributed in the hope that it will be useful,
13
# but WITHOUT ANY WARRANTY; without even the implied warranty of
14
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
# GNU General Public License for more details.
17
# You should have received a copy of the GNU General Public License
18
# along with this program. If not, see <http://www.gnu.org/licenses/>.
20
. "${srcdir=.}/init.sh"; path_prepend_ ../src
24
# The containing directory must be owned by the user who eventually runs rm.
25
chown $NON_ROOT_USERNAME .
27
mkdir a || framework_failure_
28
chmod 1777 a || framework_failure_
29
touch a/b || framework_failure_
32
# Try to ensure that $NON_ROOT_USERNAME can access
33
# the required version of rm.
35
setuidgid $NON_ROOT_USERNAME env PATH="$PATH" rm --version |
40
*) skip_ "cannot access just-built rm as user $NON_ROOT_USERNAME";;
42
setuidgid $NON_ROOT_USERNAME env PATH="$PATH" rm -rf a 2> out-t && fail=1
44
# On some systems, we get `Not owner'. Convert it.
45
# On other systems (HPUX), we get `Permission denied'. Convert it, too.
46
onp='Operation not permitted'
47
sed "s/Not owner/$onp/;s/Permission denied/$onp/" out-t > out
50
rm: cannot remove `a/b': Operation not permitted
53
compare out exp || fail=1