Skip to content

Fix multiplatform build, update golang version and dependencies #165

Fix multiplatform build, update golang version and dependencies

Fix multiplatform build, update golang version and dependencies #165

Workflow file for this run

name: Build, test and publish
on:
push:
branches: [ "**" ]
tags: [ "v*.*.*" ]
permissions:
contents: write
id-token: write
packages: write
jobs:
changes:
if: ${{ github.repository == 'danfromtitan/envars-from-node-labels' }}
runs-on: ubuntu-latest
outputs:
build: ${{ steps.filter.outputs.build }}
chart: ${{ steps.filter.outputs.chart }}
test: ${{ steps.filter.outputs.test }}
steps:
- uses: actions/checkout@v4
- uses: dorny/paths-filter@v2
id: filter
with:
base: ${{ github.ref }}
filters: |
build:
- 'cmd/envars-webhook/*'
- 'Dockerfile'
- 'go.mod'
- 'Makefile'
chart:
- 'charts/envars-webhook/**/*'
test:
- '.github/**/*'
- 'test/*'
build:
needs: changes
if: |
(github.repository == 'danfromtitan/envars-from-node-labels') &&
(needs.changes.outputs.build == 'true')
runs-on: ubuntu-latest
outputs:
image-tag: ${{ steps.image-output.outputs.image-tag }}
image-name: ${{ steps.image-output.outputs.image-name }}
image-digest: ${{ steps.image-output.outputs.image-digest }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-go@v4
with:
go-version: 1.19
cache: true
- uses: docker/metadata-action@v5
id: meta
with:
images: |
ghcr.io/danfromtitan/envars-from-node-labels
tags: |
type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'master') }}
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
type=sha,prefix=${{ github.ref_name }}-
- uses: docker/setup-qemu-action@v3
- uses: docker/setup-buildx-action@v3
- uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- run: go install github.com/mitchellh/gox@latest
- run: make build-all
- uses: docker/build-push-action@v5
id: docker-build
with:
context: ./
platforms: linux/amd64,linux/arm64
push: ${{ github.event_name != 'pull_request' }}
provenance: false
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
- id: image-output
run: |
echo image-tag=$(echo '${{ steps.docker-build.outputs.metadata }}' | jq -r '."image.name" | split(",")[-1] | split(":")[-1]') >>$GITHUB_OUTPUT
echo image-name=$(echo '${{ steps.docker-build.outputs.metadata }}' | jq -r '."image.name"') >>$GITHUB_OUTPUT
echo image-digest=${{ steps.docker-build.outputs.digest }} >>$GITHUB_OUTPUT
chart:
needs: changes
permissions:
contents: write
if: |
(github.repository == 'danfromtitan/envars-from-node-labels') &&
(needs.changes.outputs.chart == 'true')
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: configure git
run: |
git config --global user.name "$GITHUB_ACTOR"
git config --global user.email "[email protected]"
- name: lint helm chart
run: |
helm lint ./charts/envars-webhook
- uses: helm/[email protected]
with:
charts_dir: charts
env:
CR_RELEASE_NAME_TEMPLATE: "helm-chart-{{ .Version }}"
CR_SKIP_EXISTING: "true"
CR_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
test:
needs: [build, changes, chart]
if: |
always() &&
(github.repository == 'danfromtitan/envars-from-node-labels') &&
(needs.changes.outputs.build == 'true' || needs.changes.outputs.chart == 'true' || needs.changes.outputs.test == 'true')
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: medyagh/setup-minikube@master
id: minikube
with:
container-runtime: containerd
driver: docker
kubernetes-version: v1.28
minikube-version: 1.31.2
- name: Check minikube pods
run: kubectl get pods -A
- name: setup helm
run: |
curl -s https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3 | bash
helm repo add envars-webhook https://danfromtitan.github.io/envars-from-node-labels/
helm repo update
helm search repo envars-webhook -l
- name: deploy webhook
timeout-minutes: 2
env:
NAMESPACE: webtest
run: |
IMAGE_TAG=latest
[[ "${{contains(needs.build.result, 'success') }}" == "true" ]] && IMAGE_TAG=${{ needs.build.outputs.image-tag }}
helm install -n $NAMESPACE --create-namespace envars-webhook envars-webhook/envars-webhook --set image.tag="$IMAGE_TAG" \
--set webhook.containersAllowed.ingester=true,webhook.containersAllowed.prober=true,webhook.containersAllowed.store-gateway=true
until kubectl get pods -n $NAMESPACE | grep "Running" > /dev/null; do
kubectl get pods -n $NAMESPACE | tail -n +2
sleep 1
done
- name: stage samples
run: |
make sample
- name: verify pod-allowed
timeout-minutes: 2
env:
NAMESPACE: samples
run: |
kubectl apply -f test/pod-allowed.yaml
until kubectl get pods -n $NAMESPACE | grep "pod-allowed" | grep "Completed" > /dev/null; do sleep 1; done
kubectl logs -n $NAMESPACE pod-allowed | grep "NODE_MINIKUBE_K8S_IO_NAME" > /dev/null
- name: verify pod-excluded
timeout-minutes: 2
env:
NAMESPACE: samples
run: |
kubectl apply -f test/pod-excluded.yaml
until kubectl get pods -n $NAMESPACE | grep "pod-excluded" | grep "Completed" > /dev/null; do sleep 1; done
kubectl logs -n $NAMESPACE pod-excluded | grep -v "NODE_MINIKUBE_K8S_IO_NAME" > /dev/null
- name: verify pod-mixed
timeout-minutes: 2
env:
NAMESPACE: samples
run: |
kubectl apply -f test/pod-mixed.yaml
until kubectl get pods -n $NAMESPACE | grep "pod-mixed" | grep "Completed" > /dev/null; do sleep 1; done
kubectl logs -n $NAMESPACE pod-mixed ingester | grep "NODE_MINIKUBE_K8S_IO_NAME" > /dev/null
kubectl logs -n $NAMESPACE pod-mixed store-gateway | grep "NODE_MINIKUBE_K8S_IO_NAME" > /dev/null
kubectl logs -n $NAMESPACE pod-mixed compactor | grep -v "NODE_MINIKUBE_K8S_IO_NAME" > /dev/null
- name: verify deployment
timeout-minutes: 2
env:
NAMESPACE: samples
run: |
kubectl apply -f test/deployment.yaml
until [[ $(kubectl get pods -n $NAMESPACE | grep "deployment" | grep "Running" | wc -l) == "2" ]]; do sleep 1; done
for POD in $(kubectl get pods -n $NAMESPACE | grep "deployment" | awk '{print $1}'); do
kubectl logs -n $NAMESPACE $POD prober | grep "NODE_MINIKUBE_K8S_IO_NAME"
kubectl exec -n $NAMESPACE $POD -c ingester -- env | grep "NODE_MINIKUBE_K8S_IO_NAME"
done
- name: verify statefulset
timeout-minutes: 2
env:
NAMESPACE: samples
run: |
kubectl apply -f test/statefulset.yaml
until [[ $(kubectl get pods -n $NAMESPACE | grep "statefulset" | grep "Running" | wc -l) == "2" ]]; do sleep 1; done
for POD in $(kubectl get pods -n $NAMESPACE | grep "statefulset" | awk '{print $1}'); do
kubectl logs -n $NAMESPACE $POD prober | grep "NODE_MINIKUBE_K8S_IO_NAME"
kubectl exec -n $NAMESPACE $POD -c store-gateway -- env | grep "NODE_MINIKUBE_K8S_IO_NAME"
done