t1304: improve setfacl prerequisite setup

t1304 first runs setfacl as an experiment to see whether the
filesystem supports ACLs, and skips the remaining tests if
it does not. However, our setfacl run did not exercise the
ACLs very well, and some filesystems may support our initial
setfacl, but not the rest of the test.

In particular, some versions of ecryptfs will erroneously
apply the umask on top of an inherited directory ACL,
causing our tests to fail. Let's be more careful and make
sure both that we can read back the user ACL we set, and
that the inherited ACL is propagated correctly. The latter
catches the ecryptfs bug, but may also catch other bugs
(e.g., an implementation which does not handle inherited
ACLs at all).

Since we're making the setup more complex, let's move it
into its own test. This will hide the output for us unless
the user wants to run "-v" to see it (and we don't need to
bother printing anything about setfacl failing; the
remaining tests will properly print "skip" due to the
missing prerequisite).

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2012-06-06 09:28:24 -04:00 committed by Junio C Hamano
parent ac2604cf5f
commit a14ad10911

View File

@ -14,16 +14,15 @@ umask 077
# We need an arbitrary other user give permission to using ACLs. root # We need an arbitrary other user give permission to using ACLs. root
# is a good candidate: exists on all unices, and it has permission # is a good candidate: exists on all unices, and it has permission
# anyway, so we don't create a security hole running the testsuite. # anyway, so we don't create a security hole running the testsuite.
test_expect_success 'checking for a working acl setup' '
setfacl_out="$(setfacl -m u:root:rwx . 2>&1)" if setfacl -m d:m:rwx -m u:root:rwx . &&
setfacl_ret=$? getfacl . | grep user:root:rwx &&
touch should-have-readable-acl &&
if test $setfacl_ret != 0 getfacl should-have-readable-acl | egrep "mask::?rw-"
then then
say "Unable to use setfacl (output: '$setfacl_out'; return code: '$setfacl_ret')" test_set_prereq SETFACL
else fi
test_set_prereq SETFACL '
fi
if test -z "$LOGNAME" if test -z "$LOGNAME"
then then