* tests/cp/cp-a-selinux: New file. Test for the bug reported in
authorJim Meyering <jim@meyering.net>
Wed, 31 Jan 2007 22:01:50 +0000 (23:01 +0100)
committerJim Meyering <jim@meyering.net>
Thu, 29 Mar 2007 19:37:06 +0000 (21:37 +0200)
commit8a86223d45be7597b229a95381aebab3512bf6d7
tree6e26ddcaefd7f1cc3dd92cb014c5a2fb4135b585
parentadcfd944a8e7b64e11672ef8d0d077bb8de1b666
* tests/cp/cp-a-selinux: New file. Test for the bug reported in

* tests/cp/Makefile.am (TESTS): Add cp-a-selinux.

* tests/selinux: New file.
* tests/Makefile.am (EXTRA_DIST): Add selinux.
* tests/misc/selinux: Source the new script, rather than open coding it.

Change how "cp -a" and "cp --preserve=context" work with SELinux.
Now, cp -a attempts to preserve context, but failure to do so does
not change cp's exit status.  However "cp --preserve=context" is
similar, but failure *does* cause cp to exit with nonzero status.
* src/copy.h (struct cp_options) [require_preserve_context]: New member.
* src/copy.c (copy_reg, copy_internal): Implement the above.
* src/mv.c (cp_option_init): Initialize the new member.
* src/install.c (cp_option_init): Likewise.
* src/cp.c (cp_option_init): Likewise.
(decode_preserve_arg): Set it or reset it.

FIXME: add an on-writable-NFS-only test
ChangeLog-selinux
src/copy.c
src/copy.h
src/cp.c
src/install.c
src/mv.c
tests/Makefile.am
tests/cp/Makefile.am
tests/cp/cp-a-selinux [new file with mode: 0755]
tests/misc/selinux
tests/selinux [new file with mode: 0644]