X-Git-Url: http://gitweb.michael.orlitzky.com/?a=blobdiff_plain;f=run-tests.sh;h=37414302865f93d99f661fab70b29c7a26ca08e2;hb=2968629aa21aa275e09e19128bf2e36fe82096ad;hp=d87c678b811e90ce23bf32514914dbd0c0901460;hpb=95356899dfc03215a775868b77d4d1bcb5613027;p=apply-default-acl.git diff --git a/run-tests.sh b/run-tests.sh index d87c678..3741430 100755 --- a/run-tests.sh +++ b/run-tests.sh @@ -671,14 +671,14 @@ compare # If we call apply-default-acl on a single file that does not exist, # we get the expected error. TESTNUM=25 -ACTUAL=$( ${BIN} test/nonexistent 2>&1 ) -EXPECTED="${BIN}: test/nonexistent: No such file or directory" +ACTUAL=$( "${BIN}" test/nonexistent 2>&1 ) +EXPECTED="test/nonexistent: No such file or directory" compare # Same as the previous test, but with --recursive. TESTNUM=26 -ACTUAL=$( ${BIN} --recursive test/nonexistent 2>&1 ) -EXPECTED="${BIN}: test/nonexistent: No such file or directory" +ACTUAL=$( "${BIN}" --recursive test/nonexistent 2>&1 ) +EXPECTED="test/nonexistent: No such file or directory" compare # If we call apply-default-acl on more than one file, it should report any @@ -687,8 +687,8 @@ TESTNUM=27 DUMMY1="${TESTDIR}/dummy1" DUMMY2="${TESTDIR}/dummy2" touch "${DUMMY1}" "${DUMMY2}" -ACTUAL=$( ${BIN} "${DUMMY1}" test/nonexistent "${DUMMY2}" 2>&1 ) -EXPECTED="${BIN}: test/nonexistent: No such file or directory" +ACTUAL=$( "${BIN}" "${DUMMY1}" test/nonexistent "${DUMMY2}" 2>&1 ) +EXPECTED="test/nonexistent: No such file or directory" compare @@ -760,7 +760,7 @@ LINK2TARGET="${TESTDIR}/baz" mkdir -p $(dirname "${TARGET}") touch "${TARGET}" ln -s foo "${TESTDIR}/baz" -setfacl --default --modify user:${USERS[0]}:rw "${TESTDIR}/foo" +setfacl --default --modify user:${USERS[0]}:rw $(dirname "${TARGET}") pushd "${TESTDIR}/baz" > /dev/null "${BIN}" bar popd > /dev/null @@ -775,3 +775,94 @@ other::r-- EOF ) compare + + +# Ensure that symlinks in non-terminal path components are not followed. +TESTNUM=32 +TARGET="${TESTDIR}/foo/bar/baz" +LINK2FOO="${TESTDIR}/quux" +mkdir -p $(dirname "${TARGET}") +touch "${TARGET}" +ln -s foo "${LINK2FOO}" +setfacl --default --modify user:${USERS[0]}:rw $(dirname "${TARGET}") +"${BIN}" "${LINK2FOO}/bar/baz" +ACTUAL=$( getfacl --omit-header "${TARGET}" ) +EXPECTED=$(cat </dev/null +ACTUAL="$?" +EXPECTED="1" +compare + + +# Test that one "failure" exit code overrides two "successes" +# We need a default ACL on ${TESTDIR} because otherwise we do +# nothing, successfully, on the symlink path. +TESTNUM=37 +mkdir "${TESTDIR}/foo" +ln -s foo "${TESTDIR}/bar" +mkdir "${TESTDIR}/baz" +setfacl --default --modify user:${USERS[0]}:rw "${TESTDIR}" +"${BIN}" "${TESTDIR}/foo" "${TESTDIR}/bar" "${TESTDIR}/baz" +ACTUAL="$?" +EXPECTED="1" +compare + + +# And test the buggy behavior again; the previous test should return +# success (ignoring the failure) when --recursive is used. +TESTNUM=38 +mkdir "${TESTDIR}/foo" +ln -s foo "${TESTDIR}/bar" +mkdir "${TESTDIR}/baz" +"${BIN}" --recursive "${TESTDIR}" +ACTUAL="$?" +EXPECTED="0" +compare