X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/23deb0bceebc50fa7dbf3c04d15aedc5d78b73c2..434764269cc3f5bc2fc62f3789ff9d23a562d2d7:/runtests.sh diff --git a/runtests.sh b/runtests.sh index fdf51b58..0056de92 100755 --- a/runtests.sh +++ b/runtests.sh @@ -85,7 +85,7 @@ # they're explicitly given on the command line. # Also, we can't count on 'cp -a' or 'mkdir -p', although they're -# pretty handy. +# pretty handy (see function makepath for the latter). # I think some of the GNU documentation suggests that we shouldn't # rely on shell functions. However, the Bash manual seems to say that @@ -100,6 +100,8 @@ # You cannot do "export VAR=VALUE" all on one line; the export must be # separate from the assignment. (SCO SysV) +# Don't rely on grep -q, as that doesn't work everywhere -- just redirect +# stdout to /dev/null to keep it quiet. # STILL TO DO: @@ -161,6 +163,14 @@ else echo " preserve_scratch=no" fi +# Check if setfacl is around and if it supports the -k or -s option. +if setfacl --help 2>/dev/null | grep ' -k,' >/dev/null; then + setfacl_nodef='setfacl -k' +elif setfacl -s u::7,g::5,o:5 testsuite 2>/dev/null; then + setfacl_nodef='setfacl -s u::7,g::5,o:5' +else + setfacl_nodef=true +fi if [ ! -f "$rsync_bin" ]; then echo "rsync_bin $rsync_bin is not a file" >&2 @@ -175,7 +185,7 @@ fi RSYNC="$rsync_bin" #RSYNC="valgrind --tool=addrcheck $rsync_bin" -export rsync_bin RSYNC +export rsync_bin RSYNC setfacl_nodef skipped=0 missing=0 @@ -195,6 +205,9 @@ export scratchdir suitedir prep_scratch() { [ -d "$scratchdir" ] && rm -rf "$scratchdir" mkdir "$scratchdir" + # Get rid of default ACLs and dir-setgid to avoid confusing some tests. + $setfacl_nodef "$scratchdir" + chmod g-s "$scratchdir" return 0 }