mirror of https://github.com/rancher/turtles.git
140 lines
5.5 KiB
Bash
Executable File
140 lines
5.5 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# Copyright © 2023 - 2024 SUSE LLC
|
|
#
|
|
# 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.
|
|
|
|
set -xe
|
|
|
|
RANCHER_HOSTNAME=$1
|
|
if [ -z "$RANCHER_HOSTNAME" ]; then
|
|
echo "You must pass a rancher host name"
|
|
exit 1
|
|
fi
|
|
|
|
RANCHER_CHANNEL=${RANCHER_CHANNEL:-alpha}
|
|
RANCHER_PASSWORD=${RANCHER_PASSWORD:-rancheradmin}
|
|
RANCHER_VERSION=${RANCHER_VERSION:-v2.13.0-alpha3}
|
|
RANCHER_IMAGE_TAG=${RANCHER_IMAGE_TAG:-$RANCHER_VERSION} # Set RANCHER_IMAGE_TAG=head to test with latest build
|
|
RANCHER_IMAGE=${RANCHER_IMAGE:-rancher/rancher:$RANCHER_IMAGE_TAG}
|
|
CLUSTER_NAME=${CLUSTER_NAME:-capi-test}
|
|
USE_TILT_DEV=${USE_TILT_DEV:-true}
|
|
TURTLES_VERSION=${TURTLES_VERSION:-dev}
|
|
TURTLES_IMAGE=${TURTLES_IMAGE:-ghcr.io/rancher/turtles:$TURTLES_VERSION}
|
|
|
|
GITEA_PASSWORD=${GITEA_PASSWORD:-giteaadmin}
|
|
RANCHER_CHARTS_REPO_DIR=${RANCHER_CHARTS_REPO_DIR}
|
|
RANCHER_CHART_DEV_VERSION=${RANCHER_CHART_DEV_VERSION}
|
|
RANCHER_CHARTS_BASE_BRANCH=${RANCHER_CHARTS_BASE_BRANCH}
|
|
|
|
BASEDIR=$(dirname "$0")
|
|
|
|
kind create cluster --config "$BASEDIR/kind-cluster-with-extramounts.yaml" --name $CLUSTER_NAME
|
|
docker pull $RANCHER_IMAGE
|
|
kind load docker-image $RANCHER_IMAGE --name $CLUSTER_NAME
|
|
|
|
kubectl rollout status deployment coredns -n kube-system --timeout=90s
|
|
|
|
helm repo add rancher-$RANCHER_CHANNEL https://releases.rancher.com/server-charts/$RANCHER_CHANNEL --force-update
|
|
helm repo add jetstack https://charts.jetstack.io --force-update
|
|
helm repo add ngrok https://charts.ngrok.com --force-update
|
|
helm repo add gitea-charts https://dl.gitea.com/charts/ --force-update
|
|
helm repo update
|
|
|
|
helm install cert-manager jetstack/cert-manager \
|
|
--namespace cert-manager \
|
|
--create-namespace \
|
|
--set crds.enabled=true
|
|
|
|
helm upgrade ngrok ngrok/ngrok-operator \
|
|
--namespace ngrok \
|
|
--create-namespace \
|
|
--install \
|
|
--wait \
|
|
--timeout 5m \
|
|
--set credentials.apiKey=$NGROK_API_KEY \
|
|
--set credentials.authtoken=$NGROK_AUTHTOKEN
|
|
kubectl apply -f test/e2e/data/rancher/ingress-class-patch.yaml
|
|
|
|
helm install gitea gitea-charts/gitea \
|
|
-f test/e2e/data/gitea/values.yaml \
|
|
--set gitea.admin.password=$GITEA_PASSWORD \
|
|
--wait
|
|
|
|
envsubst <test/e2e/data/gitea/ingress.yaml | kubectl apply -f -
|
|
|
|
# Build and load the controller image
|
|
make docker-build-prime
|
|
kind load docker-image $TURTLES_IMAGE --name $CLUSTER_NAME
|
|
|
|
# Create Gitea repo for the Rancher charts fork
|
|
until [ "$(curl -s -o /dev/null -w "%{http_code}" https://gitea.$RANCHER_HOSTNAME)" = "200" ]; do echo "Waiting for gitea"; sleep 1; done;
|
|
curl -X POST "https://gitea:$GITEA_PASSWORD@gitea.$RANCHER_HOSTNAME/api/v1/user/repos" \
|
|
-H 'Accept: application/json' \
|
|
-H 'Content-Type: application/json' \
|
|
-d '{"name":"charts"}'
|
|
# Push to repo
|
|
git -C $RANCHER_CHARTS_REPO_DIR remote add fork https://gitea:$GITEA_PASSWORD@gitea.$RANCHER_HOSTNAME/gitea/charts.git
|
|
git -C $RANCHER_CHARTS_REPO_DIR push fork --force
|
|
|
|
helm install rancher rancher-$RANCHER_CHANNEL/rancher \
|
|
--namespace cattle-system \
|
|
--create-namespace \
|
|
--set bootstrapPassword=$RANCHER_PASSWORD \
|
|
--set replicas=1 \
|
|
--set hostname="$RANCHER_HOSTNAME" \
|
|
--set image.tag=$RANCHER_IMAGE_TAG \
|
|
--set extraEnv[0].name=CATTLE_CHART_DEFAULT_URL \
|
|
--set extraEnv[0].value=https://gitea.$RANCHER_HOSTNAME/gitea/charts.git \
|
|
--set extraEnv[1].name=CATTLE_CHART_DEFAULT_BRANCH \
|
|
--set extraEnv[1].value=$RANCHER_CHARTS_BASE_BRANCH \
|
|
--set extraEnv[2].name=CATTLE_RANCHER_TURTLES_VERSION \
|
|
--set extraEnv[2].value=$RANCHER_CHART_DEV_VERSION \
|
|
--version="$RANCHER_VERSION" \
|
|
--wait
|
|
|
|
kubectl apply -f test/e2e/data/rancher/rancher-service-patch.yaml
|
|
envsubst <test/e2e/data/rancher/ingress.yaml | kubectl apply -f -
|
|
envsubst <test/e2e/data/rancher/rancher-setting-patch.yaml | kubectl apply -f -
|
|
kubectl apply -f test/e2e/data/rancher/system-store-setting-patch.yaml
|
|
|
|
install_local_providers_chart() {
|
|
make build-providers-chart
|
|
|
|
# Wait for Turtles to be ready. This may take a few minutes before Rancher installs the system chart.
|
|
# The providers chart depends on CAPIProvider crd.
|
|
kubectl wait --for=create crds/capiproviders.turtles-capi.cattle.io --timeout=300s
|
|
|
|
helm upgrade --install rancher-turtles-providers out/charts/rancher-turtles-providers \
|
|
-n cattle-turtles-system \
|
|
--set providers.bootstrapKubeadm.enabled=true \
|
|
--set providers.controlplaneKubeadm.enabled=true \
|
|
--set providers.infrastructureDocker.enabled=true \
|
|
--set providers.infrastructureAWS.enabled=true \
|
|
--set providers.infrastructureAzure.enabled=true \
|
|
--set providers.infrastructureGCP.enabled=true \
|
|
--set providers.infrastructureGCP.variables.GCP_B64ENCODED_CREDENTIALS="" \
|
|
--set providers.infrastructureVSphere.enabled=true \
|
|
--create-namespace --wait \
|
|
--timeout 180s
|
|
}
|
|
|
|
echo "Installing local Rancher Turtles Providers..."
|
|
install_local_providers_chart
|
|
|
|
if [ "$USE_TILT_DEV" == "true" ]; then
|
|
kubectl wait --for=create deployments/rancher-turtles-controller-manager --namespace cattle-turtles-system --timeout=300s
|
|
echo "Using Tilt for development..."
|
|
tilt up
|
|
fi
|