#!/bin/sh # Make sure that touch gives reasonable diagnostics when applied # to an unwritable directory owned by some other user. # Copyright (C) 2003-2009 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 3 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, see . if test "$VERBOSE" = yes; then set -x touch --version fi . $srcdir/test-lib.sh if env -- test -w /; then skip_test_ you have write access to /. fi if env -- test -O / || env -- test -G /; then skip_test_ "you own /." fi skip_if_root_ # Before fileutils-4.1, we'd get the following misleading # diagnostic instead of `...: Permission denied'. # touch: creating `/': Is a directory touch / > out 2>&1 && fail=1 # On SunOS4, EPERM is `Not owner'. # On some *BSD systems it's `Operation not permitted'. # On a system where root file system is mounted read-only # it's `Read-only file system'. for msg in 'Not owner' 'Operation not permitted' 'Permission denied' \ 'Read-only file system'; do cat > exp < /dev/null 2>&1 && { match=1; break; } done test "$match" = 1 || fail=1 test $fail = 1 && diff out exp 2> /dev/null Exit $fail