2021-05-20 08:38:11 +00:00
|
|
|
#!/usr/bin/env bash
|
2021-05-20 21:36:14 +00:00
|
|
|
# shellcheck disable=SC2034
|
2021-05-20 08:38:11 +00:00
|
|
|
KUBECONFIG="kind.yaml"
|
|
|
|
KIND_CLUSTER="kind-cluster-kilo"
|
|
|
|
KIND_BINARY="${KIND_BINARY:-kind}"
|
|
|
|
KUBECTL_BINARY="${KUBECTL_BINARY:-kubectl}"
|
|
|
|
KILO_IMAGE="${KILO_IMAGE:-squat/kilo}"
|
|
|
|
|
2021-06-15 10:54:27 +00:00
|
|
|
retry() {
|
|
|
|
local COUNT="${1:-10}"
|
|
|
|
local SLEEP="${2:-5}"
|
|
|
|
local ERROR=$3
|
|
|
|
[ -n "$ERROR" ] && ERROR="$ERROR "
|
|
|
|
shift 3
|
|
|
|
for c in $(seq 1 "$COUNT"); do
|
|
|
|
if "$@"; then
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
printf "%s(attempt %d/%d)\n" "$ERROR" "$c" "$COUNT" | color "$YELLOW"
|
|
|
|
if [ "$c" != "$COUNT" ]; then
|
|
|
|
printf "retrying in %d seconds...\n" "$SLEEP" | color "$YELLOW"
|
|
|
|
sleep "$SLEEP"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
2021-05-20 08:38:11 +00:00
|
|
|
is_ready() {
|
2021-05-20 21:36:14 +00:00
|
|
|
for pod in $($KUBECTL_BINARY -n "$1" get pods -o name -l "$2"); do
|
|
|
|
if ! $KUBECTL_BINARY -n "$1" get "$pod" | tail -n 1 | grep -q Running; then
|
2021-05-20 08:38:11 +00:00
|
|
|
return 1;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
# Returns non zero if one pod of the given name in the given namespace is not ready.
|
|
|
|
block_until_ready_by_name() {
|
2021-05-20 21:36:14 +00:00
|
|
|
block_until_ready "$1" "app.kubernetes.io/name=$2"
|
2021-05-20 08:38:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Blocks until all pods of a deployment are ready.
|
|
|
|
block_until_ready() {
|
2021-06-15 10:54:27 +00:00
|
|
|
retry 30 5 "some $2 pods are not ready yet" is_ready "$1" "$2"
|
2021-05-20 08:38:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Set up the kind cluster and deploy Kilo, Adjacency and a helper with curl.
|
|
|
|
setup_suite() {
|
|
|
|
$KIND_BINARY delete clusters $KIND_CLUSTER > /dev/null
|
|
|
|
# Create the kind cluster.
|
|
|
|
$KIND_BINARY create cluster --name $KIND_CLUSTER --config ./kind-config.yaml
|
|
|
|
# Load the Kilo image into kind.
|
2021-05-20 21:36:14 +00:00
|
|
|
docker tag "$KILO_IMAGE" squat/kilo:test
|
2021-05-20 08:38:11 +00:00
|
|
|
$KIND_BINARY load docker-image squat/kilo:test --name $KIND_CLUSTER
|
|
|
|
# Apply Kilo the the cluster.
|
2021-06-14 07:08:46 +00:00
|
|
|
$KUBECTL_BINARY apply -f ../manifests/crds.yaml
|
2021-05-20 08:38:11 +00:00
|
|
|
$KUBECTL_BINARY apply -f kilo-kind-userspace.yaml
|
|
|
|
block_until_ready_by_name kube-system kilo-userspace
|
|
|
|
$KUBECTL_BINARY wait nodes --all --for=condition=Ready
|
|
|
|
# wait for coredns
|
|
|
|
block_until_ready kube_system k8s-app=kube-dns
|
|
|
|
$KUBECTL_BINARY taint node $KIND_CLUSTER-control-plane node-role.kubernetes.io/master:NoSchedule-
|
|
|
|
$KUBECTL_BINARY apply -f https://raw.githubusercontent.com/heptoprint/adjacency/master/example.yaml
|
|
|
|
$KUBECTL_BINARY apply -f helper-curl.yaml
|
|
|
|
block_until_ready_by_name adjacency adjacency
|
|
|
|
block_until_ready_by_name default curl
|
|
|
|
}
|
|
|
|
|
2021-06-15 10:54:27 +00:00
|
|
|
check_ping() {
|
|
|
|
for ip in $($KUBECTL_BINARY get pods -l app.kubernetes.io/name=adjacency -o jsonpath='{.items[*].status.podIP}'); do
|
|
|
|
ping=$($KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c "curl -s http://$ip:8080/ping")
|
|
|
|
if [ "$ping" = "pong" ]; then
|
|
|
|
echo "successfully pinged $ip"
|
|
|
|
else
|
|
|
|
printf 'failed to ping %s; expected "pong" but got "%s"\n' "$ip" "$ping"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
return 0
|
2021-05-20 08:38:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
check_adjacent() {
|
|
|
|
echo
|
2021-05-20 21:36:14 +00:00
|
|
|
$KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=fancy'
|
2021-05-20 08:38:11 +00:00
|
|
|
assert_equals "12" \
|
2021-05-20 21:36:14 +00:00
|
|
|
"$($KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=json' | jq | grep -c true)" \
|
2021-05-20 08:38:11 +00:00
|
|
|
"Adjacency returned the wrong number of successful pings"
|
|
|
|
echo "sleep for 30s (one reconciliation period) and try again..."
|
|
|
|
sleep 30
|
|
|
|
echo
|
2021-05-20 21:36:14 +00:00
|
|
|
$KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=fancy'
|
2021-05-20 08:38:11 +00:00
|
|
|
assert_equals "12" \
|
2021-05-20 21:36:14 +00:00
|
|
|
"$($KUBECTL_BINARY get pods -l app.kubernetes.io/name=curl -o name | xargs -I{} "$KUBECTL_BINARY" exec {} -- /bin/sh -c 'curl -s adjacency:8080/?format=json' | jq | grep -c true)" \
|
2021-05-20 08:38:11 +00:00
|
|
|
"Adjacency returned the wrong number of successful pings"
|
|
|
|
}
|
|
|
|
|
|
|
|
test_locationmesh() {
|
2021-05-21 09:09:14 +00:00
|
|
|
# shellcheck disable=SC2016
|
2021-05-20 08:38:11 +00:00
|
|
|
$KUBECTL_BINARY patch ds -n kube-system kilo -p '{"spec": {"template":{"spec":{"containers":[{"name":"kilo","args":["--hostname=$(NODE_NAME)","--create-interface=false","--mesh-granularity=location"]}]}}}}'
|
|
|
|
sleep 5
|
|
|
|
block_until_ready_by_name kube-system kilo-userspace
|
|
|
|
$KUBECTL_BINARY wait pod -l app.kubernetes.io/name=adjacency --for=condition=Ready --timeout 3m
|
2021-06-15 10:54:27 +00:00
|
|
|
retry 30 5 "" check_ping
|
2021-05-20 08:38:11 +00:00
|
|
|
sleep 5
|
2021-06-15 10:54:27 +00:00
|
|
|
retry 10 5 "the adjacency matrix is not complete yet" check_adjacent
|
2021-05-20 08:38:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
test_fullmesh() {
|
2021-05-21 09:09:14 +00:00
|
|
|
# shellcheck disable=SC2016
|
2021-05-20 08:38:11 +00:00
|
|
|
$KUBECTL_BINARY patch ds -n kube-system kilo -p '{"spec": {"template":{"spec":{"containers":[{"name":"kilo","args":["--hostname=$(NODE_NAME)","--create-interface=false","--mesh-granularity=full"]}]}}}}'
|
|
|
|
sleep 5
|
|
|
|
block_until_ready_by_name kube-system kilo-userspace
|
|
|
|
$KUBECTL_BINARY wait pod -l app.kubernetes.io/name=adjacency --for=condition=Ready --timeout 3m
|
2021-06-15 10:54:27 +00:00
|
|
|
retry 30 5 "" check_ping
|
2021-05-20 08:38:11 +00:00
|
|
|
sleep 5
|
2021-06-15 10:54:27 +00:00
|
|
|
retry 10 5 "the adjacency matrix is not complete yet" check_adjacent
|
2021-05-20 08:38:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
teardown_suite () {
|
|
|
|
$KIND_BINARY delete clusters $KIND_CLUSTER
|
|
|
|
}
|