You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
5.9 KiB
208 lines
5.9 KiB
#!/bin/bash
|
|
#
|
|
# Mint (C) 2017, 2018 Minio, Inc.
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
CONTAINER_ID=$(awk -F / '{ print substr($NF, 1, 12) }' /proc/1/cpuset)
|
|
MINT_DATA_DIR=${MINT_DATA_DIR:-/mint/data}
|
|
MINT_MODE=${MINT_MODE:-core}
|
|
SERVER_REGION=${SERVER_REGION:-us-east-1}
|
|
ENABLE_HTTPS=${ENABLE_HTTPS:-0}
|
|
ENABLE_VIRTUAL_STYLE=${ENABLE_VIRTUAL_STYLE:-0}
|
|
GO111MODULE=on
|
|
GOPROXY=https://proxy.golang.org
|
|
|
|
if [ -z "$SERVER_ENDPOINT" ]; then
|
|
SERVER_ENDPOINT="play.minio.io:9000"
|
|
ACCESS_KEY="Q3AM3UQ867SPQQA43P2F"
|
|
SECRET_KEY="zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"
|
|
ENABLE_HTTPS=1
|
|
fi
|
|
|
|
if [ "$ENABLE_VIRTUAL_STYLE" -eq 1 ]; then
|
|
SERVER_IP="${SERVER_ENDPOINT%%:*}"
|
|
SERVER_PORT="${SERVER_ENDPOINT/*:/}"
|
|
# Check if SERVER_IP is actually IPv4 address
|
|
octets=("${SERVER_IP//./ }")
|
|
if [ "${#octets[@]}" -ne 4 ]; then
|
|
echo "$SERVER_IP must be an IP address"
|
|
exit 1
|
|
fi
|
|
for octet in "${octets[@]}"; do
|
|
if [ "$octet" -lt 0 ] 2>/dev/null || [ "$octet" -gt 255 ] 2>/dev/null; then
|
|
echo "$SERVER_IP must be an IP address"
|
|
exit 1
|
|
fi
|
|
done
|
|
fi
|
|
|
|
ROOT_DIR="$PWD"
|
|
TESTS_DIR="$ROOT_DIR/run/core"
|
|
|
|
BASE_LOG_DIR="$ROOT_DIR/log"
|
|
LOG_FILE="log.json"
|
|
ERROR_FILE="error.log"
|
|
mkdir -p "$BASE_LOG_DIR"
|
|
|
|
function humanize_time()
|
|
{
|
|
time="$1"
|
|
days=$(( time / 60 / 60 / 24 ))
|
|
hours=$(( time / 60 / 60 % 24 ))
|
|
minutes=$(( time / 60 % 60 ))
|
|
seconds=$(( time % 60 ))
|
|
|
|
(( days > 0 )) && echo -n "$days days "
|
|
(( hours > 0 )) && echo -n "$hours hours "
|
|
(( minutes > 0 )) && echo -n "$minutes minutes "
|
|
(( days > 0 || hours > 0 || minutes > 0 )) && echo -n "and "
|
|
echo "$seconds seconds"
|
|
}
|
|
|
|
function run_test()
|
|
{
|
|
if [ ! -d "$1" ]; then
|
|
return 1
|
|
fi
|
|
|
|
start=$(date +%s)
|
|
|
|
mkdir -p "$BASE_LOG_DIR/$sdk_name"
|
|
|
|
(cd "$sdk_dir" && ./run.sh "$BASE_LOG_DIR/$LOG_FILE" "$BASE_LOG_DIR/$sdk_name/$ERROR_FILE")
|
|
rv=$?
|
|
end=$(date +%s)
|
|
duration=$(humanize_time $(( end - start )))
|
|
|
|
if [ "$rv" -eq 0 ]; then
|
|
echo "done in $duration"
|
|
else
|
|
echo "FAILED in $duration"
|
|
entry=$(tail -n 1 "$BASE_LOG_DIR/$LOG_FILE")
|
|
status=$(jq -e -r .status <<<"$entry")
|
|
jq_rv=$?
|
|
if [ "$jq_rv" -ne 0 ]; then
|
|
echo "$entry"
|
|
fi
|
|
## Show error.log when status is empty or not "FAIL".
|
|
## This may happen when test run failed without providing logs.
|
|
if [ "$jq_rv" -ne 0 ] || [ -z "$status" ] || ([ "$status" != "FAIL" ] && [ "$status" != "fail" ]); then
|
|
cat "$BASE_LOG_DIR/$sdk_name/$ERROR_FILE"
|
|
else
|
|
jq . <<<"$entry"
|
|
fi
|
|
fi
|
|
return $rv
|
|
}
|
|
|
|
function trust_s3_endpoint_tls_cert()
|
|
{
|
|
# Download the public certificate from the server
|
|
openssl s_client -showcerts -connect "$SERVER_ENDPOINT" </dev/null 2>/dev/null | \
|
|
openssl x509 -outform PEM -out /usr/local/share/ca-certificates/s3_server_cert.crt || \
|
|
exit -1
|
|
|
|
# Load the certificate in the system
|
|
update-ca-certificates --fresh >/dev/null
|
|
|
|
# Ask different SDKs/tools to load system certificates
|
|
export REQUESTS_CA_BUNDLE=/etc/ssl/certs/ca-certificates.crt
|
|
export NODE_EXTRA_CA_CERTS=/etc/ssl/certs/ca-certificates.crt
|
|
export SSL_CERT_FILE=/etc/ssl/certs/ca-certificates.crt
|
|
}
|
|
|
|
|
|
function main()
|
|
{
|
|
export MINT_DATA_DIR
|
|
export MINT_MODE
|
|
export SERVER_ENDPOINT
|
|
export SERVER_IP
|
|
export SERVER_PORT
|
|
|
|
export ACCESS_KEY
|
|
export SECRET_KEY
|
|
export ENABLE_HTTPS
|
|
export SERVER_REGION
|
|
export ENABLE_VIRTUAL_STYLE
|
|
export GO111MODULE
|
|
export GOPROXY
|
|
|
|
echo "Running with"
|
|
echo "SERVER_ENDPOINT: $SERVER_ENDPOINT"
|
|
echo "ACCESS_KEY: $ACCESS_KEY"
|
|
echo "SECRET_KEY: ***REDACTED***"
|
|
echo "ENABLE_HTTPS: $ENABLE_HTTPS"
|
|
echo "SERVER_REGION: $SERVER_REGION"
|
|
echo "MINT_DATA_DIR: $MINT_DATA_DIR"
|
|
echo "MINT_MODE: $MINT_MODE"
|
|
echo "ENABLE_VIRTUAL_STYLE: $ENABLE_VIRTUAL_STYLE"
|
|
echo
|
|
echo "To get logs, run 'docker cp ${CONTAINER_ID}:/mint/log /tmp/mint-logs'"
|
|
echo
|
|
|
|
[ "$ENABLE_HTTPS" == "1" ] && trust_s3_endpoint_tls_cert
|
|
|
|
declare -a run_list
|
|
if [ "$MINT_MODE" == "worm" ]; then
|
|
if [ "$#" -gt 1 ]; then
|
|
echo "No argument is accepted for worm mode"
|
|
exit 1
|
|
fi
|
|
|
|
run_list=( "$TESTS_DIR/worm" )
|
|
else
|
|
sdks=( "$@" )
|
|
|
|
## populate all sdks except worm when no argument is given.
|
|
if [ "$#" -eq 0 ]; then
|
|
sdks=( $(ls -I worm "$TESTS_DIR") )
|
|
fi
|
|
|
|
for sdk in "${sdks[@]}"; do
|
|
if [ "$sdk" == "worm" ]; then
|
|
echo "worm test cannot be run without worm mode"
|
|
exit 1
|
|
fi
|
|
|
|
run_list=( "${run_list[@]}" "$TESTS_DIR/$sdk" )
|
|
done
|
|
fi
|
|
|
|
count="${#run_list[@]}"
|
|
i=0
|
|
for sdk_dir in "${run_list[@]}"; do
|
|
sdk_name=$(basename "$sdk_dir")
|
|
(( i++ ))
|
|
if [ ! -d "$sdk_dir" ]; then
|
|
echo "Test $sdk_name not found. Exiting Mint."
|
|
exit 1
|
|
fi
|
|
echo -n "($i/$count) Running $sdk_name tests ... "
|
|
if ! run_test "$sdk_dir"; then
|
|
(( i-- ))
|
|
break
|
|
fi
|
|
done
|
|
|
|
## Report when all tests in run_list are run
|
|
if [ $i -eq "$count" ]; then
|
|
echo -e "\nAll tests ran successfully"
|
|
else
|
|
echo -e "\nExecuted $i out of $count tests successfully."
|
|
exit 1
|
|
fi
|
|
}
|
|
main "$@"
|
|
|