2014-12-16 06:54:01 +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.
|
|
|
|
|
|
|
|
# Launches a container and verifies it can be reached. Assumes that
|
|
|
|
# we're being called by hack/e2e-test.sh (we use some env vars it sets up).
|
|
|
|
|
|
|
|
set -o errexit
|
|
|
|
set -o nounset
|
|
|
|
set -o pipefail
|
|
|
|
|
|
|
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
2015-02-05 08:00:28 +00:00
|
|
|
|
|
|
|
: ${KUBE_VERSION_ROOT:=${KUBE_ROOT}}
|
|
|
|
: ${KUBECTL:="${KUBE_VERSION_ROOT}/cluster/kubectl.sh"}
|
|
|
|
: ${KUBE_CONFIG_FILE:="config-test.sh"}
|
|
|
|
|
|
|
|
export KUBECTL KUBE_CONFIG_FILE
|
|
|
|
|
2014-12-16 06:54:01 +00:00
|
|
|
source "${KUBE_ROOT}/cluster/kube-env.sh"
|
2015-02-05 08:00:28 +00:00
|
|
|
source "${KUBE_VERSION_ROOT}/cluster/${KUBERNETES_PROVIDER}/util.sh"
|
|
|
|
|
|
|
|
prepare-e2e
|
2014-12-16 06:54:01 +00:00
|
|
|
|
2014-12-24 15:49:10 +00:00
|
|
|
liveness_tests="http exec"
|
|
|
|
if [[ ${KUBERNETES_PROVIDER} == "gke" ]]; then
|
|
|
|
server_version=$(kube_server_version)
|
|
|
|
if [[ ${server_version} -le 702 ]]; then
|
|
|
|
echo "GKE server version <= 0.7.2, limiting test to http (version = ${server_version})"
|
|
|
|
liveness_tests="http"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2014-12-16 06:54:01 +00:00
|
|
|
function teardown() {
|
|
|
|
echo "Cleaning up test artifacts"
|
2014-12-24 15:49:10 +00:00
|
|
|
for test in ${liveness_tests}; do
|
2015-02-03 17:30:03 +00:00
|
|
|
${KUBECTL} delete pods liveness-${test}
|
2014-12-24 15:49:10 +00:00
|
|
|
done
|
2014-12-16 06:54:01 +00:00
|
|
|
}
|
|
|
|
|
2014-12-16 21:16:17 +00:00
|
|
|
function waitForNotPending() {
|
2015-02-03 17:30:03 +00:00
|
|
|
pod_id_list=$(${KUBECTL} get pods -o template '--template={{range.items}}{{.id}} {{end}}' -l test=liveness)
|
2014-12-16 06:54:01 +00:00
|
|
|
# Pod turn up on a clean cluster can take a while for the docker image pull.
|
|
|
|
all_running=0
|
|
|
|
for i in $(seq 1 24); do
|
|
|
|
echo "Waiting for pod to come up."
|
|
|
|
sleep 5
|
|
|
|
all_running=1
|
|
|
|
for id in $pod_id_list; do
|
2015-02-03 17:30:03 +00:00
|
|
|
current_status=$(${KUBECTL} get pods $id -o template '--template={{.currentState.status}}') || true
|
2014-12-16 21:16:17 +00:00
|
|
|
if [[ "$current_status" == "Pending" ]]; then
|
2014-12-16 06:54:01 +00:00
|
|
|
all_running=0
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if [[ "${all_running}" == 1 ]]; then
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if [[ "${all_running}" == 0 ]]; then
|
|
|
|
echo "Pods did not come up in time"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
trap "teardown" EXIT
|
|
|
|
|
2014-12-24 15:49:10 +00:00
|
|
|
for test in ${liveness_tests}; do
|
2014-12-16 21:06:58 +00:00
|
|
|
echo "Liveness test: ${test}"
|
2015-02-03 17:30:03 +00:00
|
|
|
${KUBECTL} create -f ${KUBE_ROOT}/examples/liveness/${test}-liveness.yaml
|
2014-12-16 21:06:58 +00:00
|
|
|
waitForNotPending
|
2014-12-16 06:54:01 +00:00
|
|
|
|
2015-02-03 17:30:03 +00:00
|
|
|
before=$(${KUBECTL} get pods "liveness-${test}" -o template '--template={{.currentState.info.liveness.restartCount}}')
|
2014-12-23 17:34:27 +00:00
|
|
|
while [[ "${before}" == "<no value>" ]]; do
|
2015-02-03 17:30:03 +00:00
|
|
|
before=$(${KUBECTL} get pods "liveness-${test}" -o template '--template={{.currentState.info.liveness.restartCount}}')
|
2014-12-23 17:34:27 +00:00
|
|
|
done
|
2015-02-03 17:30:03 +00:00
|
|
|
|
2014-12-16 21:06:58 +00:00
|
|
|
echo "Waiting for restarts."
|
|
|
|
for i in $(seq 1 24); do
|
2015-02-03 17:30:03 +00:00
|
|
|
sleep 10
|
|
|
|
after=$(${KUBECTL} get pods "liveness-${test}" -o template '--template={{.currentState.info.liveness.restartCount}}')
|
2014-12-16 21:06:58 +00:00
|
|
|
echo "Restarts: ${after} > ${before}"
|
2014-12-23 17:34:27 +00:00
|
|
|
if [[ "${after}" == "<no value>" ]]; then
|
|
|
|
continue
|
|
|
|
fi
|
2014-12-16 21:06:58 +00:00
|
|
|
if [[ "${after}" > "${before}" ]]; then
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2014-12-16 06:54:01 +00:00
|
|
|
|
2014-12-16 21:06:58 +00:00
|
|
|
if [[ "${before}" < "${after}" ]]; then
|
|
|
|
continue
|
2014-12-16 06:54:01 +00:00
|
|
|
fi
|
|
|
|
|
2014-12-16 21:06:58 +00:00
|
|
|
echo "Unexpected absence of failures in ${test}"
|
|
|
|
echo "Restarts before: ${before}."
|
|
|
|
echo "Restarts after: ${after}"
|
|
|
|
exit 1
|
|
|
|
done
|
2014-12-16 06:54:01 +00:00
|
|
|
|
2014-12-16 21:06:58 +00:00
|
|
|
exit 0
|