Files
copr-publish/scripts/copr-build.sh
rob thijssen ffa66e61ef fix: read gzipped builder-live.log when dumping chroot logs
copr-cli download-build fetches builder-live.log.gz (the on-mirror form
for completed builds), but the dump loop looked for plain builder-live.log
and silently emitted nothing. Try .gz first with zcat, fall back to plain,
and note the absence explicitly if neither is present.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-16 14:44:05 +03:00

69 lines
2.1 KiB
Bash
Executable File

#!/bin/bash
# Submit an SRPM to COPR, watch the build, and dump per-chroot build logs
# to stdout so they are captured in CI output.
#
# Usage: copr-build.sh <project> <srpm> [srpm...]
# Example: copr-build.sh helexa/cortex ./cortex-0.1.2-1.fc43.src.rpm
#
# Requires: copr-cli on PATH, a valid ~/.config/copr.
set -o pipefail
PROJECT="$1"
shift
if [ -z "$PROJECT" ] || [ "$#" -eq 0 ]; then
echo "usage: $0 <project> <srpm> [srpm...]" >&2
exit 2
fi
# Submit without waiting; capture the build ID from stdout.
SUBMIT_OUT=$(copr-cli build --nowait "$PROJECT" "$@")
echo "$SUBMIT_OUT"
BUILD_ID=$(echo "$SUBMIT_OUT" | grep -oP 'Created builds: \K[0-9]+' | head -n1)
if [ -z "$BUILD_ID" ]; then
echo "error: could not parse build ID from copr-cli output" >&2
exit 1
fi
echo
echo "Build $BUILD_ID submitted to $PROJECT"
echo "Follow live: https://copr.fedorainfracloud.org/coprs/build/$BUILD_ID"
echo
# Watch the build; captures status transitions to stdout. Exit non-zero
# on build failure, but defer propagating that until after we've fetched
# logs so the CI output contains diagnostics either way.
if copr-cli watch-build "$BUILD_ID"; then
STATUS=0
else
STATUS=$?
fi
# Fetch per-chroot results (logs + rpms). Anonymous download — no auth needed.
LOG_DIR="$(mktemp -d -t copr-logs.XXXXXX)"
copr-cli download-build --dest "$LOG_DIR" "$BUILD_ID" || {
echo "warning: failed to download build artifacts" >&2
}
# Dump each chroot's builder-live.log as a collapsible group. COPR stores
# the log gzipped on the mirror once the build has finished; fall back to
# the plain file in case a backend version ever serves it uncompressed.
for chroot_dir in "$LOG_DIR"/*/; do
[ -d "$chroot_dir" ] || continue
chroot=$(basename "$chroot_dir")
echo
echo "::group::${chroot} builder-live.log"
if [ -f "${chroot_dir}builder-live.log.gz" ]; then
zcat "${chroot_dir}builder-live.log.gz"
elif [ -f "${chroot_dir}builder-live.log" ]; then
cat "${chroot_dir}builder-live.log"
else
echo "(no builder-live.log found for ${chroot})"
fi
echo "::endgroup::"
done
exit "$STATUS"