Skip to content

Commit

Permalink
chore(ci): split workflows by fedora version (ublue-os#1097)
Browse files Browse the repository at this point in the history
  • Loading branch information
bsherman authored Apr 7, 2024
1 parent bb2bcac commit eb08d5d
Show file tree
Hide file tree
Showing 6 changed files with 193 additions and 55 deletions.
27 changes: 27 additions & 0 deletions .github/workflows/build-38-bluefin.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: bluefin 38
on:
merge_group:
pull_request:
branches:
- main
- testing
paths-ignore:
- '**.md'
push:
branches:
- main
- testing
paths-ignore:
- '**.md'
schedule:
- cron: '42 16 * * *' # 16:42 UTC everyday
workflow_dispatch:

jobs:
build:
name: build
uses: ./.github/workflows/reusable-build.yml
secrets: inherit
with:
brand_name: bluefin
fedora_version: 38
27 changes: 27 additions & 0 deletions .github/workflows/build-39-aurora.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: aurora 39
on:
merge_group:
pull_request:
branches:
- main
- testing
paths-ignore:
- '**.md'
push:
branches:
- main
- testing
paths-ignore:
- '**.md'
schedule:
- cron: '41 16 * * *' # 16:41 UTC everyday
workflow_dispatch:

jobs:
build:
name: build
uses: ./.github/workflows/reusable-build.yml
secrets: inherit
with:
brand_name: aurora
fedora_version: 39
27 changes: 27 additions & 0 deletions .github/workflows/build-39-bluefin.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: bluefin 39
on:
merge_group:
pull_request:
branches:
- main
- testing
paths-ignore:
- '**.md'
push:
branches:
- main
- testing
paths-ignore:
- '**.md'
schedule:
- cron: '41 16 * * *' # 16:41 UTC everyday
workflow_dispatch:

jobs:
build:
name: build
uses: ./.github/workflows/reusable-build.yml
secrets: inherit
with:
brand_name: bluefin
fedora_version: 39
27 changes: 27 additions & 0 deletions .github/workflows/build-40-aurora.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: aurora 40
on:
merge_group:
pull_request:
branches:
- main
- testing
paths-ignore:
- '**.md'
push:
branches:
- main
- testing
paths-ignore:
- '**.md'
schedule:
- cron: '40 16 * * *' # 16:40 UTC everyday
workflow_dispatch:

jobs:
build:
name: build
uses: ./.github/workflows/reusable-build.yml
secrets: inherit
with:
brand_name: aurora
fedora_version: 40
27 changes: 27 additions & 0 deletions .github/workflows/build-40-bluefin.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: bluefin 40
on:
merge_group:
pull_request:
branches:
- main
- testing
paths-ignore:
- '**.md'
push:
branches:
- main
- testing
paths-ignore:
- '**.md'
schedule:
- cron: '40 16 * * *' # 16:40 UTC everyday
workflow_dispatch:

jobs:
build:
name: build
uses: ./.github/workflows/reusable-build.yml
secrets: inherit
with:
brand_name: bluefin
fedora_version: 40
113 changes: 58 additions & 55 deletions .github/workflows/build.yml → .github/workflows/reusable-build.yml
Original file line number Diff line number Diff line change
@@ -1,66 +1,53 @@
name: Build and Push Image
on:
schedule:
- cron: '40 16 * * *' # 16:40 UTC everyday
merge_group:
pull_request:
branches:
- main
- testing
paths-ignore:
- '**.md'
push:
branches:
- main
- testing
paths-ignore:
- '**.md'
workflow_dispatch:
workflow_call:
inputs:
fedora_version:
description: 'The Fedora release version: 38, 39, 40, etc'
required: true
type: string
brand_name:
description: "'aurora' or 'bluefin'"
required: true
type: string
env:
IMAGE_REGISTRY: ghcr.io/${{ github.repository_owner }}

concurrency:
group: ${{ github.workflow }}-${{ github.ref || github.run_id }}
group: ${{ github.workflow }}-${{ github.ref || github.run_id }}-${{ inputs.fedora_version }}
cancel-in-progress: true

jobs:
build-container:
name: build
build_container:
name: image
runs-on: ubuntu-latest
continue-on-error: false
strategy:
fail-fast: false
matrix:
image_flavor: [main, nvidia, asus, asus-nvidia, framework, surface, surface-nvidia]
base_name: [bluefin, bluefin-dx, aurora, aurora-dx]
major_version: [38, 39, 40]
include:
- major_version: 38
is_latest_version: false
is_stable_version: true
is_gts_version: true
- major_version: 39
is_latest_version: true
is_stable_version: true
is_gts_version: false
- major_version: 40
is_latest_version: false
is_stable_version: false
is_gts_version: false
image_flavor:
- main
- nvidia
- asus
- asus-nvidia
- framework
- surface
- surface-nvidia
base_name:
- ${{ inputs.brand_name }}
- ${{ inputs.brand_name }}-dx
fedora_version:
- ${{ inputs.fedora_version }}
exclude:
- major_version: 38
base_name: aurora
- major_version: 38
base_name: aurora-dx
- major_version: 38
- fedora_version: 38
image_flavor: asus
- major_version: 38
- fedora_version: 38
image_flavor: asus-nvidia
- major_version: 38
- fedora_version: 38
image_flavor: surface
- major_version: 38
- fedora_version: 38
image_flavor: surface-nvidia
- major_version: 40
- fedora_version: 40
image_flavor: framework

steps:
Expand Down Expand Up @@ -95,7 +82,7 @@ jobs:
- name: Verify base image
uses: EyeCantCU/cosign-action/[email protected]
with:
containers: ${{ env.BASE_IMAGE_NAME}}-${{ matrix.image_flavor }}:${{ matrix.major_version }}
containers: ${{ env.BASE_IMAGE_NAME}}-${{ matrix.image_flavor }}:${{ matrix.fedora_version }}

- name: Verify Chainguard images
if: matrix.base_name != 'bluefin' && matrix.base_name != 'aurora'
Expand All @@ -118,23 +105,39 @@ jobs:
run: |
# Generate a timestamp for creating an image version history
TIMESTAMP="$(date +%Y%m%d)"
MAJOR_VERSION="${{ matrix.major_version }}"
FEDORA_VERSION="${{ matrix.fedora_version }}"
if [[ "${{ matrix.fedora_version }}" -eq "38" ]]; then
IS_LATEST_VERSION=false
IS_STABLE_VERSION=true
IS_GTS_VERSION=true
elif [[ "${{ matrix.fedora_version }}" -eq "39" ]]; then
IS_LATEST_VERSION=true
IS_STABLE_VERSION=true
IS_GTS_VERSION=false
elif [[ "${{ matrix.fedora_version }}" -eq "40" ]]; then
IS_LATEST_VERSION=false
IS_STABLE_VERSION=false
IS_GTS_VERSION=false
fi
COMMIT_TAGS=()
BUILD_TAGS=()
# Have tags for tracking builds during pull request
SHA_SHORT="${GITHUB_SHA::7}"
COMMIT_TAGS+=("pr-${{ github.event.number }}-${MAJOR_VERSION}")
COMMIT_TAGS+=("${SHA_SHORT}-${MAJOR_VERSION}")
COMMIT_TAGS+=("pr-${{ github.event.number }}-${FEDORA_VERSION}")
COMMIT_TAGS+=("${SHA_SHORT}-${FEDORA_VERSION}")
if [[ "${{ matrix.is_latest_version }}" == "true" ]] && \
[[ "${{ matrix.is_stable_version }}" == "true" ]]; then
COMMIT_TAGS+=("pr-${{ github.event.number }}")
COMMIT_TAGS+=("${SHA_SHORT}")
fi
BUILD_TAGS=("${MAJOR_VERSION}" "${MAJOR_VERSION}-${TIMESTAMP}")
BUILD_TAGS=("${FEDORA_VERSION}" "${FEDORA_VERSION}-${TIMESTAMP}")
if [[ ${{ github.ref_name }} == "testing" ]]; then
BUILD_TAGS=("${MAJOR_VERSION}-testing" "${MAJOR_VERSION}-testing-${TIMESTAMP}")
BUILD_TAGS=("${FEDORA_VERSION}-testing" "${FEDORA_VERSION}-testing-${TIMESTAMP}")
if [[ "${{ matrix.is_latest_version }}" == "true" ]] && \
[[ "${{ matrix.is_stable_version }}" == "true" ]]; then
BUILD_TAGS+=("testing")
Expand Down Expand Up @@ -168,7 +171,7 @@ jobs:
shell: bash
run: |
set -eo pipefail
ver=$(skopeo inspect docker://ghcr.io/ublue-os/silverblue-${{ matrix.image_flavor }}:${{ matrix.major_version }} | jq -r '.Labels["org.opencontainers.image.version"]')
ver=$(skopeo inspect docker://ghcr.io/ublue-os/silverblue-${{ matrix.image_flavor }}:${{ matrix.fedora_version }} | jq -r '.Labels["org.opencontainers.image.version"]')
if [ -z "$ver" ] || [ "null" = "$ver" ]; then
echo "inspected image version must not be empty or null"
exit 1
Expand Down Expand Up @@ -204,7 +207,7 @@ jobs:
IMAGE_NAME=${{ env.IMAGE_NAME }}
IMAGE_FLAVOR=${{ matrix.image_flavor }}
IMAGE_VENDOR=${{ github.repository_owner }}
FEDORA_MAJOR_VERSION=${{ matrix.major_version }}
FEDORA_MAJOR_VERSION=${{ matrix.fedora_version }}
TARGET_BASE=${{ matrix.target_base }}
AKMODS_FLAVOR=${{ env.AKMODS_FLAVOR }}
labels: ${{ steps.meta.outputs.labels }}
Expand Down Expand Up @@ -265,10 +268,10 @@ jobs:
echo "${{ toJSON(steps.push.outputs) }}"
check:
name: Check all builds successful
name: Check all ${{ inputs.brand_name }} ${{ inputs.fedora_version }} builds successful
if: ${{ !cancelled() }}
runs-on: ubuntu-latest
needs: [build-container]
needs: [build_container]
steps:
- name: Exit on failure
if: ${{ needs.build_container.result == 'failure' }}
Expand All @@ -279,7 +282,7 @@ jobs:
run: exit 0

build_iso:
name: build iso
name: iso
needs: [check]
if: github.ref_name == 'testing'
# Eventually would be nice for building images in PRs
Expand Down

0 comments on commit eb08d5d

Please sign in to comment.