mirror of
https://github.com/auricom/home-cluster.git
synced 2025-12-25 16:44:39 +01:00
120 lines
3.5 KiB
YAML
120 lines
3.5 KiB
YAML
---
|
|
# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
|
|
name: "Flux Image Test"
|
|
|
|
on:
|
|
pull_request:
|
|
branches: ["main"]
|
|
paths: ["kubernetes/**"]
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.event.number || github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
extract-images:
|
|
name: Extract Images
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
pull-requests: write
|
|
outputs:
|
|
matrix: ${{ steps.extract-images.outputs.images }}
|
|
steps:
|
|
- name: Generate Token
|
|
uses: actions/create-github-app-token@v1
|
|
id: app-token
|
|
with:
|
|
app-id: "${{ secrets.BOT_APP_ID }}"
|
|
private-key: "${{ secrets.BOT_APP_PRIVATE_KEY }}"
|
|
|
|
- name: Setup System Tools
|
|
shell: bash
|
|
run: sudo apt-get -qq update && sudo apt-get -qq install --no-install-recommends -y curl git jo
|
|
|
|
- name: Setup Workflow Tools
|
|
uses: jdx/rtx-action@v1
|
|
with:
|
|
install: true
|
|
rtx_toml: |
|
|
[tools]
|
|
flux2 = "latest"
|
|
yq = "latest"
|
|
|
|
- name: Checkout Default Branch
|
|
uses: actions/checkout@v4
|
|
with:
|
|
token: "${{ steps.app-token.outputs.token }}"
|
|
ref: "${{ github.event.repository.default_branch }}"
|
|
path: default
|
|
|
|
- name: Checkout Pull Request Branch
|
|
uses: actions/checkout@v4
|
|
with:
|
|
token: "${{ steps.app-token.outputs.token }}"
|
|
path: pull
|
|
|
|
- name: Gather Images in Default Branch
|
|
uses: docker://ghcr.io/allenporter/flux-local:pr-472
|
|
with:
|
|
args: >-
|
|
get cluster
|
|
--path /github/workspace/default/kubernetes
|
|
--enable-images
|
|
--output yaml
|
|
--output-file default.yaml
|
|
|
|
- name: Gather Images in Pull Request Branch
|
|
uses: docker://ghcr.io/allenporter/flux-local:pr-472
|
|
with:
|
|
args: >-
|
|
get cluster
|
|
--path /github/workspace/pull/kubernetes
|
|
--enable-images
|
|
--output yaml
|
|
--output-file pull.yaml
|
|
|
|
- name: Filter Default Branch Results
|
|
shell: bash
|
|
run: |
|
|
yq -r '[.. | .images? | select(. != null)] | flatten | sort | unique | .[]' \
|
|
default.yaml > default.txt
|
|
|
|
- name: Filter Pull Request Branch Results
|
|
shell: bash
|
|
run: |
|
|
yq -r '[.. | .images? | select(. != null)] | flatten | sort | unique | .[]' \
|
|
pull.yaml > pull.txt
|
|
|
|
- name: Compare Default and Pull Request Images
|
|
id: extract-images
|
|
shell: bash
|
|
run: |
|
|
images=$(jo -a $(grep -vf default.txt pull.txt))
|
|
echo "images=${images}" >> $GITHUB_OUTPUT
|
|
echo "${images}"
|
|
|
|
test-images:
|
|
if: ${{ needs.extract-images.outputs.matrix != '[]' }}
|
|
name: Test images
|
|
runs-on: ubuntu-latest
|
|
needs: ["extract-images"]
|
|
strategy:
|
|
matrix:
|
|
images: ${{ fromJSON(needs.extract-images.outputs.matrix) }}
|
|
max-parallel: 4
|
|
fail-fast: false
|
|
steps:
|
|
- name: Test Images
|
|
run: docker pull ${{ matrix.images }}
|
|
|
|
# Summarize matrix https://github.community/t/status-check-for-a-matrix-jobs/127354/7
|
|
test-images-success:
|
|
if: ${{ always() }}
|
|
needs: ["test-images"]
|
|
name: Test Images Successful
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- if: ${{ contains(needs.*.result, 'failure') || contains(needs.*.result, 'cancelled') }}
|
|
name: Check matrix status
|
|
run: exit 1
|