From 4f24d1f74715ba7ae5511f2eb8f285ea86965166 Mon Sep 17 00:00:00 2001 From: Yuri Gorshenin Date: Fri, 3 Apr 2015 14:51:17 +0300 Subject: [PATCH] [testing] Added script that helps to run all tests. --- tools/unix/run_tests.sh | 118 ++++++++++++++++++++++++++++++++++++---- 1 file changed, 107 insertions(+), 11 deletions(-) diff --git a/tools/unix/run_tests.sh b/tools/unix/run_tests.sh index 8701509351..e7bcb13e1e 100755 --- a/tools/unix/run_tests.sh +++ b/tools/unix/run_tests.sh @@ -1,17 +1,113 @@ #!/bin/bash -set -e -u +set -u -if [ $# -lt 1 ]; then - echo "Usage:" - echo " $0 {debug|release}" - exit 115 +readonly SCRIPT_NAME=$(basename "$0") +readonly LOG=$(mktemp --tmpdir=/tmp "${SCRIPT_NAME}.XXXXXX") +readonly SMOKE_SUITE=( \ + base_tests \ + coding_tests \ + generator_tests \ + indexer_tests \ + map_tests \ + mwm_tests \ + platform_tests \ + routing_tests \ + search_tests \ +) +BUILD_DIR=. +SUITE=full + +log() { + echo "$@" 2>&1 | tee -a "$LOG" +} + +die() { + log "$@" + echo "Terminated. Log is written to $LOG" + exit 1 +} + +usage() { + log "Usage: $0 [options]" + log "Options:" + log " -b path to build directory, default: ." + log " -s test suite, smoke or full, default: full" + log " -f regular expression which is applied to all tests, default: .*" + log " -h prints this help message" + log "" + log "Smoke test suite consists of:" + for testName in "${SMOKE_SUITE[@]}" + do + log " " "$testName" + done + exit 1 +} + +while [ $# -ne 0 ] +do + case "$1" in + -b) BUILD_DIR=${2?"Build directory is not set"} + shift + ;; + -s) SUITE=${2?"Suite name is not set"} + shift + ;; + -f) FILTER=${2?"Test filter regex is not set"} + shift + ;; + -h) usage + ;; + esac + shift +done + +if [ ! -d "$BUILD_DIR" ] +then + die "Build directory $BUILD_DIR does not exists" fi -set -x +cd "$BUILD_DIR" -# Ignore GUI tests as they need display connection and can't be tested in linux console -find "`dirname $0`/../../../omim-build-$1/out/$1" -name "*_tests" \( ! -iname "gui_tests" \)| \ - grep -v /tmp/ | \ - awk '{ print $0" &&" } END { print "echo REALLY ALL TESTS PASSED" }' | \ - sh -x +case "$SUITE" in + smoke) TESTS=("${SMOKE_SUITE[@]}") + ;; + full) TESTS=($(find . -maxdepth 1 -name '*_tests')) + ;; + *) die "Unknown test suite: $SUITE" + ;; +esac + +EXIT_STATUS=0 +for testBin in "${TESTS[@]}" +do + if [ ! -x "$testBin" ] + then + die "Can't find test $testBin" + fi + + log "Running $testBin..." + if [ -z "${FILTER+undefined}" ] + then + ./$testBin 2>&1 | tee -a "$LOG" + if [ ${PIPESTATUS[0]} -ne 0 ] + then + EXIT_STATUS=1 + fi + else + ./$testBin --filter="$FILTER" 2>&1 | tee -a "$LOG" + if [ ${PIPESTATUS[0]} -ne 0 ] + then + EXIT_STATUS=1 + fi + fi +done + +if [ $EXIT_STATUS -eq 0 ] +then + log "All tests passed, see log for details." +else + log "Some of tests failed, see log for details." +fi +log "Log is written to: $LOG" +exit $EXIT_STATUS