commit 4514bfe9c25f3222e0feba29c5129229287f3963 Author: teor teor@torproject.org Date: Tue Nov 12 16:45:07 2019 +1000
test/parseconf: Stop ignoring --dump-config failures
When we added the $FILTER for Windows newlines, we made the pipeline always exit successfully, even if tor failed.
Fixes bug 32468; bugfix on 0.4.2.1-alpha. --- changes/bug32468 | 3 + src/test/conf_examples/pt_02/error | 1 + src/test/conf_examples/pt_02/expected | 0 src/test/conf_examples/pt_09/error | 1 + src/test/conf_examples/pt_09/expected | 0 src/test/conf_examples/relay_02/error | 1 + src/test/conf_examples/relay_02/expected | 0 src/test/test_parseconf.sh | 189 +++++++++++++++++++------------ 8 files changed, 120 insertions(+), 75 deletions(-)
diff --git a/changes/bug32468 b/changes/bug32468 new file mode 100644 index 000000000..fa0d87709 --- /dev/null +++ b/changes/bug32468 @@ -0,0 +1,3 @@ + o Minor bugfixes (testing): + - Stop ignoring "tor --dump-config" errors in test_parseconf.sh. + Fixes bug 32468; bugfix on 0.4.2.1-alpha. diff --git a/src/test/conf_examples/pt_02/error b/src/test/conf_examples/pt_02/error new file mode 100644 index 000000000..ce28eab72 --- /dev/null +++ b/src/test/conf_examples/pt_02/error @@ -0,0 +1 @@ +Invalid ExtORPort configuration diff --git a/src/test/conf_examples/pt_02/expected b/src/test/conf_examples/pt_02/expected deleted file mode 100644 index e69de29bb..000000000 diff --git a/src/test/conf_examples/pt_09/error b/src/test/conf_examples/pt_09/error new file mode 100644 index 000000000..882b50a7b --- /dev/null +++ b/src/test/conf_examples/pt_09/error @@ -0,0 +1 @@ +Error parsing ServerTransportListenAddr address \ No newline at end of file diff --git a/src/test/conf_examples/pt_09/expected b/src/test/conf_examples/pt_09/expected deleted file mode 100644 index e69de29bb..000000000 diff --git a/src/test/conf_examples/relay_02/error b/src/test/conf_examples/relay_02/error new file mode 100644 index 000000000..dd87d9f7e --- /dev/null +++ b/src/test/conf_examples/relay_02/error @@ -0,0 +1 @@ +Unrecognized value bad diff --git a/src/test/conf_examples/relay_02/expected b/src/test/conf_examples/relay_02/expected deleted file mode 100644 index e69de29bb..000000000 diff --git a/src/test/test_parseconf.sh b/src/test/test_parseconf.sh index 962d43dd7..b84350985 100755 --- a/src/test/test_parseconf.sh +++ b/src/test/test_parseconf.sh @@ -102,6 +102,8 @@ umask 077 set -e
+MYNAME="$0" + # emulate realpath(), in case coreutils or equivalent is not installed. abspath() { f="$*" @@ -156,7 +158,20 @@ fi
FINAL_EXIT=0
-die() { echo "$1" >&2 ; FINAL_EXIT=$EXITCODE; } +NEXT_TEST= +fail() { printf "FAIL: " >&2; + # The first argument is a printf string, so this warning is spurious + # shellcheck disable=SC2059 + printf "$@" >&2; + printf '\n' >&2; + NEXT_TEST="yes" + FINAL_EXIT=$EXITCODE; } +die() { printf "FAIL: CRITICAL error in '%s':" "$MYNAME" >&2; + # The first argument is a printf string, so this warning is spurious + # shellcheck disable=SC2059 + printf "$@" >&2; + printf '\n' >&2; + exit $EXITCODE; }
if test "$WINDOWS" = 1; then FILTER="dos2unix" @@ -166,7 +181,8 @@ fi
EMPTY="${DATA_DIR}/EMPTY"
-touch "$EMPTY" || die "Couldn't create empty file." +touch "$EMPTY" || die "Couldn't create empty file '%s'." \ + "$EMPTY"
STANDARD_LIBS="libevent\|openssl\|zlib" # Lib names are restricted to [a-z0-9]* at the moment @@ -185,9 +201,8 @@ TOR_LIBS_ENABLED=${TOR_LIBS_ENABLED%_} # If we ever have more than 3 optional libraries, we'll need more code here TOR_LIBS_ENABLED_COUNT="$(echo "$TOR_LIBS_ENABLED_SEARCH" \ | tr ' ' '\n' | wc -l)" -if [ "$TOR_LIBS_ENABLED_COUNT" -gt 3 ]; then - echo "$0 can not handle more than 3 optional libraries" - exit 1 +if test "$TOR_LIBS_ENABLED_COUNT" -gt 3; then + die "Can not handle more than 3 optional libraries" fi # Brute-force the combinations of libraries TOR_LIBS_ENABLED_SEARCH_3="$(echo "$TOR_LIBS_ENABLED" \ @@ -214,7 +229,9 @@ fi echo "Disabled Modules: ${TOR_MODULES_DISABLED:-(None)}"
for dir in "${EXAMPLEDIR}"/*; do - if ! test -d "${dir}"; then + NEXT_TEST= + + if ! test -d "$dir"; then # Only count directories. continue fi @@ -254,10 +271,11 @@ for dir in "${EXAMPLEDIR}"/*; do
# Check for broken configs if test -f "./error${suffix}"; then - echo "FAIL: Found both ${dir}/expected${suffix}" >&2 - echo "and ${dir}/error${suffix}." >&2 - echo "(Only one of these files should exist.)" >&2 - FINAL_EXIT=$EXITCODE + fail "Found both '%s' and '%s'.%s" \ + "${dir}/expected${suffix}" \ + "${dir}/error${suffix}" \ + "(Only one of these files should exist.)" + break fi
EXPECTED="./expected${suffix}" @@ -272,92 +290,114 @@ for dir in "${EXAMPLEDIR}"/*; do fi done
- # Exit as soon as the inner loop finds a file - if test -f "$EXPECTED" || test -f "$ERROR"; then + # Exit as soon as the inner loop finds a file, or fails + if test -f "$EXPECTED" || test -f "$ERROR" || test "$NEXT_TEST"; then break fi done
- if test -f "$EXPECTED"; then + if test "$NEXT_TEST"; then + # The test failed inside the file search loop: go to the next test + continue + elif test -f "$EXPECTED"; then # This case should succeed: run dump-config and see if it does. - FAILED_LOG= - FAILED_CONFIG=
if test -f "$EXPECTED_LOG"; then if ! test -s "$EXPECTED_LOG"; then - echo "FAIL: expected log file '$EXPECTED_LOG' is empty." >&2 - echo "Empty expected log files match any output." >&2 - FINAL_EXIT=$EXITCODE + fail "Expected log file '%s' is empty.%s" \ + "$EXPECTED_LOG" \ + "(Empty expected log files match any output.)" + continue fi fi
- "${TOR_BINARY}" -f "./torrc" \ - --defaults-torrc "${DEFAULTS}" \ - --dump-config short \ - ${CMDLINE} \ - | "${FILTER}" > "${DATA_DIR}/output.${testname}" \ - || die "FAIL: $EXPECTED: Tor reported an error." + "$TOR_BINARY" -f "./torrc" \ + --defaults-torrc "$DEFAULTS" \ + --dump-config short \ + $CMDLINE > "${DATA_DIR}/output_raw.${testname}" \ + || fail "'%s': Tor --dump-config reported an error." \ + "$EXPECTED"
+ "$FILTER" "${DATA_DIR}/output_raw.${testname}" \ + > "${DATA_DIR}/output.${testname}" \ + || fail "'%s': Filter '%s' reported an error." \ + "$EXPECTED" \ + "$FILTER"
- if cmp "$EXPECTED" "${DATA_DIR}/output.${testname}">/dev/null ; then + if cmp "$EXPECTED" "${DATA_DIR}/output.${testname}" > /dev/null; then # Check round-trip. - "${TOR_BINARY}" -f "${DATA_DIR}/output.${testname}" \ - --defaults-torrc "${DATA_DIR}/empty" \ - --dump-config short \ - | "${FILTER}" \ - > "${DATA_DIR}/output_2.${testname}" \ - || die \ - "FAIL: $EXPECTED: Tor reported an error on round-trip." + "$TOR_BINARY" -f "${DATA_DIR}/output.${testname}" \ + --defaults-torrc "$EMPTY" \ + --dump-config short \ + > "${DATA_DIR}/output_2_raw.${testname}" \ + || fail "'%s': Tor --dump-config reported an error%s." \ + "$EXPECTED" \ + " on round-trip" + + "$FILTER" "${DATA_DIR}/output_2_raw.${testname}" \ + > "${DATA_DIR}/output_2.${testname}" \ + || fail "'%s': Filter '%s' reported an error." \ + "$EXPECTED" \ + "$FILTER"
if ! cmp "${DATA_DIR}/output.${testname}" \ "${DATA_DIR}/output_2.${testname}"; then - echo "FAIL: $EXPECTED did not match on round-trip:" >&2 + fail "'%s': did not match on round-trip:" \ + "$EXPECTED" diff -u "${DATA_DIR}/output.${testname}" \ "${DATA_DIR}/output_2.${testname}" >&2 \ || true - FINAL_EXIT=$EXITCODE fi else - FAILED_CONFIG="yes" if test "$(wc -c < "${DATA_DIR}/output.${testname}")" = 0; then - echo "FAIL: $EXPECTED: Tor said:" >&2 # There was no output -- probably we failed. - "${TOR_BINARY}" -f "./torrc" \ - --defaults-torrc "${DEFAULTS}" \ - --verify-config \ - ${CMDLINE} || true + fail "'%s': Tor said:" \ + "$EXPECTED" + "$TOR_BINARY" -f "./torrc" \ + --defaults-torrc "$DEFAULTS" \ + --verify-config \ + $CMDLINE >&2 \ + || true fi - echo "FAIL: $EXPECTED did not match:" >&2 + fail "'%s' did not match:" \ + "$EXPECTED" diff -u "$EXPECTED" "${DATA_DIR}/output.${testname}" >&2 \ || true - FINAL_EXIT=$EXITCODE fi
- if test -f "$EXPECTED_LOG"; then + if test -f "$EXPECTED_LOG" || test "$NEXT_TEST"; then # This case should succeed: run verify-config and see if it does. + # + # As a temporary hack, we also use this code when --dump-config + # has failed, to display the error logs. + if ! test -f "$EXPECTED_LOG"; then + NON_EMPTY="${DATA_DIR}/NON_EMPTY" + echo "This pattern should not match any log messages" \ + > "$NON_EMPTY" + EXPECTED_LOG=$NON_EMPTY + fi
- "${TOR_BINARY}" --verify-config \ - -f ./torrc \ - --defaults-torrc "${DEFAULTS}" \ - ${CMDLINE} \ - > "${DATA_DIR}/output_log.${testname}" \ - || die "FAIL: $EXPECTED_LOG: Tor reported an error." - - expect_log="$(cat "$EXPECTED_LOG")" - if grep "${expect_log}" "${DATA_DIR}/output_log.${testname}" \ - >/dev/null; then + "$TOR_BINARY" --verify-config \ + -f ./torrc \ + --defaults-torrc "$DEFAULTS" \ + $CMDLINE \ + > "${DATA_DIR}/output_log.${testname}" \ + || fail "'%s': Tor --verify-config reported an error." \ + "$EXPECTED_LOG" + + expect_log="$(cat "${EXPECTED_LOG}")" + if grep "$expect_log" "${DATA_DIR}/output_log.${testname}" \ + > /dev/null; then : else - FAILED_LOG="yes" - echo "FAIL: Expected $EXPECTED_LOG:" >&2 - echo "${expect_log}" >&2 - echo "Tor said:" >&2 + fail "Expected '%s':\n%s\nTor said:" \ + "$EXPECTED_LOG" \ + "$expect_log" cat "${DATA_DIR}/output_log.${testname}" >&2 - FINAL_EXIT=$EXITCODE fi fi
- if test -z "${FAILED_LOG}${FAILED_CONFIG}"; then + if test -z "$NEXT_TEST"; then echo "OK" fi
@@ -365,35 +405,34 @@ for dir in "${EXAMPLEDIR}"/*; do # This case should fail: run verify-config and see if it does.
if ! test -s "$ERROR"; then - echo "FAIL: error file '$ERROR' is empty." >&2 - echo "Empty error files match any output." >&2 - FINAL_EXIT=$EXITCODE + fail "Error file '%s' is empty.%s" \ + "$ERROR" \ + "(Empty error files match any output.)" + continue fi
- "${TOR_BINARY}" --verify-config \ - -f ./torrc \ - --defaults-torrc "${DEFAULTS}" \ - ${CMDLINE} \ - > "${DATA_DIR}/output.${testname}" \ - && die "FAIL: $ERROR: Tor did not report an error." + "$TOR_BINARY" --verify-config \ + -f ./torrc \ + --defaults-torrc "$DEFAULTS" \ + $CMDLINE \ + > "${DATA_DIR}/output.${testname}" \ + && fail "'%s': Tor did not report an error." \ + "$ERROR"
expect_err="$(cat "$ERROR")" if grep "${expect_err}" "${DATA_DIR}/output.${testname}" >/dev/null; then echo "OK" else - echo "FAIL: Expected $ERROR: " >&2 - echo "${expect_err}" >&2 - echo "Tor said:" >&2 + fail "Expected '%s':\n%s\nTor said:" \ + "$ERROR" \ + "$expect_err" cat "${DATA_DIR}/output.${testname}" >&2 - FINAL_EXIT=$EXITCODE fi
else # This case is not actually configured with a success or a failure. # call that an error. - - echo "FAIL: Did not find ${dir}/*expected or ${dir}/*error." >&2 - FINAL_EXIT=$EXITCODE + fail "Did not find ${dir}/*expected or ${dir}/*error." fi
cd "${PREV_DIR}"