From a56c910877d367a31e3fa11e40d93a6bec8d35fa Mon Sep 17 00:00:00 2001 From: Lukas Zapletal Date: Mon, 5 May 2014 14:18:46 +0200 Subject: [PATCH] Added one log option (--log) --- libexec/bats | 15 ++++++++++----- libexec/bats-exec-test | 10 ++++++++++ 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/libexec/bats b/libexec/bats index 732c56ae..ffc33927 100755 --- a/libexec/bats +++ b/libexec/bats @@ -16,11 +16,12 @@ help() { echo " is the path to a Bats test file, or the path to a directory" echo " containing Bats test files." echo - echo " -c, --count Count the number of test cases without running any tests" - echo " -h, --help Display this help message" - echo " -p, --pretty Show results in pretty format (default for terminals)" - echo " -t, --tap Show results in TAP format" - echo " -v, --version Display the version number" + echo " -c, --count Count the number of test cases without running any tests" + echo " -h, --help Display this help message" + echo " -p, --pretty Show results in pretty format (default for terminals)" + echo " -t, --tap Show results in TAP format" + echo " --log [FILE] Combine output and test logs into FILE" + echo " -v, --version Display the version number" echo echo " For more information, see https://github.com/sstephenson/bats" echo @@ -94,6 +95,10 @@ for option in "${options[@]}"; do "t" | "tap" ) pretty="" ;; + "log" ) + export BATS_LOG="/tmp/bats.log" + touch "$BATS_LOG" + ;; "p" | "pretty" ) pretty="1" ;; diff --git a/libexec/bats-exec-test b/libexec/bats-exec-test index 266d15c8..511a10ac 100755 --- a/libexec/bats-exec-test +++ b/libexec/bats-exec-test @@ -74,6 +74,9 @@ bats_test_begin() { if [ -n "$BATS_EXTENDED_SYNTAX" ]; then echo "begin $BATS_TEST_NUMBER $BATS_TEST_DESCRIPTION" >&3 fi + if [ -w "$BATS_LOG" ]; then + echo "[$$] $BATS_TEST_DESCRIPTION" >> "$BATS_LOG" + fi setup } @@ -195,9 +198,16 @@ bats_exit_trap() { bats_print_stack_trace >&3 sed -e "s/^/# /" < "$BATS_OUT" >&3 status=1 + to_log="not ok $BATS_TEST_DESCRIPTION" else echo "ok ${BATS_TEST_NUMBER}${skipped} ${BATS_TEST_DESCRIPTION}" >&3 status=0 + to_log="ok $BATS_TEST_DESCRIPTION" + fi + + if [ -w "$BATS_LOG" ]; then + sed -e "s/^/\[$$\] /" "$BATS_OUT" >> "$BATS_LOG" + echo "[$$] $to_log" >> "$BATS_LOG" fi rm -f "$BATS_OUT"