mirror of
https://github.com/flatcar/scripts.git
synced 2025-09-23 14:41:31 +02:00
Merge pull request #510 from marineam/dist
Properly report errors from update_distfiles and other cleanups
This commit is contained in:
commit
4744e3f96c
@ -33,6 +33,8 @@ if [[ ${FLAGS_parallel} -eq ${FLAGS_TRUE} ]]; then
|
|||||||
GSUTIL_OPTS="-m"
|
GSUTIL_OPTS="-m"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
EXIT_CODE=0
|
||||||
|
|
||||||
|
|
||||||
update_local_mirror() {
|
update_local_mirror() {
|
||||||
local repo_name="$1"
|
local repo_name="$1"
|
||||||
@ -46,6 +48,7 @@ update_local_mirror() {
|
|||||||
info "Starting distfiles update for $repo_name"
|
info "Starting distfiles update for $repo_name"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
rm -rf "${repo_mirror}/log" # clear old logs
|
||||||
mkdir -p "${repo_mirror}/"{distfiles,info,log,tmp}
|
mkdir -p "${repo_mirror}/"{distfiles,info,log,tmp}
|
||||||
emirrordist --mirror --verbose $extra_flags \
|
emirrordist --mirror --verbose $extra_flags \
|
||||||
--jobs=${NUM_JOBS} --repo="${repo_name}" \
|
--jobs=${NUM_JOBS} --repo="${repo_name}" \
|
||||||
@ -54,13 +57,29 @@ update_local_mirror() {
|
|||||||
--fetch-log-dir="${repo_mirror}/log" \
|
--fetch-log-dir="${repo_mirror}/log" \
|
||||||
--failure-log="${repo_mirror}/log/failure.log" \
|
--failure-log="${repo_mirror}/log/failure.log" \
|
||||||
--success-log="${repo_mirror}/log/success.log" \
|
--success-log="${repo_mirror}/log/success.log" \
|
||||||
--scheduled-deletion-log="${repo_mirror}/log/deletion.log" \
|
|
||||||
--deletion-db="${repo_mirror}/info/deletion.db" \
|
|
||||||
--distfiles-db="${repo_mirror}/info/distfiles.db" \
|
--distfiles-db="${repo_mirror}/info/distfiles.db" \
|
||||||
--deletion-delay=$((86400 * 14)) \
|
|
||||||
--restrict-mirror-exemptions="gentoo" \
|
--restrict-mirror-exemptions="gentoo" \
|
||||||
--temp-dir="${repo_mirror}/tmp" \
|
--temp-dir="${repo_mirror}/tmp" \
|
||||||
--verify-existing-digest
|
--verify-existing-digest
|
||||||
|
|
||||||
|
if [[ ! -s "${repo_mirror}/log/failure.log" ]]; then
|
||||||
|
info "Completed distfiles update for $repo_name without error"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# report what went wrong :(
|
||||||
|
local lastpkg pkg file error
|
||||||
|
while read pkg file error; do
|
||||||
|
local log="${repo_mirror}/log/${file}.log"
|
||||||
|
if [[ "${pkg}" != "${lastpkg}" ]]; then
|
||||||
|
error "${pkg} failed:"
|
||||||
|
lastpkg="${pkg}"
|
||||||
|
fi
|
||||||
|
error " ${file} ${error}"
|
||||||
|
[[ -s "${log}" ]] && cat "${log}"
|
||||||
|
done <"${repo_mirror}/log/failure.log"
|
||||||
|
|
||||||
|
EXIT_CODE=1
|
||||||
}
|
}
|
||||||
upload_mirror() {
|
upload_mirror() {
|
||||||
local repo_name="$1"
|
local repo_name="$1"
|
||||||
@ -68,10 +87,11 @@ upload_mirror() {
|
|||||||
local remote_mirror="${UPLOAD_ROOT}/$repo_name"
|
local remote_mirror="${UPLOAD_ROOT}/$repo_name"
|
||||||
|
|
||||||
info "Uploading public distfiles for $repo_name"
|
info "Uploading public distfiles for $repo_name"
|
||||||
gsutil ${GSUTIL_OPTS} cp -n \
|
gsutil ${GSUTIL_OPTS} rsync -c \
|
||||||
"${local_mirror}/distfiles/*" "${remote_mirror}/distfiles"
|
"${local_mirror}/distfiles/" "${remote_mirror}/distfiles"
|
||||||
|
|
||||||
info "Uploading private metadata for $repo_name"
|
info "Uploading private metadata for $repo_name"
|
||||||
|
# uses cp instead of rsync in order to provide acl
|
||||||
gsutil ${GSUTIL_OPTS} cp -a project-private \
|
gsutil ${GSUTIL_OPTS} cp -a project-private \
|
||||||
"${local_mirror}/info/*" "${remote_mirror}/info"
|
"${local_mirror}/info/*" "${remote_mirror}/info"
|
||||||
}
|
}
|
||||||
@ -82,17 +102,15 @@ download_mirror() {
|
|||||||
|
|
||||||
info "Downloading public distfiles for $repo_name"
|
info "Downloading public distfiles for $repo_name"
|
||||||
mkdir -p "${local_mirror}/"{distfiles,info}
|
mkdir -p "${local_mirror}/"{distfiles,info}
|
||||||
gsutil ${GSUTIL_OPTS} cp -n \
|
gsutil ${GSUTIL_OPTS} rsync -c -d \
|
||||||
"${remote_mirror}/distfiles/*" "${local_mirror}/distfiles"
|
"${remote_mirror}/distfiles/" "${local_mirror}/distfiles"
|
||||||
|
|
||||||
info "Downloading private metadata for $repo_name"
|
info "Downloading private metadata for $repo_name"
|
||||||
gsutil ${GSUTIL_OPTS} cp "${remote_mirror}/info/*" "${local_mirror}/info"
|
gsutil ${GSUTIL_OPTS} rsync -c -d \
|
||||||
|
"${remote_mirror}/info/" "${local_mirror}/info"
|
||||||
}
|
}
|
||||||
|
|
||||||
if [[ ${FLAGS_download} -eq ${FLAGS_TRUE} ]]; then
|
if [[ ${FLAGS_download} -eq ${FLAGS_TRUE} ]]; then
|
||||||
if [[ ! -f "$HOME/.boto" ]]; then
|
|
||||||
die_notrace "Please run gsutil config to create ~/.boto"
|
|
||||||
fi
|
|
||||||
for repo in "$@"; do
|
for repo in "$@"; do
|
||||||
download_mirror "$repo"
|
download_mirror "$repo"
|
||||||
done
|
done
|
||||||
@ -111,12 +129,10 @@ if [[ ${FLAGS_dry_run} == ${FLAGS_TRUE} ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ${FLAGS_upload} -eq ${FLAGS_TRUE} ]]; then
|
if [[ ${FLAGS_upload} -eq ${FLAGS_TRUE} ]]; then
|
||||||
if [[ ! -f "$HOME/.boto" ]]; then
|
|
||||||
die_notrace "Please run gsutil config to create ~/.boto"
|
|
||||||
fi
|
|
||||||
for repo in "$@"; do
|
for repo in "$@"; do
|
||||||
upload_mirror "$repo"
|
upload_mirror "$repo"
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
info "Done!"
|
command_completed
|
||||||
|
exit $EXIT_CODE
|
||||||
|
Loading…
x
Reference in New Issue
Block a user