-
Notifications
You must be signed in to change notification settings - Fork 5
99 lines (80 loc) · 3.52 KB
/
ci-github-cms.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
name: ci [CMS]
on:
push:
branches:
- "**"
pull_request:
branches:
- "main"
jobs:
deploy-at-github:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Set up Kubernetes cluster with Kind
uses: helm/[email protected]
with:
cluster_name: gh-k8s-cluster
- name: Set up Helm
uses: azure/setup-helm@v3
with:
version: v3.12.0
- name: Create CMS namespace
run: |
kubectl create namespace cms
- name: Install Prometheus Operator CRDs
run: |
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
helm repo update
kubectl create namespace monitoring
helm install prometheus-operator prometheus-community/kube-prometheus-stack --namespace monitoring --set prometheusOperator.createCustomResource=false --set defaultRules.create=false --set alertmanager.enabled=false --set prometheus.enabled=false --set grafana.enabled=false
- name: Install KEDA Autoscaler
run: |
helm repo add kedacore https://kedacore.github.io/charts
helm repo update
kubectl create namespace keda
helm install keda kedacore/keda --namespace keda
- name: Mount CVMFS
run: |
kubectl create namespace cvmfs-csi
helm install -n cvmfs-csi cvmfs-csi oci://registry.cern.ch/kubernetes/charts/cvmfs-csi --values ci/values-cvmfs-csi.yaml
kubectl apply -f ci/cvmfs-storageclass.yaml -n cvmfs-csi
- name: Deploy Helm chart
run: |
helm upgrade --install supersonic ./helm/supersonic \
--values values/values-cms-ci.yaml -n cms
- name: CVMFS Mount ready
run: |
kubectl wait --for condition=Ready pod --all -n cvmfs-csi --timeout 120s
- name: Envoy proxy ready
run: |
kubectl wait --for condition=Ready pod -l app.kubernetes.io/component=envoy --timeout 120s -n cms
- name: Prometheus ready
run: |
kubectl wait --for condition=Ready pod -l app.kubernetes.io/component=prometheus --timeout 120s -n cms
kubectl get svc,pod -l app.kubernetes.io/component=prometheus -n cms
- name: Grafana ready
run: |
kubectl wait --for condition=Ready pod -l app.kubernetes.io/component=grafana --timeout 120s -n cms
- name: Triton server ready
run: |
kubectl wait --for condition=Ready pod -l app.kubernetes.io/component=triton --timeout 300s -n cms
- name: Autoscaler ready
run: |
kubectl wait --for condition=AbleToScale hpa -l app.kubernetes.io/component=keda --timeout 120s -n cms
kubectl wait --for condition=Ready so -l app.kubernetes.io/component=keda --timeout 120s -n cms
- name: Validate Deployment
run: |
kubectl get all -n cms
- name: Run Perf Analyzer Job
run: |
kubectl apply -f ci/perf-analyzer-job.yaml
kubectl wait --for=condition=complete job/perf-analyzer-job -n cms --timeout=180s || \
(echo "Perf-analyzer job did not complete in time or failed." && exit 1)
POD_NAME=$(kubectl get pods -n cms -l job-name=perf-analyzer-job -o jsonpath="{.items[0].metadata.name}")
echo "========== Perf Analyzer Logs =========="
kubectl logs -n cms "$POD_NAME"
echo "========================================"
- name: Cleanup
run: kind delete cluster --name gh-k8s-cluster