diff options
author | Bernhard Voelker <mail@bernhard-voelker.de> | 2014-01-10 16:48:25 +0100 |
---|---|---|
committer | Bernhard Voelker <mail@bernhard-voelker.de> | 2014-01-10 16:48:25 +0100 |
commit | 5d7591d0edf0dd31c2daa195ee766c1383b89f4c (patch) | |
tree | a640b513646b4dfdf26f61fc2d3d64e1d305eb99 | |
parent | d1342119790fc9c12729db50ee5db9248be82408 (diff) | |
download | coreutils-5d7591d0edf0dd31c2daa195ee766c1383b89f4c.tar.xz |
tests: improve test for a working setfacl
Prompted by a test framework failure of tests/mkdir/p-acl.sh on armv7l:
The previous test for a working setfacl was not sufficient in some
circumstances.
* init.cfg (require_setfacl_): Call setfacl twice with conflictive
ACL specs, and use ACL specs which can't be mapped into regular file
permission bits. Document the reasons.
-rw-r--r-- | init.cfg | 30 |
1 files changed, 29 insertions, 1 deletions
@@ -192,9 +192,37 @@ require_valgrind_() skip_ "requires a working valgrind" } +# Skip the current test if setfacl doesn't work on the current file system, +# which could happen if not installed, or if ACLs are not supported by the +# kernel or the file system, or are turned off via mount options. +# +# Work around the following two issues: +# +# 1) setfacl maps ACLs into file permission bits if on "noacl" file systems. +# +# On file systems which do not support ACLs (e.g. ext4 mounted with -o noacl), +# setfacl operates on the regular file permission bits, and only fails if the +# given ACL spec does not fit into there. Thus, to test if ACLs really work +# on the current file system, pass an ACL spec which can't be mapped that way. +# "Default" ACLs (-d) seem to fulfill this requirement. +# +# 2) setfacl only invokes the underlying system call if the ACL would change. +# +# If the given ACL spec would not change the ACLs on the file, then setfacl +# does not invoke the underlying system call - setxattr(). Therefore, to test +# if setting ACLs really works on the current file system, call setfacl twice +# with conflictive ACL specs. require_setfacl_() { - setfacl -m user::rwx . \ + local d='acltestdir_' + mkdir $d || framework_failure_ + local f=0 + + setfacl -d -m user::r-x $d \ + && setfacl -d -m user::rwx $d \ + || f=1 + rm -rf $d || framework_failure_ + test $f = 0 \ || skip_ "setfacl does not work on the current file system" } |