test
All checks were successful
Build and Push Teamspeak Images on Base Image Update / check-for-changes (push) Successful in 11s
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 / build-basic (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / generate-build-info (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / generate-changelogs (push) Has been skipped
All checks were successful
Build and Push Teamspeak Images on Base Image Update / check-for-changes (push) Successful in 11s
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 / build-basic (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / generate-build-info (push) Has been skipped
Build and Push Teamspeak Images on Base Image Update / generate-changelogs (push) Has been skipped
This commit is contained in:
@@ -135,6 +135,8 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Login to Docker registry
|
- name: Login to Docker registry
|
||||||
run: |
|
run: |
|
||||||
@@ -157,6 +159,8 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Login to Docker registry
|
- name: Login to Docker registry
|
||||||
run: |
|
run: |
|
||||||
@@ -179,6 +183,8 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Login to Docker registry
|
- name: Login to Docker registry
|
||||||
run: |
|
run: |
|
||||||
@@ -208,16 +214,30 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Generate build-info.json only for updated variants
|
- name: Load digests from cache
|
||||||
|
id: base_digests
|
||||||
|
run: |
|
||||||
|
load_digest() {
|
||||||
|
file=".cache/$1-base.digest"
|
||||||
|
if [ -f "$file" ]; then
|
||||||
|
cat "$file"
|
||||||
|
else
|
||||||
|
echo "unknown"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
echo "alpine=$(load_digest alpine)" >> $GITHUB_OUTPUT
|
||||||
|
echo "debian=$(load_digest debian)" >> $GITHUB_OUTPUT
|
||||||
|
echo "basic=$(load_digest basic)" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Generate build-info.json for each variant
|
||||||
env:
|
env:
|
||||||
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 }}
|
|
||||||
DEBIAN_DIGEST: ${{ needs.check-for-changes.outputs.debian_digest }}
|
|
||||||
BASIC_DIGEST: ${{ needs.check-for-changes.outputs.basic_digest }}
|
|
||||||
CACHE_DIR: ${{ env.CACHE_DIR }}
|
|
||||||
run: |
|
run: |
|
||||||
|
variants=(alpine debian basic)
|
||||||
|
|
||||||
human_size() {
|
human_size() {
|
||||||
local b=$1
|
local b=$1
|
||||||
local d=''
|
local d=''
|
||||||
@@ -231,39 +251,31 @@ jobs:
|
|||||||
printf "%s%s\n" "$b" "${S[$s]}"
|
printf "%s%s\n" "$b" "${S[$s]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
versions=()
|
variants=()
|
||||||
if [[ "${{ needs.check-for-changes.outputs.should_build_alpine }}" == "true" ]]; then
|
[[ "${{ needs.build-alpine.outputs.built }}" == "true" ]] && variants+=("alpine")
|
||||||
versions+=("alpine")
|
[[ "${{ needs.build-debian.outputs.built }}" == "true" ]] && variants+=("debian")
|
||||||
fi
|
[[ "${{ needs.build-basic.outputs.built }}" == "true" ]] && variants+=("basic")
|
||||||
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 variant in "${variants[@]}"; do
|
||||||
echo "[INFO] Generating build-info.json for $version"
|
image_tag="${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO_TS}:${variant}"
|
||||||
mkdir -p "$version"
|
digest=$(docker inspect --format='{{index .RepoDigests 0}}' "$image_tag" 2>/dev/null || echo "unknown")
|
||||||
infofile="$version/build-info.json"
|
size_bytes=$(docker image inspect "$image_tag" --format='{{.Size}}' 2>/dev/null || echo 0)
|
||||||
image="${IMAGE_REGISTRY}/${IMAGE_ORG}/${IMAGE_REPO_TS}:$version"
|
size_human=$(numfmt --to=iec --suffix=B $size_bytes 2>/dev/null || echo "${size_bytes}B")
|
||||||
|
commit_hash=$(git rev-parse HEAD)
|
||||||
|
build_time=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
|
||||||
|
|
||||||
echo "[DEBUG] Inspecting image: $image"
|
base_digest="${{ steps.base_digests.outputs[$variant] }}"
|
||||||
|
|
||||||
docker pull "$image" || echo "[WARN] Failed to pull $image"
|
|
||||||
docker images --digests | grep "$version" || echo "[WARN] Image not listed locally"
|
|
||||||
digest=$(docker inspect --format='{{index .RepoDigests 0}}' "$(docker images --format '{{.Repository}}:{{.Tag}}' | grep "${IMAGE_REPO_TS}:$version" | head -n1)" 2>/dev/null || echo "unknown")
|
|
||||||
size_bytes=$(docker inspect --format='{{.Size}}' "$(docker images --format '{{.Repository}}:{{.Tag}}' | grep "${IMAGE_REPO_TS}:$version" | head -n1)" 2>/dev/null || echo "0")
|
|
||||||
size_human=$(human_size "$size_bytes")
|
|
||||||
|
|
||||||
|
mkdir -p "$variant"
|
||||||
jq -n \
|
jq -n \
|
||||||
--arg version "$version" \
|
--arg version "$variant" \
|
||||||
--arg commit "$(git rev-parse HEAD)" \
|
--arg commit "$commit_hash" \
|
||||||
--arg build_time "$(date -u +'%Y-%m-%dT%H:%M:%SZ')" \
|
--arg build_time "$build_time" \
|
||||||
--arg image_tag "$image" \
|
--arg image_tag "$image_tag" \
|
||||||
--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,
|
||||||
@@ -272,9 +284,14 @@ jobs:
|
|||||||
digest: $digest,
|
digest: $digest,
|
||||||
image_size: $image_size,
|
image_size: $image_size,
|
||||||
image_size_bytes: $image_size_bytes,
|
image_size_bytes: $image_size_bytes,
|
||||||
}' > "$infofile"
|
base_digest: $base_digest
|
||||||
|
}' > "$variant/build-info.json"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
- name: Show generated build-info.json
|
||||||
|
run: |
|
||||||
|
find . -name build-info.json -exec echo '--- {} ---' \; -exec cat {} \;
|
||||||
|
|
||||||
- name: Commit and push build-info if changed
|
- name: Commit and push build-info if changed
|
||||||
run: |
|
run: |
|
||||||
git config user.name "${{ secrets.GIT_USERNAME }}"
|
git config user.name "${{ secrets.GIT_USERNAME }}"
|
||||||
|
|||||||
Reference in New Issue
Block a user