#!/bin/bash # Copyright 2015 The Bazel Authors. All rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # # not a proper test suite, but # - a sanity check that unittest.bash is syntactically valid # - and a means to run some quick experiments # --- begin runfiles.bash initialization --- set -euo pipefail if [[ ! -d "${RUNFILES_DIR:-/dev/null}" && ! -f "${RUNFILES_MANIFEST_FILE:-/dev/null}" ]]; then if [[ -f "$0.runfiles_manifest" ]]; then export RUNFILES_MANIFEST_FILE="$0.runfiles_manifest" elif [[ -f "$0.runfiles/MANIFEST" ]]; then export RUNFILES_MANIFEST_FILE="$0.runfiles/MANIFEST" elif [[ -f "$0.runfiles/bazel_tools/tools/bash/runfiles/runfiles.bash" ]]; then export RUNFILES_DIR="$0.runfiles" fi fi if [[ -f "${RUNFILES_DIR:-/dev/null}/bazel_tools/tools/bash/runfiles/runfiles.bash" ]]; then source "${RUNFILES_DIR}/bazel_tools/tools/bash/runfiles/runfiles.bash" elif [[ -f "${RUNFILES_MANIFEST_FILE:-/dev/null}" ]]; then source "$(grep -m1 "^bazel_tools/tools/bash/runfiles/runfiles.bash " \ "$RUNFILES_MANIFEST_FILE" | cut -d ' ' -f 2-)" else echo >&2 "ERROR: cannot find @bazel_tools//tools/bash/runfiles:runfiles.bash" exit 1 fi # --- end runfiles.bash initialization --- source "$(rlocation "io_bazel/src/test/shell/unittest.bash")" \ || { echo "Could not source unittest.bash" >&2; exit 1; } function set_up() { tmp_TEST_TMPDIR=$TEST_TMPDIR TEST_TMPDIR=$TEST_TMPDIR/$TEST_name mkdir -p $TEST_TMPDIR } function tear_down() { TEST_TMPDIR=$tmp_TEST_TMPDIR } function test_1() { echo "Everything is okay in test_1" } function test_2() { echo "Everything is okay in test_2" } function test_timestamp() { local ts=$(timestamp) [[ $ts =~ ^[0-9]{13}$ ]] || fail "timestamp wan't valid: $ts" local time_diff=$(get_run_time 100000 223456) assert_equals $time_diff 123.456 } function test_failure_message() { cd $TEST_TMPDIR cat > thing.sh <&\" escaped symbols" } run_suite "thing tests" EOF chmod +x thing.sh ./thing.sh &> $TEST_log && fail "thing.sh should fail" expect_not_log "__fail: No such file or directory" assert_contains "message=\"I'm a failure with <>&" escaped symbols\"" ${TEST_TMPDIR}/dummy.xml assert_contains "I'm a failure with <>&\" escaped symbols" ${TEST_TMPDIR}/dummy.xml assert_contains 'errors="1"' ${TEST_TMPDIR}/dummy.xml } function test_no_failure_message() { cd $TEST_TMPDIR cat > thing.sh < $TEST_log && fail "thing.sh should fail" expect_not_log "__fail: No such file or directory" assert_contains "No failure message" ${TEST_TMPDIR}/dummy.xml } function test_errexit_prints_stack_trace() { cd $TEST_TMPDIR cat > thing.sh < $TEST_log && fail "thing.sh should fail" #cat $TEST_log # Make sure the full stack trace is there. expect_log "test_thing FAILED: terminated because this command returned a non-zero status:" expect_log "./thing.sh:[0-9]*: in call to helper" expect_log "./thing.sh:[0-9]*: in call to test_thing" } run_suite "unittests Tests"