2014-10-23 23:13:46 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Copyright 2014 Google Inc. 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.
|
|
|
|
|
2015-02-05 08:00:28 +00:00
|
|
|
set -o errexit
|
|
|
|
set -o nounset
|
|
|
|
set -o pipefail
|
|
|
|
|
2015-02-05 00:57:53 +00:00
|
|
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/..
|
2015-02-05 08:00:28 +00:00
|
|
|
|
2015-03-05 23:41:52 +00:00
|
|
|
# --- Find local test binaries.
|
2015-04-14 18:24:49 +00:00
|
|
|
|
|
|
|
# Detect the OS name/arch so that we can find our binary
|
|
|
|
case "$(uname -s)" in
|
|
|
|
Darwin)
|
|
|
|
host_os=darwin
|
|
|
|
;;
|
|
|
|
Linux)
|
|
|
|
host_os=linux
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "Unsupported host OS. Must be Linux or Mac OS X." >&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case "$(uname -m)" in
|
|
|
|
x86_64*)
|
|
|
|
host_arch=amd64
|
|
|
|
;;
|
|
|
|
i?86_64*)
|
|
|
|
host_arch=amd64
|
|
|
|
;;
|
|
|
|
amd64*)
|
|
|
|
host_arch=amd64
|
|
|
|
;;
|
|
|
|
arm*)
|
|
|
|
host_arch=arm
|
|
|
|
;;
|
|
|
|
i?86*)
|
|
|
|
host_arch=x86
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "Unsupported host arch. Must be x86_64, 386 or arm." >&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# Gather up the list of likely places and use ls to find the latest one.
|
|
|
|
locations=(
|
|
|
|
"${KUBE_ROOT}/_output/dockerized/bin/${host_os}/${host_arch}/e2e"
|
|
|
|
"${KUBE_ROOT}/_output/local/bin/${host_os}/${host_arch}/e2e"
|
|
|
|
"${KUBE_ROOT}/platforms/${host_os}/${host_arch}/e2e"
|
|
|
|
)
|
|
|
|
e2e=$( (ls -t "${locations[@]}" 2>/dev/null || true) | head -1 )
|
2014-10-22 23:26:59 +00:00
|
|
|
|
2015-03-05 23:41:52 +00:00
|
|
|
# --- Setup some env vars.
|
|
|
|
|
|
|
|
: ${KUBE_VERSION_ROOT:=${KUBE_ROOT}}
|
|
|
|
: ${KUBECTL:="${KUBE_VERSION_ROOT}/cluster/kubectl.sh"}
|
|
|
|
: ${KUBE_CONFIG_FILE:="config-test.sh"}
|
|
|
|
|
|
|
|
export KUBECTL KUBE_CONFIG_FILE
|
|
|
|
|
|
|
|
source "${KUBE_ROOT}/cluster/kube-env.sh"
|
2014-10-22 23:26:59 +00:00
|
|
|
|
2015-03-05 23:41:52 +00:00
|
|
|
# ---- Do cloud-provider-specific setup
|
2015-03-13 09:00:28 +00:00
|
|
|
if [[ -z "${AUTH_CONFIG:-}" ]]; then
|
2015-03-05 23:41:52 +00:00
|
|
|
echo "Setting up for KUBERNETES_PROVIDER=\"${KUBERNETES_PROVIDER}\"."
|
|
|
|
|
|
|
|
source "${KUBE_VERSION_ROOT}/cluster/${KUBERNETES_PROVIDER}/util.sh"
|
|
|
|
|
|
|
|
prepare-e2e
|
|
|
|
|
|
|
|
detect-master >/dev/null
|
|
|
|
|
|
|
|
|
|
|
|
if [[ "$KUBERNETES_PROVIDER" == "vagrant" ]]; then
|
|
|
|
# When we are using vagrant it has hard coded auth. We repeat that here so that
|
|
|
|
# we don't clobber auth that might be used for a publicly facing cluster.
|
|
|
|
auth_config=(
|
2015-03-13 18:42:09 +00:00
|
|
|
"--auth_config=${HOME}/.kubernetes_vagrant_auth"
|
|
|
|
"--kubeconfig=${HOME}/.kubernetes_vagrant_kubeconfig"
|
2015-03-05 23:41:52 +00:00
|
|
|
)
|
|
|
|
elif [[ "${KUBERNETES_PROVIDER}" == "gke" ]]; then
|
2015-03-31 23:36:31 +00:00
|
|
|
# GKE stores its own kubeconfig in gcloud's config directory.
|
2015-03-05 23:41:52 +00:00
|
|
|
detect-project &> /dev/null
|
|
|
|
auth_config=(
|
2015-03-31 23:36:31 +00:00
|
|
|
"--kubeconfig=${GCLOUD_CONFIG_DIR}/kubeconfig"
|
|
|
|
# gcloud doesn't set the current-context, so we have to set it
|
|
|
|
"--context=gke_${PROJECT}_${ZONE}_${CLUSTER_NAME}"
|
2015-03-05 23:41:52 +00:00
|
|
|
)
|
|
|
|
elif [[ "${KUBERNETES_PROVIDER}" == "gce" ]]; then
|
|
|
|
auth_config=(
|
|
|
|
"--kubeconfig=${HOME}/.kube/.kubeconfig"
|
|
|
|
)
|
|
|
|
elif [[ "${KUBERNETES_PROVIDER}" == "aws" ]]; then
|
|
|
|
auth_config=(
|
|
|
|
"--auth_config=${HOME}/.kube/${INSTANCE_PREFIX}/kubernetes_auth"
|
|
|
|
)
|
2015-03-13 14:54:53 +00:00
|
|
|
elif [[ "${KUBERNETES_PROVIDER}" == "libvirt-coreos" ]]; then
|
|
|
|
auth_config=(
|
|
|
|
"--kubeconfig=${HOME}/.kube/.kubeconfig"
|
|
|
|
)
|
2015-03-05 23:41:52 +00:00
|
|
|
elif [[ "${KUBERNETES_PROVIDER}" == "conformance_test" ]]; then
|
|
|
|
auth_config=(
|
|
|
|
"--auth_config=${KUBERNETES_CONFORMANCE_TEST_AUTH_CONFIG:-}"
|
|
|
|
"--cert_dir=${KUBERNETES_CONFORMANCE_TEST_CERT_DIR:-}"
|
|
|
|
)
|
|
|
|
else
|
|
|
|
auth_config=()
|
|
|
|
fi
|
2015-03-02 16:13:57 +00:00
|
|
|
else
|
2015-03-05 23:41:52 +00:00
|
|
|
echo "Conformance Test. No cloud-provider-specific preparation."
|
|
|
|
KUBERNETES_PROVIDER=""
|
|
|
|
auth_config=(
|
|
|
|
"--auth_config=${AUTH_CONFIG:-}"
|
|
|
|
"--cert_dir=${CERT_DIR:-}"
|
|
|
|
)
|
2015-03-02 16:13:57 +00:00
|
|
|
fi
|
|
|
|
|
2015-02-28 02:29:28 +00:00
|
|
|
# Use the kubectl binary from the same directory as the e2e binary.
|
2015-03-19 14:13:35 +00:00
|
|
|
# The --host setting is used only when providing --auth_config
|
|
|
|
# If --kubeconfig is used, the host to use is retrieved from the .kubeconfig
|
|
|
|
# file and the one provided with --host is ignored.
|
2015-02-28 02:29:28 +00:00
|
|
|
export PATH=$(dirname "${e2e}"):"${PATH}"
|
2015-01-28 22:54:08 +00:00
|
|
|
"${e2e}" "${auth_config[@]:+${auth_config[@]}}" \
|
2015-03-13 14:54:53 +00:00
|
|
|
--host="https://${KUBE_MASTER_IP-}" \
|
2015-01-28 22:54:08 +00:00
|
|
|
--provider="${KUBERNETES_PROVIDER}" \
|
2015-02-20 22:01:15 +00:00
|
|
|
--gce_project="${PROJECT:-}" \
|
|
|
|
--gce_zone="${ZONE:-}" \
|
|
|
|
--kube_master="${KUBE_MASTER:-}" \
|
2015-01-28 22:53:22 +00:00
|
|
|
${E2E_REPORT_DIR+"--report_dir=${E2E_REPORT_DIR}"} \
|
2015-02-11 17:39:06 +00:00
|
|
|
"${@:-}"
|