Create automated environments from PRs.
The following tools will need to be installed:
- Spin up
minikube
using your local Docker as the driver (creating the management cluster). According to our tests, at least 4 CPUs and 8 GB of memory should be allocated for the Docker engine to spin up the clusters:
minikube start --memory=8g --cpus=4 --driver=docker
This will change your kubectl
context to this new cluster.
Now we need to configure CAPI (Cluster API) that will be responsible for managing the virtual clusters.
- Initialize the cluster with the desired infrastructure:
export CLUSTER_TOPOLOGY=true
clusterctl init --infrastructure vcluster
- Create the required namespaces:
kubectl create namespace argo
kubectl create namespace argocd
kubectl create namespace argo-events
kubectl create namespace autoenvs
- (optional) If you want to test it, you can execute the following command, creating a workload cluster.
export HELM_VALUES=""
clusterctl generate cluster example \
--infrastructure vcluster \
--kubernetes-version v1.28.0 \
--target-namespace autoenvs | kubectl apply -f -
This could take some time to spin up, but you can monitor if it's provisioned already with the command:
kubectl get cluster -n autoenvs
And finally, retrieve the kubeconfig
information to access the virtual
cluster:
clusterctl get kubeconfig example -n autoenvs
After you're happy with your test, you can remove the example cluster with the command:
kubectl delete cluster example -n autoenvs
- Install ArgoCD:
kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/v2.8.0/manifests/install.yaml
- Patch the ArgoCD repository server to fix the GPG issue:
kubectl patch deployment argocd-repo-server --patch-file ./argocd-fix/repo.yaml -n argocd
- Port-forward ArgoCD to access the web UI:
kubectl port-forward svc/argocd-server -n argocd 8080:443
- Retrieve the
admin
password:
argocd admin initial-password -n argocd
-
Log into the web UI: https://localhost:8080 (user
admin
). -
Log into ArgoCD CLI:
argocd login localhost:8080 --username admin --password <password>
- Generate a GitHub token for the repository (avoid rate limit issues). It needs to have at least Pull Request permissions.
kubectl create secret generic github-token --from-literal=token=<token> -n argocd
- Add ArgoCD secret into k8s secrets for internal scripts:
kubectl create secret generic argocd-login --from-literal=password=<password> --from-literal=username=admin -n argo
- Install Argo workflows, also apply a patch to allow the use of ArgoCD login.
kubectl apply -n argo -f https://github.com/argoproj/argo-workflows/releases/download/v3.4.10/install.yaml
kubectl patch deployment \
argo-server \
--namespace argo \
--type='json' \
-p='[{"op": "replace", "path": "/spec/template/spec/containers/0/args", "value": [
"server",
"--auth-mode=server"
]}]'
- Install Argo events:
kubectl apply -f https://raw.githubusercontent.com/argoproj/argo-events/stable/manifests/install.yaml
- Port-forward ArgoCD Workflows to access the web UI:
kubectl -n argo port-forward deployment/argo-server 2746:2746
-
Log into the web UI: https://localhost:2746
-
Install workflow components:
kubectl apply -n argocd -f argocd/cluster-workflows.yaml
kubectl apply -n argocd -f argocd/rollouts.yaml
kubectl apply -n argocd -f argocd/appset.yaml
kubectl apply -n argocd -f argocd/app.yaml
- Create your Pull Request with the
preview
tag.
This repository uses the following contents as a reference:
- https://cluster-api.sigs.k8s.io/user/quick-start
- https://github.com/loft-sh/cluster-api-provider-vcluster
- https://github.com/mtougeron/hundreds-of-clusters-demo
- https://www.vcluster.com/docs/operator/external-access#ingress
- https://github.com/loft-sh/vcluster/blob/main/charts/k3s/templates/ingress.yaml
- https://betterprogramming.pub/demystifying-gitops-ephemeral-pull-request-environments-5f1032f01299