~ubuntu-branches/ubuntu/utopic/coreutils/utopic-proposed

« back to all changes in this revision

Viewing changes to tests/rm/fail-2eperm

  • Committer: Package Import Robot
  • Author(s): Colin Watson
  • Date: 2012-11-28 03:03:42 UTC
  • mfrom: (8.3.4 sid)
  • Revision ID: package-import@ubuntu.com-20121128030342-21zanj8354gas5gr
Tags: 8.20-3ubuntu1
* Resynchronise with Debian.  Remaining changes:
  - Make 'uname -i -p' return the real processor/hardware, instead of
    unknown.
  - Build-depend on gettext:any instead of on gettext, so that apt-get can
    properly resolve build-dependencies on the tool when cross-building.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
#!/bin/sh
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.
4
 
 
5
 
# Copyright (C) 2003, 2006-2011 Free Software Foundation, Inc.
6
 
 
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.
11
 
 
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.
16
 
 
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/>.
19
 
 
20
 
. "${srcdir=.}/init.sh"; path_prepend_ ../src
21
 
print_ver_ rm
22
 
require_root_
23
 
 
24
 
# The containing directory must be owned by the user who eventually runs rm.
25
 
chown $NON_ROOT_USERNAME .
26
 
 
27
 
mkdir a || framework_failure_
28
 
chmod 1777 a || framework_failure_
29
 
touch a/b || framework_failure_
30
 
 
31
 
 
32
 
# Try to ensure that $NON_ROOT_USERNAME can access
33
 
# the required version of rm.
34
 
rm_version=`
35
 
  setuidgid $NON_ROOT_USERNAME env PATH="$PATH" rm --version |
36
 
  sed -n '1s/.* //p'
37
 
`
38
 
case $rm_version in
39
 
  $PACKAGE_VERSION) ;;
40
 
  *) skip_ "cannot access just-built rm as user $NON_ROOT_USERNAME";;
41
 
esac
42
 
setuidgid $NON_ROOT_USERNAME env PATH="$PATH" rm -rf a 2> out-t && fail=1
43
 
 
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
48
 
 
49
 
cat <<\EOF > exp
50
 
rm: cannot remove `a/b': Operation not permitted
51
 
EOF
52
 
 
53
 
compare out exp || fail=1
54
 
 
55
 
Exit $fail