[tor-commits] [tor/master] test/parseconf: Show tor command lines on failure
nickm at torproject.org
nickm at torproject.org
Thu Nov 14 14:58:58 UTC 2019
commit 2c4ada729e275f37a2165866a78378ff606cb451
Author: teor <teor at torproject.org>
Date: Thu Nov 14 10:50:20 2019 +1000
test/parseconf: Show tor command lines on failure
Part of 32451.
---
src/test/test_parseconf.sh | 88 +++++++++++++++++++++++++++++++---------------
1 file changed, 59 insertions(+), 29 deletions(-)
diff --git a/src/test/test_parseconf.sh b/src/test/test_parseconf.sh
index 816ed97e3..2156077d7 100755
--- a/src/test/test_parseconf.sh
+++ b/src/test/test_parseconf.sh
@@ -252,6 +252,15 @@ FALSE=1
# Send tor's standard output to stderr.
log_verify_config()
{
+ # show the command we're about to execute
+ # log_verify_config() is only called when we've failed
+ printf "Tor --verify-config said:\\n" >&2
+ printf "$ %s %s %s %s %s %s %s\\n" \
+ "$TOR_BINARY" --verify-config \
+ -f "$1" \
+ --defaults-torrc "$2" \
+ "$3" \
+ >&2
# We need cmdline unquoted
# shellcheck disable=SC2086
"$TOR_BINARY" --verify-config \
@@ -266,6 +275,8 @@ log_verify_config()
# may be $EMPTY. Pass tor the extra command line arguments $3, which will be
# passed unquoted. Send tor's standard output to $4.
#
+# Set $FULL_TOR_CMD to the tor command line that was executed.
+#
# If tor fails, fail_printf() using the file name $5, and context $6,
# which may be an empty string. Then run log_verify_config().
dump_config()
@@ -276,6 +287,13 @@ dump_config()
CONTEXT=""
fi
+ # keep the command we're about to execute, and show if it we fail
+ FULL_TOR_CMD=$(printf "$ %s %s %s %s %s %s %s %s" \
+ "$TOR_BINARY" --dump-config short \
+ -f "$1" \
+ --defaults-torrc "$2" \
+ "$3"
+ )
# We need cmdline unquoted
# shellcheck disable=SC2086
if ! "$TOR_BINARY" --dump-config short \
@@ -283,9 +301,10 @@ dump_config()
--defaults-torrc "$2" \
$3 \
> "$4"; then
- fail_printf "'%s': Tor --dump-config reported an error%s. Tor said:" \
+ fail_printf "'%s': Tor --dump-config reported an error%s:\\n%s" \
"$5" \
- "$CONTEXT"
+ "$CONTEXT" \
+ "$FULL_TOR_CMD"
log_verify_config "$1" \
"$2" \
"$3"
@@ -314,19 +333,18 @@ filter()
# Compare the expected file $1, and output file $2.
#
-# If they are different, fail. If this is the first step that failed in this
-# test, run log_verify_config() with torrc $3, defaults torrc $4, and command
-# line $5, to log Tor's error messages. Finally, log the differences between
-# the files.
+# If they are different, fail. Log the differences between the files.
+# Run log_verify_config() with torrc $3, defaults torrc $4, and command
+# line $5, to log Tor's error messages.
#
# If the file contents are identical, returns true. Otherwise, return false.
#
-# Log failure messages using fail_printf(), with the expected file name, and
-# context $6, which may be an empty string.
+# Log failure messages using fail_printf(), with the expected file name,
+# context $6, which may be an empty string, and the tor command line $7.
check_diff()
{
if test "$6"; then
- CONTEXT=" $=6"
+ CONTEXT=" $6"
else
CONTEXT=""
fi
@@ -334,21 +352,15 @@ check_diff()
if cmp "$1" "$2" > /dev/null; then
return "$TRUE"
else
- # If this is the first step that failed in this test,
- # show tor's logs
- if test -z "$NEXT_TEST"; then
- fail_printf "'%s': Tor said%s:" \
- "$1" \
- "$CONTEXT"
- log_verify_config "$3" \
- "$4" \
- "$5"
- fi
- fail_printf "'%s' did not match%s:" \
+ fail_printf "'%s': Tor --dump-config said%s:\\n%s" \
"$1" \
- "$CONTEXT"
+ "$CONTEXT" \
+ "$7"
diff -u "$1" "$2" >&2 \
|| true
+ log_verify_config "$3" \
+ "$4" \
+ "$5"
return "$FALSE"
fi
}
@@ -372,6 +384,8 @@ check_dump_config()
{
OUTPUT="$4"
OUTPUT_RAW="${OUTPUT}_raw"
+
+ FULL_TOR_CMD=
dump_config "$1" \
"$2" \
"$3" \
@@ -389,8 +403,8 @@ check_dump_config()
"$1" \
"$2" \
"$3" \
- "$5" \
- "$6"; then
+ "$6" \
+ "$FULL_TOR_CMD"; then
return "$TRUE"
else
return "$FALSE"
@@ -416,11 +430,21 @@ check_empty_pattern()
# be $EMPTY. Pass tor the extra command line arguments $3, which will be
# passed unquoted. Send tor's standard output to $4.
#
+# Set $FULL_TOR_CMD to the tor command line that was executed.
+#
# If tor's exit status does not match the boolean $5, fail_printf()
# using the file name $6, and context $7, which is required.
verify_config()
{
RESULT=$TRUE
+
+ # keep the command we're about to execute, and show if it we fail
+ FULL_TOR_CMD=$(printf "$ %s %s %s %s %s %s %s" \
+ "$TOR_BINARY" --verify-config \
+ -f "$1" \
+ --defaults-torrc "$2" \
+ "$3"
+ )
# We need cmdline unquoted
# shellcheck disable=SC2086
"$TOR_BINARY" --verify-config \
@@ -431,9 +455,11 @@ verify_config()
# Convert the actual and expected results to boolean, and compare
if test $((! (! RESULT))) -ne $((! (! $5))); then
- fail_printf "'%s': Tor --verify-config did not %s." \
+ fail_printf "'%s': Tor --verify-config did not %s:\\n%s" \
"$6" \
- "$7"
+ "$7" \
+ "$FULL_TOR_CMD"
+ cat "$4" >&2
fi
}
@@ -445,15 +471,17 @@ verify_config()
# Log the pattern, and the entire contents of the output file.
#
# Log failure messages using fail_printf(), with the match file name,
-# and context $3, which is required.
+# context $3, and tor command line $4, which are required.
check_pattern()
{
expect_log="$(cat "$1")"
if ! grep "$expect_log" "$2" > /dev/null; then
- fail_printf "Expected %s '%s':\\n%s\\nTor said:" \
+ fail_printf "Expected %s '%s':\\n%s" \
"$3" \
"$1" \
"$expect_log"
+ printf "Tor --verify-config said:\\n%s\\n" \
+ "$4" >&2
cat "$2" >&2
fi
}
@@ -479,6 +507,7 @@ check_verify_config()
return
fi
+ FULL_TOR_CMD=
verify_config "$1" \
"$2" \
"$3" \
@@ -489,7 +518,8 @@ check_verify_config()
check_pattern "$6" \
"$4" \
- "$7"
+ "$7" \
+ "$FULL_TOR_CMD"
}
for dir in "${EXAMPLEDIR}"/*; do
@@ -591,7 +621,7 @@ for dir in "${EXAMPLEDIR}"/*; do
"${DATA_DIR}/output_log.${testname}" \
"$TRUE" \
"$EXPECTED_LOG" \
- "log ok"
+ "log success"
fi
elif test -f "$ERROR"; then
More information about the tor-commits
mailing list