84 lines
2.6 KiB
Bash
Executable File
84 lines
2.6 KiB
Bash
Executable File
#!/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).
|
|
|
|
# TODO: Convert uses of gcutil to gcloud
|
|
|
|
set -o errexit
|
|
set -o nounset
|
|
set -o pipefail
|
|
|
|
KUBE_ROOT=$(dirname "${BASH_SOURCE}")/../..
|
|
source "${KUBE_ROOT}/cluster/kube-env.sh"
|
|
source "${KUBE_ROOT}/cluster/$KUBERNETES_PROVIDER/util.sh"
|
|
|
|
if [[ "$KUBERNETES_PROVIDER" != "gce" ]]; then
|
|
echo "PD test is only run for GCE"
|
|
return 0
|
|
fi
|
|
|
|
disk_name="e2e-$(date +%H-%M-%s)"
|
|
config="/tmp/${disk_name}.yaml"
|
|
|
|
function teardown() {
|
|
echo "Cleaning up test artifacts"
|
|
${KUBECFG} delete pods/testpd
|
|
rm -rf ${config}
|
|
echo "Waiting for disk to become unmounted"
|
|
sleep 20
|
|
gcutil deletedisk -f --zone=${ZONE} ${disk_name}
|
|
}
|
|
|
|
trap "teardown" EXIT
|
|
|
|
perl -p -e "s/%.*%/${disk_name}/g" ${KUBE_ROOT}/examples/gce-pd/testpd.yaml > ${config}
|
|
|
|
# Create and mount the disk.
|
|
gcutil adddisk --size_gb=10 --zone=${ZONE} ${disk_name}
|
|
gcutil attachdisk --disk ${disk_name} ${MASTER_NAME}
|
|
gcutil ssh ${MASTER_NAME} sudo rm -rf /mnt/tmp
|
|
gcutil ssh ${MASTER_NAME} sudo mkdir /mnt/tmp
|
|
gcutil ssh ${MASTER_NAME} sudo /usr/share/google/safe_format_and_mount /dev/disk/by-id/google-${disk_name} /mnt/tmp
|
|
gcutil ssh ${MASTER_NAME} sudo umount /mnt/tmp
|
|
gcloud compute instances detach-disk --disk ${disk_name} --zone ${ZONE} ${MASTER_NAME}
|
|
|
|
${KUBECFG} -c ${config} create pods
|
|
|
|
pod_id_list=$($KUBECFG '-template={{range.items}}{{.id}} {{end}}' -l test=testpd list pods)
|
|
# 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 pods to come up."
|
|
sleep 5
|
|
all_running=1
|
|
for id in $pod_id_list; do
|
|
current_status=$($KUBECFG -template '{{.currentState.status}}' get pods/$id) || true
|
|
if [[ "$current_status" != "Running" ]]; then
|
|
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
|