Skip to content

Scheduled rpmrepo snapshot #159

Scheduled rpmrepo snapshot

Scheduled rpmrepo snapshot #159

name: Scheduled rpmrepo snapshot
on:
schedule:
- cron: '0 0 1,15 * *' # 1st and 15th of every month
workflow_dispatch:
jobs:
update-snapshots:
name: "Scheduled rpmrepo snapshot"
timeout-minutes: 2880 # 2 days timeout
runs-on: ubuntu-latest
steps:
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: us-east-1
role-duration-seconds: 21600 # 6 hour session length
- name: Clone repository
uses: actions/checkout@v4
- name: Count jobs
id: count_jobs
run: echo "size=$(find repo -name '*json' | wc -l)" >>$GITHUB_OUTPUT
- name: Generate suffix
id: generate_suffix
run: echo "suffix=$(date '+%Y%m%d')" >>$GITHUB_OUTPUT
- name: Submit snapshot array job
id: submit_job
run: |
echo size ${{ steps.count_jobs.outputs.size }} sha ${GITHUB_SHA}
aws batch submit-job \
--job-name "snapshot-runner" \
--job-definition "rpmrepo-batch-snapshot-staging" \
--job-queue "rpmrepo-batch-staging" \
--timeout "attemptDurationSeconds=86400" \
--array-properties "size=${{ steps.count_jobs.outputs.size }}" \
--parameters "repoCommit=$GITHUB_SHA,repoBranch=main,repoSuffix=${{ steps.generate_suffix.outputs.suffix }},repoTarget=auto" \
> out.json
echo "job_id=$(jq -r .jobId out.json)" >>$GITHUB_OUTPUT
echo "job_name=$(jq -r .jobName out.json)" >>$GITHUB_OUTPUT
- name: Wait for snapshot jobs to start
id: wait_for_jobs_start
run: |
while true; do
SUBMITTED=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status SUBMITTED | jq '.jobSummaryList | length')
PENDING=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status PENDING | jq '.jobSummaryList | length')
RUNNABLE=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status RUNNABLE | jq '.jobSummaryList | length')
STARTING=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status STARTING | jq '.jobSummaryList | length')
RUNNING=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status RUNNING | jq '.jobSummaryList | length')
if [ $((SUBMITTED + PENDING + RUNNABLE + STARTING + RUNNING)) -gt 0 ]; then
break
fi
sleep 30s
done
- name: Wait for snapshot jobs to finish
id: wait_for_jobs
run: |
while true; do
SUBMITTED=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status SUBMITTED | jq '.jobSummaryList | length')
PENDING=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status PENDING | jq '.jobSummaryList | length')
RUNNABLE=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status RUNNABLE | jq '.jobSummaryList | length')
STARTING=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status STARTING | jq '.jobSummaryList | length')
RUNNING=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status RUNNING | jq '.jobSummaryList | length')
if [ $((SUBMITTED + PENDING + RUNNABLE + STARTING + RUNNING)) = 0 ]; then
break
fi
echo Submitted $SUBMITTED, Pending $PENDING, Runnable $RUNNABLE, Starting $STARTING, Running $RUNNING
sleep 5m
done
aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status FAILED > failed.json
if [ $(jq '.jobSummaryList | length' failed.json) != 0 ]; then
echo Failed jobs!
for JOBID in $(jq -r '.jobSummaryList[].jobId' failed.json | xargs); do
LOGSTREAM_NAME=$(aws batch describe-jobs --jobs "$JOBID" | jq -r '.jobs[0].container.logStreamName')
LOGS="$(aws logs get-log-events --log-group-name /aws/batch/job --log-stream-name "$LOGSTREAM_NAME" --start-from-head | jq -r '.events[].message')"
echo "Logs for failed job \"$JOBID\":"
echo "$LOGS"
echo
done
fi
SUCCEEDED=$(aws batch list-jobs --array-job-id ${{ steps.submit_job.outputs.job_id }} --job-status SUCCEEDED | jq '.jobSummaryList | length')
echo "succeeded=$SUCCEEDED" >>$GITHUB_OUTPUT
echo "failed=$(jq '.jobSummaryList | length' failed.json)" >>$GITHUB_OUTPUT
- name: Submit enumerate-cache job
id: submit_cache_job
run: |
aws batch submit-job \
--job-name "enumerate-cache-runner" \
--job-definition "rpmrepo-batch-enumerate-cache-staging" \
--job-queue "rpmrepo-batch-staging" \
--timeout "attemptDurationSeconds=600" > out.json
echo "enumerate_cache_job_id=$(jq -r .jobId out.json)" >>$GITHUB_OUTPUT
echo "enumerate_cache_job_name=$(jq -r .jobName out.json)" >>$GITHUB_OUTPUT
- name: Wait for enumerate cache job to finish
id: wait_for_cache_job
run: |
while true; do
STATUS=$(aws batch describe-jobs \
--jobs ${{ steps.submit_cache_job.outputs.enumerate_cache_job_id}} \
| jq -r .jobs[0].status)
if [ $STATUS = "FAILED" ]; then
echo "enumerate_cache_succeeded=false" >>$GITHUB_OUTPUT
break
fi
if [ $STATUS = "SUCCEEDED" ]; then
echo "enumerate_cache_succeeded=true" >>$GITHUB_OUTPUT
break
fi
echo "Waiting on cache job (status: $STATUS)"
sleep 10s
done
- name: Clone osbuild-composer repository
uses: actions/checkout@v4
with:
repository: osbuild/osbuild-composer
path: osbuild-composer
fetch-depth: 0
- name: Update schutzfile and open PR in osbuild-composer repository
env:
GITHUB_TOKEN: ${{ secrets.SCHUTZBOT_GH_TOKEN }}
SUFFIX: ${{ steps.generate_suffix.outputs.suffix }}
JOBS_SUCCEEDED: ${{ steps.wait_for_jobs.outputs.succeeded }}
JOBS_FAILED: ${{ steps.wait_for_jobs.outputs.failed }}
WORKFLOW_RUN: ${{ github.run_id }}
ENUMERATE_CACHE_SUCCEEDED: ${{steps.wait_for_cache_job.outputs.enumerate_cache_succeeded}}
REPO: "osbuild-composer"
run: .github/scripts/snapshot_update_pr.sh
- name: Clone osbuild repository
uses: actions/checkout@v4
with:
repository: osbuild/osbuild
path: osbuild
fetch-depth: 0
- name: Update schutzfile and open PR in osbuild repository
env:
GITHUB_TOKEN: ${{ secrets.SCHUTZBOT_GH_TOKEN }}
SUFFIX: ${{ steps.generate_suffix.outputs.suffix }}
JOBS_SUCCEEDED: ${{ steps.wait_for_jobs.outputs.succeeded }}
JOBS_FAILED: ${{ steps.wait_for_jobs.outputs.failed }}
WORKFLOW_RUN: ${{ github.run_id }}
ENUMERATE_CACHE_SUCCEEDED: ${{steps.wait_for_cache_job.outputs.enumerate_cache_succeeded}}
REPO: "osbuild"
run: .github/scripts/snapshot_update_pr.sh
- name: Clone cloud image val repository
uses: actions/checkout@v4
with:
repository: osbuild/cloud-image-val
path: cloud-image-val
fetch-depth: 0
- name: Update schutzfile and open PR in cloud-image-val repository
env:
GITHUB_TOKEN: ${{ secrets.SCHUTZBOT_GH_TOKEN }}
SUFFIX: ${{ steps.generate_suffix.outputs.suffix }}
JOBS_SUCCEEDED: ${{ steps.wait_for_jobs.outputs.succeeded }}
JOBS_FAILED: ${{ steps.wait_for_jobs.outputs.failed }}
WORKFLOW_RUN: ${{ github.run_id }}
ENUMERATE_CACHE_SUCCEEDED: ${{steps.wait_for_cache_job.outputs.enumerate_cache_succeeded}}
REPO: "cloud-image-val"
run: .github/scripts/snapshot_update_pr.sh
- name: Clone images repository
uses: actions/checkout@v4
with:
repository: osbuild/images
path: images
fetch-depth: 0
- name: Update schutzfile and open PR in images repository
env:
GITHUB_TOKEN: ${{ secrets.SCHUTZBOT_GH_TOKEN }}
SUFFIX: ${{ steps.generate_suffix.outputs.suffix }}
JOBS_SUCCEEDED: ${{ steps.wait_for_jobs.outputs.succeeded }}
JOBS_FAILED: ${{ steps.wait_for_jobs.outputs.failed }}
WORKFLOW_RUN: ${{ github.run_id }}
ENUMERATE_CACHE_SUCCEEDED: ${{steps.wait_for_cache_job.outputs.enumerate_cache_succeeded}}
REPO: "images"
run: .github/scripts/snapshot_update_pr.sh