#!/usr/bin/env bash set -o errexit set -o nounset set -o pipefail readonly REPO_ROOT="${REPO_ROOT:-$(git rev-parse --show-toplevel)}" run_kind() { echo "Get kind binary..." # docker run --rm -it -v "$(pwd)":/go/bin golang go get sigs.k8s.io/kind && chmod +x kind && sudo mv kind /usr/local/bin/ curl -Lo kind https://storage.googleapis.com/rimusz-ci-artifacts/kind && chmod +x kind && sudo mv kind /usr/local/bin/ echo "Download kubectl..." curl -Lo kubectl https://storage.googleapis.com/kubernetes-release/release/"${K8S_VERSION}"/bin/linux/amd64/kubectl && chmod +x kubectl && sudo mv kubectl /usr/local/bin/ echo echo "Create Kubernetes cluster with kind..." kind create cluster --image=kindest/node:"$K8S_VERSION" echo "Export kubeconfig..." # shellcheck disable=SC2155 export KUBECONFIG="$(kind get kubeconfig-path)" echo echo "Ensure the apiserver is responding..." kubectl cluster-info echo echo "Wait for Kubernetes to be up and ready..." JSONPATH='{range .items[*]}{@.metadata.name}:{range @.status.conditions[*]}{@.type}={@.status};{end}{end}'; until kubectl get nodes -o jsonpath="$JSONPATH" 2>&1 | grep -q "Ready=True"; do sleep 1; done echo } main() { echo "Starting kind ..." echo run_kind local config_container_id config_container_id=$(docker run -it -d -v "$REPO_ROOT:/workdir" --workdir /workdir "$CHART_TESTING_IMAGE:$CHART_TESTING_TAG" cat) # shellcheck disable=SC2064 trap "docker rm -f $config_container_id > /dev/null" EXIT # Get kind container IP kind_container_ip=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' kind-1-control-plane) # Copy kubeconfig file docker exec "$config_container_id" mkdir /root/.kube docker cp "$KUBECONFIG" "$config_container_id:/root/.kube/config" # Update in kubeconfig localhost to kind container IP docker exec "$config_container_id" sed -i "s/localhost/$kind_container_ip/g" /root/.kube/config echo "Add git remote k8s ${CHARTS_REPO}" git remote add k8s "${CHARTS_REPO}" &> /dev/null || true git fetch k8s master echo # Install Tiller with RABC kubectl -n kube-system create sa tiller kubectl create clusterrolebinding tiller-cluster-rule --clusterrole=cluster-admin --serviceaccount=kube-system:tiller docker exec "$config_container_id" helm init --service-account tiller echo "Wait for Tiller to be up and ready..." until kubectl -n kube-system get pods 2>&1 | grep -w "tiller-deploy" | grep -w "1/1"; do sleep 1; done echo # Run chart install test docker exec "$config_container_id" ct install --config /workdir/.test/ct.yaml echo "Done Testing!" } main