-
Notifications
You must be signed in to change notification settings - Fork 112
85 lines (84 loc) · 3.42 KB
/
test_kminion.yaml
File metadata and controls
85 lines (84 loc) · 3.42 KB
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
---
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You 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.
name: Test KMinion Chart
on:
workflow_call:
inputs: {}
secrets: {}
defaults:
run:
shell: nix develop --impure --command bash {0}
jobs:
test:
name: Run ct tests for kminion chart
env:
KMINION_NAMESPACE: kminion-${{ github.run_id }}-${{ github.run_attempt }}
strategy:
fail-fast: true
runs-on: ubuntu-22.04
steps:
- uses: nixbuild/nix-quick-install-action@v34
with:
github_access_token: ${{ secrets.GITHUB_TOKEN }}
# Cache the nix store.
- uses: nix-community/cache-nix-action@v6
with:
primary-key: nix-${{ runner.os }}-${{ runner.arch }}-${{ hashFiles('**/*.nix', '**/flake.lock') }}
restore-prefixes-first-match: nix-${{ runner.os }}-${{ runner.arch }}
# Cache helm repositories.
- uses: actions/cache@v4
with:
key: helm-repositories
path: |
~/.cache/helm
- uses: actions/checkout@v6
with:
fetch-depth: 0
- name: Create kind cluster
uses: helm/kind-action@92086f6be054225fa813e0a4b13787fc9088faab # v1.13.0
with:
config: .github/kind.yaml
- name: Check kind config worked
run: kubectl get nodes
- name: Install cert-manager
run: task helm:install:cert-manager
- name: Install Redpanda
run: |
helm repo add redpanda https://charts.redpanda.com
helm install --namespace redpanda --create-namespace redpanda redpanda/redpanda --wait --wait-for-jobs
- name: Copy Redpanda TLS cert to kminion namespace
run: |
kubectl create namespace ${{ env.KMINION_NAMESPACE }} || true
kubectl -n redpanda wait --for=condition=Ready --timeout=10m certificates/redpanda-default-cert
kubectl -n redpanda get secret redpanda-default-cert -o yaml | \
sed -e '/namespace/d' | \
sed -e '/resourceVersion/d' | \
sed -e '/uid/d' | \
kubectl apply -n ${{ env.KMINION_NAMESPACE }} -f -
# Chart-testing requires there to be a branch on the local repository
# for diffing. This will create such a branch without performing a
# checkout.
- name: Fetch origin/main
run: git fetch origin ${{ github.event.repository.default_branch }}:${{ github.event.repository.default_branch }}
- name: Run chart-testing (install and upgrade)
run: |
ct install \
--github-groups \
--upgrade \
--config .github/ct-kminion.yaml \
--skip-missing-values \
--target-branch ${{ github.event.repository.default_branch }} \
--namespace ${{ env.KMINION_NAMESPACE }}