this is a test
All checks were successful
Build and Push Teamspeak Images on Base Image Update / check-for-changes (push) Successful in 14s
Build and Push Teamspeak Images on Base Image Update / build-alpine (push) Successful in 9s
Build and Push Teamspeak Images on Base Image Update / build-basic (push) Successful in 9s
Build and Push Teamspeak Images on Base Image Update / build-debian (push) Successful in 9s
Build and Push Teamspeak Images on Base Image Update / generate-changelogs (push) Successful in 9s
Build and Push Teamspeak Images on Base Image Update / generate-build-info (push) Successful in 7s

This commit is contained in:
2025-07-10 14:55:58 -07:00
parent 1bc9954509
commit d974e63287

View File

@@ -25,8 +25,10 @@ jobs:
outputs: outputs:
should_build_alpine: ${{ steps.check.outputs.should_build_alpine }} should_build_alpine: ${{ steps.check.outputs.should_build_alpine }}
should_build_debian: ${{ steps.check.outputs.should_build_debian }} should_build_debian: ${{ steps.check.outputs.should_build_debian }}
should_build_basic: ${{ steps.check.outputs.should_build_basic }}
alpine_digest: ${{ steps.get_digest.outputs.alpine_digest }} alpine_digest: ${{ steps.get_digest.outputs.alpine_digest }}
debian_digest: ${{ steps.get_digest.outputs.debian_digest }} debian_digest: ${{ steps.get_digest.outputs.debian_digest }}
basic_digest: ${{ steps.get_digest.outputs.basic_digest }}
steps: steps:
- name: Checkout code - name: Checkout code
@@ -44,8 +46,10 @@ jobs:
run: | run: |
alpine_digest=$(docker inspect --format='{{index .RepoDigests 0}}' alpine:latest || echo "unknown") alpine_digest=$(docker inspect --format='{{index .RepoDigests 0}}' alpine:latest || echo "unknown")
debian_digest=$(docker inspect --format='{{index .RepoDigests 0}}' gitea.fithwum.tech/${{ secrets.GIT_USERNAME }}/debian-base:bookworm || echo "unknown") debian_digest=$(docker inspect --format='{{index .RepoDigests 0}}' gitea.fithwum.tech/${{ secrets.GIT_USERNAME }}/debian-base:bookworm || echo "unknown")
basic_digest=$(docker inspect --format='{{index .RepoDigests 0}}' gitea.fithwum.tech/${{ secrets.GIT_USERNAME }}/debian-base:bookworm || echo "unknown")
echo "alpine_digest=$alpine_digest" >> $GITHUB_OUTPUT echo "alpine_digest=$alpine_digest" >> $GITHUB_OUTPUT
echo "debian_digest=$debian_digest" >> $GITHUB_OUTPUT echo "debian_digest=$debian_digest" >> $GITHUB_OUTPUT
echo "basic_digest=$basic_digest" >> $GITHUB_OUTPUT
- name: Compare digests and detect changes - name: Compare digests and detect changes
id: check id: check
@@ -84,6 +88,7 @@ jobs:
check_variant "alpine" "${{ steps.get_digest.outputs.alpine_digest }}" check_variant "alpine" "${{ steps.get_digest.outputs.alpine_digest }}"
check_variant "debian" "${{ steps.get_digest.outputs.debian_digest }}" check_variant "debian" "${{ steps.get_digest.outputs.debian_digest }}"
check_variant "basic" "${{ steps.get_digest.outputs.basic_digest }}"
build-alpine: build-alpine:
needs: check-for-changes needs: check-for-changes
@@ -131,7 +136,21 @@ jobs:
echo "[INFO] Building $IMAGE" echo "[INFO] Building $IMAGE"
docker buildx build --platform linux/amd64 --push -t "$IMAGE" --metadata-file "$METAFILE" ./debian docker buildx build --platform linux/amd64 --push -t "$IMAGE" --metadata-file "$METAFILE" ./debian
- name: Build and Push Basic Image (depends on debian) build-basic:
needs: check-for-changes
if: needs.check-for-changes.outputs.should_build_basic == 'true'
runs-on: doc-docker-build
outputs:
built: 'true'
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Login to Docker registry
run: |
echo "${{ secrets.GIT_TOKEN }}" | docker login gitea.fithwum.tech -u "${{ secrets.GIT_USERNAME }}" --password-stdin
- name: Build and Push Basic Image
run: | run: |
IMAGE="${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_ORG }}/${{ env.IMAGE_REPO_TS }}:basic" IMAGE="${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_ORG }}/${{ env.IMAGE_REPO_TS }}:basic"
METAFILE2="${{ env.CACHE_DIR }}/metadata-basic.json" METAFILE2="${{ env.CACHE_DIR }}/metadata-basic.json"
@@ -143,7 +162,8 @@ jobs:
needs: check-for-changes needs: check-for-changes
if: | if: |
needs.check-for-changes.outputs.should_build_alpine == 'true' || needs.check-for-changes.outputs.should_build_alpine == 'true' ||
needs.check-for-changes.outputs.should_build_debian == 'true' needs.check-for-changes.outputs.should_build_debian == 'true' ||
needs.check-for-changes.outputs.should_build_basic == 'true'
runs-on: doc-docker-build runs-on: doc-docker-build
steps: steps:
- name: Checkout source - name: Checkout source
@@ -160,6 +180,9 @@ jobs:
if [[ "${{ needs.check-for-changes.outputs.should_build_debian }}" == "true" ]]; then if [[ "${{ needs.check-for-changes.outputs.should_build_debian }}" == "true" ]]; then
versions+=("debian") versions+=("debian")
fi fi
if [[ "${{ needs.check-for-changes.outputs.should_build_basic }}" == "true" ]]; then
versions+=("basic")
fi
for version in "${versions[@]}"; do for version in "${versions[@]}"; do
echo "[INFO] Updating changelog for $version" echo "[INFO] Updating changelog for $version"
@@ -219,8 +242,9 @@ jobs:
IMAGE_REGISTRY: ${{ env.IMAGE_REGISTRY }} IMAGE_REGISTRY: ${{ env.IMAGE_REGISTRY }}
IMAGE_ORG: ${{ env.IMAGE_ORG }} IMAGE_ORG: ${{ env.IMAGE_ORG }}
IMAGE_REPO_TS: ${{ env.IMAGE_REPO_TS }} IMAGE_REPO_TS: ${{ env.IMAGE_REPO_TS }}
ALPINE_DIGEST: ${{ needs.check-for-changes.outputs.alpine_digest }} ALPINE_DIGEST: ${{ needs.check-for-changes.outputs.alpine_digest || 'unknown' }}
DEBIAN_DIGEST: ${{ needs.check-for-changes.outputs.debian_digest }} DEBIAN_DIGEST: ${{ needs.check-for-changes.outputs.debian_digest || 'unknown' }}
BASIC_DIGEST: ${{ needs.check-for-changes.outputs.basic_digest || 'unknown' }}
run: | run: |
human_size() { human_size() {
local b=$1 local b=$1
@@ -236,8 +260,15 @@ jobs:
} }
versions=() versions=()
[[ "${{ needs.check-for-changes.outputs.should_build_alpine }}" == "true" ]] && versions+=("alpine") if [[ "${{ needs.check-for-changes.outputs.should_build_alpine }}" == "true" ]]; then
[[ "${{ needs.check-for-changes.outputs.should_build_debian }}" == "true" ]] && versions+=("debian") versions+=("alpine")
fi
if [[ "${{ needs.check-for-changes.outputs.should_build_debian }}" == "true" ]]; then
versions+=("debian")
fi
if [[ "${{ needs.check-for-changes.outputs.should_build_basic }}" == "true" ]]; then
versions+=("basic")
fi
for version in "${versions[@]}"; do for version in "${versions[@]}"; do
echo "[INFO] Generating build-info.json for $version" echo "[INFO] Generating build-info.json for $version"
@@ -254,6 +285,8 @@ jobs:
base_digest="$ALPINE_DIGEST" base_digest="$ALPINE_DIGEST"
elif [ "$version" = "debian" ]; then elif [ "$version" = "debian" ]; then
base_digest="$DEBIAN_DIGEST" base_digest="$DEBIAN_DIGEST"
elif [ "$version" = "basic" ]; then
base_digest="$BASIC_DIGEST"
fi fi
jq -n \ jq -n \
@@ -286,7 +319,7 @@ jobs:
git commit -m "Update build-info on $(date -u +'%Y-%m-%dT%H:%M:%SZ')" git commit -m "Update build-info on $(date -u +'%Y-%m-%dT%H:%M:%SZ')"
git push git push
for version in alpine debian; do for version in alpine debian basic; do
TAG="build-$version" TAG="build-$version"
git tag -d "$TAG" 2>/dev/null || true git tag -d "$TAG" 2>/dev/null || true
git tag "$TAG" git tag "$TAG"