2014-09-18 04:04:29 +00:00
|
|
|
#!/bin/sh -x
|
|
|
|
|
|
|
|
set -e
|
|
|
|
mkdir -p testdir
|
|
|
|
cd testdir
|
|
|
|
|
|
|
|
set +e
|
|
|
|
setfacl -d -m u:nobody:rw .
|
|
|
|
if test $? != 0; then
|
|
|
|
echo "Filesystem does not support ACL"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2016-06-01 09:42:24 +00:00
|
|
|
expect_failure() {
|
2016-06-30 08:05:57 +00:00
|
|
|
if "$@"; then return 1; else return 0; fi
|
2016-06-01 09:42:24 +00:00
|
|
|
}
|
|
|
|
|
2014-09-18 04:04:29 +00:00
|
|
|
set -e
|
2014-10-08 12:38:33 +00:00
|
|
|
c=0
|
|
|
|
while [ $c -lt 100 ]
|
2014-09-18 04:04:29 +00:00
|
|
|
do
|
2014-10-08 12:38:33 +00:00
|
|
|
c=`expr $c + 1`
|
2014-09-18 04:04:29 +00:00
|
|
|
# inherited ACL from parent directory's default ACL
|
|
|
|
mkdir d1
|
|
|
|
c1=`getfacl d1 | grep -c "nobody:rw"`
|
2014-11-07 01:59:22 +00:00
|
|
|
echo 3 | sudo tee /proc/sys/vm/drop_caches > /dev/null
|
2014-09-18 04:04:29 +00:00
|
|
|
c2=`getfacl d1 | grep -c "nobody:rw"`
|
|
|
|
rmdir d1
|
2014-10-08 12:38:33 +00:00
|
|
|
if [ $c1 -ne 2 ] || [ $c2 -ne 2 ]
|
2014-09-18 04:04:29 +00:00
|
|
|
then
|
|
|
|
echo "ERROR: incorrect ACLs"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2016-06-01 09:42:24 +00:00
|
|
|
mkdir d1
|
|
|
|
|
|
|
|
# The ACL xattr only contains ACL header. ACL should be removed
|
|
|
|
# in this case.
|
|
|
|
setfattr -n system.posix_acl_access -v 0x02000000 d1
|
|
|
|
setfattr -n system.posix_acl_default -v 0x02000000 .
|
|
|
|
|
|
|
|
expect_failure getfattr -n system.posix_acl_access d1
|
|
|
|
expect_failure getfattr -n system.posix_acl_default .
|
|
|
|
|
|
|
|
|
|
|
|
rmdir d1
|
2014-09-18 04:04:29 +00:00
|
|
|
cd ..
|
|
|
|
rmdir testdir
|
|
|
|
echo OK
|