mirror of
git://git.sv.gnu.org/coreutils.git
synced 2026-02-19 13:52:14 +02:00
* src/copy.c (copy_attr): A new function which merges copy_attr_by_fd and copy_attr_by_name. Also display all errors when --attributes-only * src/copy.c (copy_reg): Skip copying the file contents if specified. Refactor the SELinux error handling code a little and display all SELinux errors when only copying attributes. * src/copy.h (struct cp_options): Add a data_copy_required boolean * src/cp.c (main): Default to copying data but don't if specified * src/install.c: Default to copying data * src/mv.c: Likewise tests/cp/reflink-perm: Add a test to check that --attributes-only does not copy data * tests/cp/acl: Likewise. Also refactor to remove redundant acl manipulation * doc/coreutils.texi (cp invocation): Describe the new option * NEWS: Mention the new feature
68 lines
2.1 KiB
Bash
Executable File
68 lines
2.1 KiB
Bash
Executable File
#!/bin/sh
|
|
# copy files/directories across file system boundaries
|
|
# and make sure acls are preserved appropriately
|
|
|
|
# Copyright (C) 2005-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 <http://www.gnu.org/licenses/>.
|
|
|
|
# Make sure we get English translations.
|
|
|
|
if test "$VERBOSE" = yes; then
|
|
set -x
|
|
mv --version
|
|
getfacl --version
|
|
setfacl --version
|
|
fi
|
|
|
|
. $srcdir/test-lib.sh
|
|
require_acl_
|
|
|
|
# Skip this test if cp was built without ACL support:
|
|
grep '^#define USE_ACL 1' $CONFIG_HEADER > /dev/null ||
|
|
skip_test_ "insufficient ACL support"
|
|
|
|
mkdir -p a b || framework_failure
|
|
touch a/file || framework_failure
|
|
|
|
# Ensure that setfacl and getfacl work on this file system.
|
|
skip=no
|
|
acl1=`cd a && getfacl file` || skip=yes
|
|
setfacl -m user:bin:rw a/file 2> /dev/null || skip=yes
|
|
test $skip = yes &&
|
|
skip_test_ "'.' is not on a suitable file system for this test"
|
|
|
|
# copy a file without preserving permissions
|
|
cp a/file b/ || fail=1
|
|
acl2=`cd b && getfacl file` || framework_failure
|
|
test "$acl1" = "$acl2" || fail=1
|
|
|
|
# Update with acl set above
|
|
acl1=`cd a && getfacl file` || framework_failure
|
|
|
|
# copy a file, preserving permissions
|
|
cp -p a/file b/ || fail=1
|
|
acl2=`cd b && getfacl file` || framework_failure
|
|
test "$acl1" = "$acl2" || fail=1
|
|
|
|
# copy a file, preserving permissions, with --attributes-only
|
|
echo > a/file || framework_failure # add some data
|
|
test -s a/file || framework_failure
|
|
cp -p --attributes-only a/file b/ || fail=1
|
|
test -s b/file && fail=1
|
|
acl2=`cd b && getfacl file` || framework_failure
|
|
test "$acl1" = "$acl2" || fail=1
|
|
|
|
Exit $fail
|