gitpod/test/run.sh

165 lines
4.6 KiB
Bash
Executable File

#!/usr/bin/env bash
#
# Convenience script to run our integration tests suites.
#
# Usage:
#
# run.sh --suite [suite] --report [report_file]
#
# Examples
#
# run.sh This will run all test suites
# run.sh -s ide This will run just the 'ide' test suite
# run.sh -s ide -r report.csv This will run just the 'ide' test suite with the report for the quality assurance
#
set -euo pipefail
REPORT=""
TEST_SUITE=all
opt=""
optarg=""
while getopts rs-: opt; do
optarg="${!OPTIND}"
[[ "$opt" = - ]] && opt="-$OPTARG"
case "-$opt" in
-r|--report)
REPORT=${optarg}
shift
;;
-s|--suit)
TEST_SUITE=${optarg}
shift
;;
*) ;;
esac
done
shift $((OPTIND - 1))
THIS_DIR="$(dirname "$0")"
FAILURE_COUNT=0
LOGS_DIR=$(mktemp -d)
WEBAPP_TEST_LIST="$THIS_DIR/tests/components/database $THIS_DIR/tests/components/server"
JETBRAINS_TESTS="$THIS_DIR/tests/ide/jetbrains"
VSCODE_TESTS="$THIS_DIR/tests/ide/vscode"
SSH_TESTS="$THIS_DIR/tests/ide/ssh"
IDE_TEST_LIST="$SSH_TESTS $VSCODE_TESTS $JETBRAINS_TESTS"
WORKSPACE_TEST_LIST="$THIS_DIR/tests/components/ws-manager $THIS_DIR/tests/components/image-builder $THIS_DIR/tests/components/content-service $THIS_DIR/tests/components/ws-daemon $THIS_DIR/tests/workspace"
case $TEST_SUITE in
"webapp")
TEST_LIST="$WEBAPP_TEST_LIST"
;;
"ide")
TEST_LIST="$IDE_TEST_LIST"
;;
"jetbrains")
TEST_LIST="$JETBRAINS_TESTS"
;;
"vscode")
TEST_LIST="$VSCODE_TESTS"
;;
"ssh")
TEST_LIST="$SSH_TESTS"
;;
"workspace")
TEST_LIST="${WORKSPACE_TEST_LIST}"
;;
"" | "all")
TEST_LIST="${WEBAPP_TEST_LIST} ${IDE_TEST_LIST} ${WORKSPACE_TEST_LIST}"
;;
*)
echo "Unknown test suite ${TEST_SUITE}"
exit 1
esac
args=()
if [ "${REPORT}" != "" ]; then
args+=( "--json" )
fi
args+=( "-kubeconfig=${KUBECONFIG:-/home/gitpod/.kube/config}" )
args+=( "-namespace=${NAMESPACE:-default}" )
args+=( "-timeout=60m" )
args+=( "-p=2" )
if [[ "${GITPOD_REPO_ROOT:-}" != "" ]]; then
echo "Running in Gitpod workspace. Fetching USERNAME and USER_TOKEN" | werft log slice "test-setup"
USERNAME="$(kubectl --context=dev -n werft get secret integration-test-user -o jsonpath='{.data.username}' | base64 -d)"
USER_TOKEN="$(kubectl --context=dev -n werft get secret integration-test-user -o jsonpath='{.data.token}' | base64 -d)"
export USER_TOKEN
else
echo "Running in Werft. Using INTEGRATION_TEST_USERNAME and INTEGRATION_TEST_USER_TOKEN for USERNAME and USER_TOKEN" | werft log slice "test-setup"
USERNAME="${INTEGRATION_TEST_USERNAME}"
USER_TOKEN="${INTEGRATION_TEST_USER_TOKEN}"
export USERNAME
export USER_TOKEN
fi
werft log slice "test-setup" --done
[[ "$USERNAME" != "" ]] && args+=( "-username=$USERNAME" )
if [ "$TEST_SUITE" == "workspace" ]; then
TEST_NAME="workspace"
LOG_FILE="${LOGS_DIR}/${TEST_NAME}.log"
cd "$THIS_DIR"
echo "running integration for ${TEST_NAME} - log file at ${LOG_FILE}" | werft log slice "test-${TEST_NAME}-parallel"
set +e
# shellcheck disable=SC2086
go test -v $TEST_LIST "${args[@]}" -run '.*[^.SerialOnly]$' 2>&1 | tee "${LOG_FILE}" | werft log slice "test-${TEST_NAME}-parallel"
RC=${PIPESTATUS[0]}
set -e
if [ "${RC}" -ne "0" ]; then
FAILURE_COUNT=$((FAILURE_COUNT+1))
werft log slice "test-${TEST_NAME}-parallel" --fail "${RC}"
else
werft log slice "test-${TEST_NAME}-parallel" --done
fi
echo "running integration for ${TEST_NAME} - log file at ${LOG_FILE}" | werft log slice "test-${TEST_NAME}-serial-only"
set +e
# shellcheck disable=SC2086
go test -v $TEST_LIST "${args[@]}" -run '.*SerialOnly$' -p 1 2>&1 | tee -a "${LOG_FILE}" | werft log slice "test-${TEST_NAME}-serial-only"
RC=${PIPESTATUS[0]}
set -e
if [ "${RC}" -ne "0" ]; then
FAILURE_COUNT=$((FAILURE_COUNT+1))
werft log slice "test-${TEST_NAME}-serial-only" --fail "${RC}"
else
werft log slice "test-${TEST_NAME}-serial-only" --done
fi
cd -
if [ "${REPORT}" != "" ]; then
./report.sh "${LOG_FILE}" > "$REPORT"
fi
else
for TEST_PATH in ${TEST_LIST}
do
TEST_NAME=$(basename "${TEST_PATH}")
LOG_FILE="${LOGS_DIR}/${TEST_NAME}.log"
echo "running integration for ""${TEST_NAME}"" - log file at ${LOG_FILE}" | werft log slice "test-${TEST_NAME}"
cd "${TEST_PATH}"
set +e
go test -v ./... "${args[@]}" 2>&1 | tee "${LOG_FILE}" | werft log slice "test-${TEST_NAME}"
RC=${PIPESTATUS[0]}
set -e
cd -
if [ "${RC}" -ne "0" ]; then
FAILURE_COUNT=$((FAILURE_COUNT+1))
werft log slice "test-${TEST_NAME}" --fail "${RC}"
else
werft log slice "test-${TEST_NAME}" --done
fi
done
fi
exit $FAILURE_COUNT