test
All checks were successful
Build and Push Teamspeak Images on Base Image Update / check-for-changes (push) Successful in 16s
Build and Push Teamspeak Images on Base Image Update / build-alpine (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / build-debian (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / generate-changelogs (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / generate-build-info (push) Has been skipped

This commit is contained in:
2025-07-10 13:30:19 -07:00
parent 09571c9bf5
commit 6fe9d612d1

View File

@@ -20,68 +20,73 @@ env:
CACHE_DIR: .cache CACHE_DIR: .cache
jobs: jobs:
check-base-images-and-build: check-for-changes:
runs-on: doc-docker-build runs-on: doc-docker-build
outputs:
should_build_alpine: ${{ steps.check.outputs.should_build_alpine }}
should_build_debian: ${{ steps.check.outputs.should_build_debian }}
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v3 uses: actions/checkout@v3
- name: Set up Docker Buildx - name: Pull latest base images
uses: docker/setup-buildx-action@v3
- name: Log in to Gitea Registry
run: echo "${{ secrets.DOCKER_PASSWORD }}" | docker login ${{ env.IMAGE_REGISTRY }} -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin
- name: Get alpine:latest digest
id: alpine_digest
run: | run: |
docker pull docker.io/library/alpine:latest docker pull alpine:latest
DIGEST=$(docker inspect --format='{{index .RepoDigests 0}}' alpine:latest || echo "unknown") docker pull gitea.fithwum.tech/${{ secrets.GIT_USERNAME }}/debian-base:bookworm
echo "digest=$DIGEST" >> $GITHUB_OUTPUT
- name: Get debian-base:bookworm digest - name: Get base image digests
id: debian_digest id: get_digest
run: | run: |
IMAGE="${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_ORG }}/${{ env.IMAGE_REPO_DEBIAN }}:${{ env.IMAGE_TAG_DEBIAN }}" alpine_digest=$(docker inspect --format='{{index .RepoDigests 0}}' alpine:latest || echo "unknown")
docker pull "$IMAGE" debian_digest=$(docker inspect --format='{{index .RepoDigests 0}}' gitea.fithwum.tech/${{ secrets.GIT_USERNAME }}/debian-base:bookworm || echo "unknown")
DIGEST=$(docker inspect --format='{{index .RepoDigests 0}}' "$IMAGE" || echo "unknown")
echo "digest=$DIGEST" >> $GITHUB_OUTPUT
- name: Compare digests and update .cache echo "alpine_digest=$alpine_digest" >> $GITHUB_OUTPUT
id: compare_digests echo "debian_digest=$debian_digest" >> $GITHUB_OUTPUT
- name: Compare digests and detect changes
id: check
run: | run: |
mkdir -p $CACHE_DIR check_variant() {
local variant=$1
check_digest() {
local name=$1
local new_digest=$2 local new_digest=$2
local file="$CACHE_DIR/$name.digest" local infofile="$variant/build-info.json"
local last_digest=""
local base_changed=false
local code_changed=false
echo "[INFO] Checking $name..." if [ -f "$infofile" ]; then
if [[ -f $file ]]; then last_digest=$(jq -r '.base_digest // empty' "$infofile")
old_digest=$(cat "$file")
else
old_digest=""
fi fi
if [[ "$old_digest" == "$new_digest" ]]; then if [ "$last_digest" != "$new_digest" ]; then
echo "$name_changed=false" >> $GITHUB_OUTPUT base_changed=true
echo "[INFO] $name unchanged." fi
if git diff --name-only origin/main...HEAD | grep "^$variant/" > /dev/null; then
code_changed=true
fi
if [ "$base_changed" = true ] || [ "$code_changed" = true ]; then
echo "$variant_changed=true" >> $GITHUB_OUTPUT
else else
echo "$new_digest" > "$file" echo "$variant_changed=false" >> $GITHUB_OUTPUT
echo "$name_changed=true" >> $GITHUB_OUTPUT
echo "[INFO] $name changed."
fi fi
} }
check_digest "alpine" "${{ steps.alpine_digest.outputs.digest }}" git fetch origin main
check_digest "debian-base" "${{ steps.debian_digest.outputs.digest }}"
git config user.name "${{ secrets.GIT_USERNAME }}" check_variant "alpine" "${{ steps.get_digest.outputs.alpine_digest }}"
git config user.email "${{ secrets.GIT_EMAIL }}" check_variant "debian" "${{ steps.get_digest.outputs.debian_digest }}"
git add $CACHE_DIR
git commit -m "Update base image digests" || echo "[INFO] No cache changes to commit" build-alpine:
git push || true needs: check-for-changes
if: needs.check-for-changes.outputs.should_build_alpine == 'true'
runs-on: doc-docker-build
outputs:
built: 'true'
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Build and Push Alpine Image - name: Build and Push Alpine Image
if: steps.compare_digests.outputs.alpine_changed == 'true' if: steps.compare_digests.outputs.alpine_changed == 'true'
@@ -90,6 +95,16 @@ jobs:
echo "[INFO] Building $IMAGE" echo "[INFO] Building $IMAGE"
docker buildx build --platform linux/amd64 --push -t "$IMAGE" ./alpine docker buildx build --platform linux/amd64 --push -t "$IMAGE" ./alpine
build-debian:
needs: check-for-changes
if: needs.check-for-changes.outputs.should_build_debian == 'true'
runs-on: doc-docker-build
outputs:
built: 'true'
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Build and Push Debian Image - name: Build and Push Debian Image
if: steps.compare_digests.outputs.debian-base_changed == 'true' if: steps.compare_digests.outputs.debian-base_changed == 'true'
run: | run: |
@@ -105,7 +120,10 @@ jobs:
docker buildx build --platform linux/amd64 --push -t "$IMAGE" ./basic docker buildx build --platform linux/amd64 --push -t "$IMAGE" ./basic
generate-changelogs: generate-changelogs:
needs: check-base-images-and-build needs: check-for-changes
if: |
needs.check-for-changes.outputs.should_build_alpine == 'true' ||
needs.check-for-changes.outputs.should_build_debian == 'true'
runs-on: doc-docker-build runs-on: doc-docker-build
steps: steps:
- name: Checkout source - name: Checkout source
@@ -115,10 +133,18 @@ jobs:
run: | run: |
git clone https://${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_TOKEN }}@gitea.fithwum.tech/fithwum/teamspeak-server.git upload-repo git clone https://${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_TOKEN }}@gitea.fithwum.tech/fithwum/teamspeak-server.git upload-repo
- name: Generate per-version changelogs - name: Generate changelogs only for updated variants
run: | run: |
cd upload-repo cd upload-repo
for version in alpine basic debian; do
if [[ "${{ needs.check-for-changes.outputs.should_build_alpine }}" == "true" ]]; then
versions+=("alpine")
fi
if [[ "${{ needs.check-for-changes.outputs.should_build_debian }}" == "true" ]]; then
versions+=("debian")
fi
for version in "${versions[@]}"; do
echo "[INFO] Updating changelog for $version" echo "[INFO] Updating changelog for $version"
changelog="$version/CHANGES.md" changelog="$version/CHANGES.md"
@@ -139,7 +165,7 @@ jobs:
fi fi
done done
- name: Commit and push changelogs if changed - name: Commit and push changelogs
run: | run: |
cd upload-repo cd upload-repo
git config user.name "${{ secrets.GIT_USERNAME }}" git config user.name "${{ secrets.GIT_USERNAME }}"
@@ -154,7 +180,12 @@ jobs:
fi fi
generate-build-info: generate-build-info:
needs: generate-changelogs needs:
- build-alpine
- build-debian
if: |
needs.build-alpine.outputs.built == 'true' ||
needs.build-debian.outputs.built == 'true'
runs-on: doc-docker-build runs-on: doc-docker-build
steps: steps:
- name: Checkout source - name: Checkout source
@@ -164,7 +195,13 @@ jobs:
run: | run: |
git clone https://${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_TOKEN }}@gitea.fithwum.tech/fithwum/teamspeak-server.git upload-repo git clone https://${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_TOKEN }}@gitea.fithwum.tech/fithwum/teamspeak-server.git upload-repo
- name: Generate build-info.json per version - name: Generate build-info.json only for updated variants
env:
IMAGE_REGISTRY: ${{ env.IMAGE_REGISTRY }}
IMAGE_ORG: ${{ env.IMAGE_ORG }}
IMAGE_REPO_TS: ${{ env.IMAGE_REPO_TS }}
ALPINE_DIGEST: ${{ needs.check-for-changes.outputs.alpine_digest }}
DEBIAN_DIGEST: ${{ needs.check-for-changes.outputs.debian_digest }}
run: | run: |
human_size() { human_size() {
local b=$1 local b=$1
@@ -180,21 +217,27 @@ jobs:
} }
cd upload-repo cd upload-repo
for version in alpine basic debian; do declare -A digests
digests[alpine]="${ALPINE_DIGEST}"
digests[debian]="${DEBIAN_DIGEST}"
versions=()
[[ "${{ needs.check-for-changes.outputs.should_build_alpine }}" == "true" ]] && versions+=("alpine")
[[ "${{ needs.check-for-changes.outputs.should_build_debian }}" == "true" ]] && versions+=("debian")
for version in "${versions[@]}"; do
echo "[INFO] Generating build-info.json for $version" echo "[INFO] Generating build-info.json for $version"
mkdir -p "$version" mkdir -p "$version"
infofile="$version/build-info.json" infofile="$version/build-info.json"
image="${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO_TS}:$version"
image="${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_ORG }}/${{ env.IMAGE_REPO_TS }}:$version"
digest=$(docker inspect --format='{{if .RepoDigests}}{{index .RepoDigests 0}}{{else}}unknown{{end}}' "$image" 2>/dev/null || echo "unknown") digest=$(docker inspect --format='{{if .RepoDigests}}{{index .RepoDigests 0}}{{else}}unknown{{end}}' "$image" 2>/dev/null || echo "unknown")
size_bytes=$(docker image inspect "$image" --format='{{.Size}}' 2>/dev/null || echo "0") size_bytes=$(docker image inspect "$image" --format='{{.Size}}' 2>/dev/null || echo "0")
size_bytes=${size_bytes//[^0-9]/} size_bytes=${size_bytes//[^0-9]/}
if [[ -z "$size_bytes" ]]; then size_bytes=0; fi
size_human=$(human_size "$size_bytes") size_human=$(human_size "$size_bytes")
base_digest="${digests[$version]:-unknown}"
jq -n \ jq -n \
--arg version "$version" \ --arg version "$version" \
--arg commit "$(git rev-parse HEAD)" \ --arg commit "$(git rev-parse HEAD)" \
@@ -203,6 +246,7 @@ jobs:
--arg digest "$digest" \ --arg digest "$digest" \
--arg image_size "$size_human" \ --arg image_size "$size_human" \
--argjson image_size_bytes "$size_bytes" \ --argjson image_size_bytes "$size_bytes" \
--arg base_digest "$base_digest" \
'{ '{
version: $version, version: $version,
commit: $commit, commit: $commit,
@@ -210,7 +254,8 @@ jobs:
image_tag: $image_tag, image_tag: $image_tag,
digest: $digest, digest: $digest,
image_size: $image_size, image_size: $image_size,
image_size_bytes: $image_size_bytes image_size_bytes: $image_size_bytes,
base_digest: $base_digest
}' > "$infofile" }' > "$infofile"
done done
@@ -225,8 +270,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
# Tag the commit for each version for version in alpine debian; do
for version in alpine basic debian; 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"
@@ -234,4 +278,4 @@ jobs:
done done
else else
echo "[INFO] No build-info changes to commit." echo "[INFO] No build-info changes to commit."
fi fi