Add an integration test for etcd

This commit is contained in:
Clayton Coleman
2014-08-22 21:12:16 -04:00
parent 8a677b1226
commit b037989478
6 changed files with 297 additions and 62 deletions

View File

@@ -17,26 +17,7 @@
# This command checks that the built commands can function together for
# simple scenarios. It does not require Docker so it can run in travis.
function wait_for_url {
url=$1
prefix=${2:-}
wait=${3:-0.2}
times=${4:-10}
set +e
for i in $(seq 1 $times); do
out=$(curl -fs $url 2>/dev/null)
if [ $? -eq 0 ]; then
set -e
echo ${prefix}${out}
return 0
fi
sleep $wait
done
echo "ERROR: timed out for $url"
set -e
return 1
}
source $(dirname $0)/util.sh
function cleanup()
{
@@ -47,47 +28,31 @@ function cleanup()
kill ${PROXY_PID} 1>&2 2>/dev/null
kill ${ETCD_PID} 1>&2 2>/dev/null
rm -rf ${ETCD_DIR} 1>&2 2>/dev/null
echo
echo "Complete"
}
trap cleanup EXIT SIGINT
ETCD_HOST=127.0.0.1
ETCD_PORT=4001
set -e
# Start etcd
start_etcd
ETCD_HOST=${ETCD_HOST:-127.0.0.1}
ETCD_PORT=${ETCD_PORT:-4001}
API_PORT=${API_PORT:-8080}
API_HOST=${API_HOST:-127.0.0.1}
KUBELET_PORT=${KUBELET_PORT:-10250}
GO_OUT=$(dirname $0)/../output/go/bin
if [ "$(which etcd)" == "" ]; then
echo "etcd must be in your PATH"
exit 1
fi
running_etcd=$(ps -ef | grep etcd | grep -c name)
if [ "$running_etcd" != "0" ]; then
echo "etcd appears to already be running on this machine, please kill and restart the test."
exit 1
fi
# Stop on any failures
set -e
# Start etcd
ETCD_DIR=$(mktemp -d -t test-cmd.XXXXXX)
etcd -name test -data-dir ${ETCD_DIR} -bind-addr $ETCD_HOST:$ETCD_PORT >/dev/null 2>/dev/null &
ETCD_PID=$!
wait_for_url "http://localhost:4001/version" "etcd: "
# Check kubecfg
out=$(${GO_OUT}/kubecfg -version)
echo kubecfg: $out
# Start kubelet
${GO_OUT}/kubelet \
--etcd_servers="http://127.0.0.1:${ETCD_PORT}" \
--etcd_servers="http://${ETCD_HOST}:${ETCD_PORT}" \
--hostname_override="127.0.0.1" \
--address="127.0.0.1" \
--port="$KUBELET_PORT" 1>&2 &
@@ -99,7 +64,7 @@ wait_for_url "http://127.0.0.1:${KUBELET_PORT}/healthz" "kubelet: "
${GO_OUT}/apiserver \
--address="127.0.0.1" \
--port="${API_PORT}" \
--etcd_servers="http://127.0.0.1:${ETCD_PORT}" \
--etcd_servers="http://${ETCD_HOST}:${ETCD_PORT}" \
--machines="127.0.0.1" \
--minion_port=${KUBELET_PORT} 1>&2 &
APISERVER_PID=$!

View File

@@ -14,30 +14,36 @@
# See the License for the specific language governing permissions and
# limitations under the License.
if [ "$(which etcd)" == "" ]; then
echo "etcd must be in your PATH"
exit 1
fi
source $(dirname $0)/util.sh
running_etcd=$(ps -ef | grep etcd | grep -c name)
if [ "$running_etcd" != "0" ]; then
echo "etcd appears to already be running on this machine, please kill and restart the test."
exit 1
fi
function cleanup()
{
set +e
kill ${ETCD_PID} 1>&2 2>/dev/null
rm -rf ${ETCD_DIR} 1>&2 2>/dev/null
echo
echo "Complete"
}
# Stop right away if the build fails
set -e
$(dirname $0)/build-go.sh cmd/integration
ETCD_DIR=$(mktemp -d -t kube-integration.XXXXXX)
trap "rm -rf ${ETCD_DIR}" EXIT
start_etcd
(etcd -name test -data-dir ${ETCD_DIR} > /tmp/etcd.log) &
ETCD_PID=$!
trap cleanup EXIT SIGINT
sleep 5
echo
echo Integration test cases ...
echo
$(dirname $0)/../hack/test-go.sh test/integration -tags 'integration no-docker'
# leave etcd running if integration tests fail
trap "echo etcd still running" EXIT
echo
echo Integration scenario ...
echo
$(dirname $0)/../output/go/bin/integration
kill $ETCD_PID
# nuke etcd
trap cleanup EXIT SIGINT

66
hack/util.sh Normal file
View File

@@ -0,0 +1,66 @@
#!/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.
# Provides simple utility functions
function wait_for_url {
url=$1
prefix=${2:-}
wait=${3:-0.2}
times=${4:-10}
set +e
for i in $(seq 1 $times); do
out=$(curl -fs $url 2>/dev/null)
if [ $? -eq 0 ]; then
set -e
echo ${prefix}${out}
return 0
fi
sleep $wait
done
echo "ERROR: timed out for $url"
set -e
return 1
}
function start_etcd {
host=${ETCD_HOST:-127.0.0.1}
port=${ETCD_PORT:-4001}
set +e
if [ "$(which etcd)" == "" ]; then
echo "etcd must be in your PATH"
exit 1
fi
running_etcd=$(ps -ef | grep etcd | grep -c name)
if [ "$running_etcd" != "0" ]; then
echo "etcd appears to already be running on this machine, please kill and restart the test."
exit 1
fi
# Stop on any failures
set -e
# Start etcd
export ETCD_DIR=$(mktemp -d -t test-etcd.XXXXXX)
etcd -name test -data-dir ${ETCD_DIR} -bind-addr ${host}:${port} >/dev/null 2>/dev/null &
export ETCD_PID=$!
wait_for_url "http://localhost:4001/v2/keys/" "etcd: "
}