Merge pull request #862 from flatcar/gabriel-samfira/add-on-pr-workflow

Add on pr workflow
This commit is contained in:
Gabriel 2023-06-02 10:32:24 +03:00 committed by GitHub
commit 1cfedaf8b3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 77 additions and 18 deletions

View File

@ -89,7 +89,7 @@ jobs:
echo "arch=${arch}" >> $GITHUB_ENV
IMAGE_FORMATS="qemu_uefi"
[ -z "${{ github.event.inputs.image_formats }}" ] || IMAGE_FORMATS="${{ github.event.inputs.image_formats }}"
[ -z "${{ inputs.image_formats }}" ] || IMAGE_FORMATS="${{ inputs.image_formats }}"
echo "IMAGE_FORMATS=${IMAGE_FORMATS}" >> $GITHUB_ENV
# Artifact root for images and torcx tarball as seen from within the container
@ -101,8 +101,8 @@ jobs:
# this with its IP address.
echo "TORCX_TESTS_PACKAGE_URL=http://localhost:12345" >> $GITHUB_ENV
if [ -n "${{ github.event.inputs.custom_sdk_version }}" ] ; then
echo "CUSTOM_SDK_VERSION=${{ github.event.inputs.custom_sdk_version }}" >> $GITHUB_ENV
if [ -n "${{ inputs.custom_sdk_version }}" ] ; then
echo "CUSTOM_SDK_VERSION=${{ inputs.custom_sdk_version }}" >> $GITHUB_ENV
fi
- name: Build packages
@ -147,7 +147,7 @@ jobs:
-cvf binpkgs.tar .
- name: Extract build logs
if: always()
if: always() && !cancelled()
shell: bash
run: |
set -euo pipefail
@ -158,7 +158,7 @@ jobs:
/build/${arch}-usr/var/tmp/portage
- name: Upload build logs
if: always()
if: always() && !cancelled()
uses: actions/upload-artifact@v3
with:
retention-days: 7

View File

@ -11,18 +11,18 @@ concurrency:
cancel-in-progress: true
jobs:
check_maintainer_membership:
run_pre_checks:
# Only run if this is a PR comment that contains a valid command
if: |
${{ github.event.issue.pull_request }} &&
( contains(github.event.comment.body, '/update-sdk') || contains(github.event.comment.body, '/build-image') )
if: ${{ github.event.issue.pull_request }} && ( contains(github.event.comment.body, '/build-image') || contains(github.event.comment.body, '/update-sdk'))
name: Check if commenter is in the Flatcar maintainers team
outputs:
maintainers: steps.step1.output.maintainers
sdk_changes: ${{ steps.step3.outputs.sdk_changes }}
runs-on:
- ubuntu-latest
steps:
- name: Fetch members of the maintainers team
id: step1
env:
requester: ${{ github.event.comment.user.login }}
shell: bash
@ -49,25 +49,30 @@ jobs:
$res
- name: Set outputs
id: step2
shell: bash
run: |
echo "sdk_changes=${{ contains(github.event.comment.body, '/update-sdk') }}" >> $GITHUB_OUTPUT
- name: Post a link to the workflow run to the PR
id: step3
uses: mshick/add-pr-comment@v2
with:
issue: ${{ github.event.issue.pull_request.number }}
message: "Build action triggered: [${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})"
update_sdk:
needs: check_maintainer_membership
if: ( needs.check_maintainer_membership.result == 'success'
&& contains(github.event.comment.body, '/update-sdk') )
needs: run_pre_checks
if: needs.run_pre_checks.result == 'success' && needs.run_pre_checks.outputs.sdk_changes == 'true'
name: "Build an updated SDK container"
# SDK build needs access to bincache ssh secret
secrets: inherit
uses: ./.github/workflows/update-sdk.yaml
build_image:
needs: [ check_maintainer_membership, update_sdk ]
if: ( needs.check_maintainer_membership.result == 'success'
&& ( contains(github.event.comment.body, '/build-image') || needs.update_sdk.result == 'success' ) )
needs: [ run_pre_checks, update_sdk ]
if: (always() && ! cancelled()) && needs.run_pre_checks.result == 'success' && needs.update_sdk.result != 'failure' && contains(github.event.comment.body, '/build-image')
name: "Build the OS image"
uses: ./.github/workflows/ci.yaml
with:

49
.github/workflows/pr-workflows.yaml vendored Normal file
View File

@ -0,0 +1,49 @@
name: "Run PR workflows"
on:
pull_request:
permissions:
pull-requests: write
concurrency:
group: ${{ github.workflow }}-pr-${{ github.head_ref || github.ref_name }}
cancel-in-progress: true
jobs:
pre_check:
name: "Check if we need to update the SDK"
runs-on: ubuntu-latest
# Setting the environment is the more important reason we need this job.
# We use this job as a gate, so we can approve the PR workflow only once. If
# we set this in the update_sdk job and in the build_image job, we would have
# to approve the workflow for every job that kicks off. Given that the jobs
# are sequenced, this is cumbersome. Use this job as a gate and make the rest
# dependent on it.
environment: development
outputs:
sdk_changes: ${{ steps.step1.outputs.sdk_changes }}
steps:
- name: Set outputs
id: step1
shell: bash
run: |
echo "sdk_changes=${{ contains(github.event.pull_request.body, '/update-sdk') }}" >> $GITHUB_OUTPUT
update_sdk:
name: "Build an updated SDK container"
needs: [ pre_check ]
if: needs.pre_check.outputs.sdk_changes == 'true'
# SDK build needs access to bincache ssh secret
secrets: inherit
uses: ./.github/workflows/update-sdk.yaml
build_image:
needs: [ update_sdk ]
# The update-sdk job may be skipped, which is fine. We only care if it tried to
# run, but failed.
if: (always() && !cancelled()) && needs.update_sdk.result != 'failure'
name: "Build the OS image"
uses: ./.github/workflows/ci.yaml
with:
custom_sdk_version: ${{ needs.update_sdk.outputs.sdk_version }}
image_formats: qemu_uefi

View File

@ -243,7 +243,7 @@ jobs:
set -e
- name: Upload detailed test logs
if: always()
if: always() && !cancelled()
uses: actions/upload-artifact@v3
with:
name: ${{ matrix.arch }}-test-logs-and-results
@ -255,7 +255,7 @@ jobs:
scripts/results-*.md
- name: Upload raw TAP files of all runs for later merging
if: always()
if: always() && !cancelled()
uses: actions/upload-artifact@v3
with:
name: ${{ matrix.arch }}-raw-tapfiles
@ -266,7 +266,7 @@ jobs:
merge_and_publish_results:
name: "Merge TAP reports and post results"
needs: tests
if: always()
if: always() && !cancelled()
runs-on:
- self-hosted
- debian

View File

@ -14,6 +14,10 @@ on:
Custom SDK container version to build. Defaults to source SDK w/ "-github-[DATE]" appended.
workflow_call:
outputs:
sdk_version:
description: "The version of the SDK container that was built"
value: ${{ jobs.update_sdk.outputs.sdk_version }}
inputs:
source_sdk_version:
type: string
@ -117,6 +121,7 @@ jobs:
target_version="${CUSTOM_SDK_VERSION}"
fi
echo "setting sdk_version=${target_version} as a github output"
echo "sdk_version=${target_version}" >> "$GITHUB_OUTPUT"
# This also updates sdk_container/.repo/manifests/version.txt with the new SDK version.