All checks were successful
Build Container / build (push) Successful in 1m13s
## Summary With Phases 1 and 2 complete, the runner image no longer needs most of its bundled tools. This PR strips it down and adds what was missing. **Removed** (now inside Dagger containers): - Node.js 24.x - Docker CLI + buildx plugin - skopeo - gnupg, lsb-release, xz-utils **Added:** - `tzdata` — fixes the TZ env var (#159, #160, #161) so `TZ=America/Los_Angeles` actually works - `flyctl` — was being installed from scratch every release **Workflow changes:** - Remove "Ensure Dagger CLI" bootstrap steps from both workflows (Dagger is in the image) - Remove "Install flyctl" step from build-blumeops (flyctl is in the image) - Remove job-level `TZ` from build-blumeops (moved to runner configmap `runner.envs`) - Set `TZ: America/Los_Angeles` in runner configmap so all job containers inherit it ## Deployment After merge: 1. Build and release the new runner image: `mise run container-release forgejo-runner v2.0.0` 2. Sync the runner: `argocd app sync forgejo-runner` 3. Verify: `kubectl -n forgejo-runner exec deploy/forgejo-runner -c runner -- date` (but the real test is running a docs release and checking the changelog date) Reviewed-on: https://forge.ops.eblu.me/eblume/blumeops/pulls/162
77 lines
2.4 KiB
YAML
77 lines
2.4 KiB
YAML
# Generic container build workflow
|
|
# Triggers on tags matching: <container>-v<version>
|
|
# Builds from containers/<container>/Dockerfile if it exists
|
|
#
|
|
# Uses Dagger to build and push images to the Zot registry.
|
|
#
|
|
# Examples:
|
|
# nettest-v1.0.0 -> builds containers/nettest/
|
|
# devpi-v2.1.0 -> builds containers/devpi/
|
|
# foo-v1.0.0 -> skips if containers/foo/ doesn't exist
|
|
name: Build Container
|
|
|
|
on:
|
|
push:
|
|
tags:
|
|
- '*-v[0-9]*'
|
|
|
|
jobs:
|
|
build:
|
|
runs-on: k8s
|
|
steps:
|
|
- name: Parse tag
|
|
id: parse
|
|
run: |
|
|
TAG="${GITHUB_REF_NAME}"
|
|
echo "Tag: $TAG"
|
|
|
|
# Extract container name (everything before -v)
|
|
# e.g., "nettest-v1.0.0" -> "nettest", "my-app-v2.0.0" -> "my-app"
|
|
CONTAINER="${TAG%-v[0-9]*}"
|
|
VERSION="${TAG#"${CONTAINER}"-}"
|
|
|
|
echo "container=$CONTAINER" >> "$GITHUB_OUTPUT"
|
|
echo "version=$VERSION" >> "$GITHUB_OUTPUT"
|
|
echo "Container: $CONTAINER"
|
|
echo "Version: $VERSION"
|
|
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Check if container exists
|
|
id: check
|
|
run: |
|
|
CONTAINER="${{ steps.parse.outputs.container }}"
|
|
CONTEXT="containers/$CONTAINER"
|
|
|
|
if [ -f "$CONTEXT/Dockerfile" ]; then
|
|
echo "Found $CONTEXT/Dockerfile"
|
|
echo "exists=true" >> "$GITHUB_OUTPUT"
|
|
else
|
|
echo "No Dockerfile found at $CONTEXT/Dockerfile"
|
|
echo "exists=false" >> "$GITHUB_OUTPUT"
|
|
fi
|
|
|
|
- name: Skip if container not found
|
|
if: steps.check.outputs.exists != 'true'
|
|
run: |
|
|
echo "========================================"
|
|
echo "Container not found: ${{ steps.parse.outputs.container }}"
|
|
echo "========================================"
|
|
echo ""
|
|
echo "Tag '${{ github.ref_name }}' does not match any container in containers/"
|
|
echo ""
|
|
echo "Available containers:"
|
|
find containers -maxdepth 1 -mindepth 1 -type d -exec basename {} \; 2>/dev/null | sort | while read -r name; do
|
|
echo " - $name"
|
|
done || echo " (none)"
|
|
echo ""
|
|
echo "Skipping build."
|
|
|
|
- name: Publish
|
|
if: steps.check.outputs.exists == 'true'
|
|
run: |
|
|
dagger call publish \
|
|
--src=. \
|
|
--container-name=${{ steps.parse.outputs.container }} \
|
|
--version=${{ steps.parse.outputs.version }}
|