Skip to content

Namespace needs to be created before #56

Namespace needs to be created before

Namespace needs to be created before #56

Workflow file for this run

# This is a basic workflow to help you get started with Actions
name: test sx-cnp-oss k3d stack on kind cluster
# Controls when the workflow will run
on:
# at he moment this action only works when pushed to main because all references in the scripts and argocd apps use the main branch
push:
branches: [ "main" ]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
create-cluster:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Create k8s Kind Cluster
uses: helm/kind-action@v1
with:
cluster_name: sx-cnp-oss-cluster
config: ${{ github.workspace }}/.github/kind-config.yaml
- name: install mkcert
shell: bash
run: |
curl -JLO "https://dl.filippo.io/mkcert/latest?for=linux/amd64"
chmod +x mkcert-v*-linux-amd64
sudo cp mkcert-v*-linux-amd64 /usr/local/bin/mkcert
- name: install nginx
shell: bash
run: |
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/kind/deploy.yaml
kubectl wait --namespace ingress-nginx \
--for=condition=ready pod \
--selector=app.kubernetes.io/component=controller \
--timeout=90s
- name: install k8sgpt
shell: bash
run: |
curl -LO https://github.com/k8sgpt-ai/k8sgpt/releases/download/v0.3.30/k8sgpt_amd64.deb
sudo dpkg -i k8sgpt_amd64.deb
k8sgpt analyze
- name: install sx-cnp-oss stack
env:
INSTALL_K3D_CLUSTER: "false"
INSTALL_MKCERTS: "false"
shell: bash
run: |
kubectl create ns backstage
kubectl create secret generic -n backstage manual-secret --from-literal=GITHUB_CLIENTSECRET=dummy --from-literal=GITHUB_CLIENTID=dummy --from-literal=GITHUB_TOKEN=dummy --from-literal=K8S_SA_TOKEN=dummy --from-literal=ARGOCD_AUTH_TOKEN=dummy --from-literal=GRAFANA_TOKEN=dummy
curl -L https://raw.githubusercontent.com/suxess-it/sx-cnp-oss/main/install-k3d-cluster.sh | bash
- name: argocd show diff
if: ${{ failure() }}
env:
APPS: "argocd sx-loki sx-kubecost sx-keycloak sx-promtail sx-tempo sx-crossplane sx-bootstrap-app sx-kargo approved-application-team-app sx-cert-manager sx-argo-rollouts sx-external-secrets sx-kyverno sx-kube-prometheus-stack"
shell: bash
run: |
pwd
curl -kL -o argocd https://argocd-127-0-0-1.nip.io/download/argocd-linux-amd64
chmod u+x argocd
ls -l
./argocd login argocd-127-0-0-1.nip.io --grpc-web --insecure --username admin --password admin
for app in ${APPS} ; do echo "$app diff" ; ./argocd app diff $app --grpc-web ; done
- name: mustgather data for troubleshooting
if: ${{ failure() }}
shell: bash
run: |
echo "===== node describe ======"
kubectl describe node sx-cnp-oss-cluster-control-plane
echo "===== node top ======"
kubectl top node
echo "===== node yaml ======"
kubectl get nodes -o yaml
echo "===== yaml output of all applications ======"
kubectl get application -n argocd -o yaml
- name: analyze with k8sgpt
if: ${{ failure() }}
shell: bash
run: |
k8sgpt analyze
- name: mustgather logs for troubleshooting
if: ${{ failure() }}
shell: bash
run: |
kubectl logs -n argocd statefulset/argocd-application-controller
kubectl logs -n argocd deployment/argocd-repo-server