#!/bin/sh # Make sure cp -p isn't too generous with existing file permissions. # Copyright (C) 2006-2010 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 cp --version fi . $srcdir/test-lib.sh require_membership_in_two_groups_ # cp -p gives ENOTSUP on NFS on Linux 2.6.9 at least require_local_dir_ set _ $groups; shift g1=$1 g2=$2 umask 077 mkfifo fifo || skip_test_ "fifos not supported" touch fifo-copy && chgrp $g1 fifo && chgrp $g2 fifo-copy && chmod g+r fifo-copy || framework-failure # Copy a fifo's contents. That way, we can examine the # destination permissions before they're finalized. cp -p --copy-contents fifo fifo-copy & cp_pid=$! ( # Now 'cp' is reading the fifo. Wait for the destination file to # be written to, encouraging things along by echoing to the fifo. while test ! -s fifo-copy; do echo foo done # Check the permissions of the destination. ls -l -n fifo-copy >ls.out && # Close the fifo so that "cp" can continue. But output first, # before exiting, otherwise some shells would optimize away the file # descriptor that holds the fifo open. echo foo ) >fifo || fail=1 # Check that the destination mode is safe while the file is being copied. read mode links owner group etc ls.out && read mode links owner group etc