1
0
Fork 0
mirror of https://github.com/JasonN3/build-container-installer.git synced 2025-12-25 10:57:55 +01:00

use bot for tests

This commit is contained in:
Jason N. 2024-03-18 11:08:48 -04:00
parent a18843e281
commit 3cfe2264e8
2 changed files with 200 additions and 14 deletions

View file

@ -3,10 +3,10 @@ on: issue_comment
jobs: jobs:
pr_commented: pr_commented:
name: Run Tests for PR name: Check Permissions
if: > if: >
github.event.issue.pull_request && github.event.issue.pull_request &&
contains(github.event.issue.bodyText, '/run tests') contains(github.event.comment.body, '/run tests')
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Check association - name: Check association
@ -14,9 +14,21 @@ jobs:
allowed=("OWNER" "COLLABORATOR") allowed=("OWNER" "COLLABORATOR")
value="\<${{ github.event.issue.author_association }}\>" value="\<${{ github.event.issue.author_association }}\>"
if [[ ${array[@]} =~ $value ]] if [[ ${allowed[@]} =~ $value ]]
then then
exit 0 exit 0
else else
exit 1 exit 1
fi fi
run-tests:
name: Run Tests
permissions:
contents: read
packages: write
statuses: write
needs:
- pr_commented
uses: ./.github/workflows/build-and-test.yml
with:
pr: ${{ github.event.issue.number }}

View file

@ -6,11 +6,14 @@ on:
- 'main' - 'main'
tags: tags:
- 'v*' - 'v*'
workflow_run: pull_request:
workflows: [Run Tests on PR]
types: workflow_call:
- completed inputs:
pr:
required: true
type: string
concurrency: concurrency:
@ -33,21 +36,54 @@ jobs:
build-container: build-container:
if: > if: >
github.event_name == 'push' || github.event_name == 'push' ||
( github.event.workflow_run.event == 'pull_request' && github.event_name == 'issue_comment' ||
github.event.workflow_run.conclusion == 'success' ) ( github.event_name == 'pull_request' &&
contains(github.event.pull_request.labels.*.name, 'auto-test') )
name: Build Container Image name: Build Container Image
env:
JOB_NAME: Build Container Image
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions: permissions:
contents: read contents: read
packages: write packages: write
statuses: write
steps: steps:
- name: Checkout repo - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
fetch-depth: 0 fetch-depth: 0
fetch-tags: 'true' fetch-tags: 'true'
- name: Switch branch
if: inputs.pr
env:
GITHUB_USER: ${{ github.actor }}
GITHUB_TOKEN: ${{ github.token }}
run: |
sudo apt-get update
sudo apt-get install -y hub
hub pr checkout ${{ inputs.pr }}
echo "sha=$(git rev-parse HEAD)" >> $GITHUB_ENV
- name: Get Current Job Log URL
if: inputs.pr && always()
uses: Tiryoh/gha-jobid-action@v1
id: jobs
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
job_name: "Run Tests / ${{ env.JOB_NAME }}"
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
- name: Docker meta - name: Docker meta
id: meta id: meta
uses: docker/metadata-action@v5 uses: docker/metadata-action@v5
@ -75,15 +111,28 @@ jobs:
tags: ${{ steps.build-image.outputs.tags }} tags: ${{ steps.build-image.outputs.tags }}
username: ${{ github.actor }} username: ${{ github.actor }}
password: ${{ github.token }} password: ${{ github.token }}
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
build-and-push-iso: build-and-push-iso:
name: Build ISO name: Build ISO
env:
JOB_NAME: Build ISO
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: needs:
- build-container - build-container
permissions: permissions:
contents: read contents: read
packages: write packages: write
statuses: write
continue-on-error: false continue-on-error: false
strategy: strategy:
fail-fast: false fail-fast: false
@ -97,8 +146,39 @@ jobs:
iso_name-39: ${{ steps.save_output.outputs.iso_name-39 }} iso_name-39: ${{ steps.save_output.outputs.iso_name-39 }}
iso_name-40: ${{ steps.save_output.outputs.iso_name-40 }} iso_name-40: ${{ steps.save_output.outputs.iso_name-40 }}
steps: steps:
- name: Checkout repo - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
with:
submodules: recursive
- name: Switch branch
if: inputs.pr
env:
GITHUB_USER: ${{ github.actor }}
GITHUB_TOKEN: ${{ github.token }}
run: |
sudo apt-get update
sudo apt-get install -y hub
hub pr checkout ${{ inputs.pr }}
echo "sha=$(git rev-parse HEAD)" >> $GITHUB_ENV
- name: Get Current Job Log URL
if: inputs.pr && always()
uses: Tiryoh/gha-jobid-action@v1
id: jobs
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
job_name: "Run Tests / ${{ env.JOB_NAME }}"
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
- name: Lowercase Registry - name: Lowercase Registry
id: registry_case id: registry_case
@ -148,13 +228,26 @@ jobs:
compression-level: 0 compression-level: 0
overwrite: true overwrite: true
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
test-iso: test-iso:
name: Test ISO name: Test ISO
env:
JOB_NAME: Test ISO
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: needs:
- build-and-push-iso - build-and-push-iso
permissions: permissions:
contents: read contents: read
statuses: write
continue-on-error: false continue-on-error: false
strategy: strategy:
fail-fast: false fail-fast: false
@ -164,11 +257,40 @@ jobs:
- 39 - 39
- 40 - 40
steps: steps:
- name: Checkout repo - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
- name: Switch branch
if: inputs.pr
env:
GITHUB_USER: ${{ github.actor }}
GITHUB_TOKEN: ${{ github.token }}
run: |
sudo apt-get update
sudo apt-get install -y hub
hub pr checkout ${{ inputs.pr }}
echo "sha=$(git rev-parse HEAD)" >> $GITHUB_ENV
- name: Get Current Job Log URL
if: inputs.pr && always()
uses: Tiryoh/gha-jobid-action@v1
id: jobs
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
job_name: "Run Tests / ${{ env.JOB_NAME }}"
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
- name: Install test tools - name: Install test tools
run: | run: |
sudo apt-get update sudo apt-get update
@ -199,13 +321,26 @@ jobs:
SECURE_BOOT_KEY_URL=${{ env.SECURE_BOOT_KEY_URL }} \ SECURE_BOOT_KEY_URL=${{ env.SECURE_BOOT_KEY_URL }} \
ENROLLMENT_PASSWORD=${{ env.ENROLLMENT_PASSWORD }} ENROLLMENT_PASSWORD=${{ env.ENROLLMENT_PASSWORD }}
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
test-deployment: test-deployment:
name: Test deployment name: Test deployment
env:
JOB_NAME: Test deployment
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: needs:
- build-and-push-iso - build-and-push-iso
permissions: permissions:
contents: read contents: read
statuses: write
continue-on-error: false continue-on-error: false
strategy: strategy:
fail-fast: false fail-fast: false
@ -215,11 +350,40 @@ jobs:
- 39 - 39
- 40 - 40
steps: steps:
- name: Checkout repo - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
submodules: recursive submodules: recursive
- name: Switch branch
if: inputs.pr
env:
GITHUB_USER: ${{ github.actor }}
GITHUB_TOKEN: ${{ github.token }}
run: |
sudo apt-get update
sudo apt-get install -y hub
hub pr checkout ${{ inputs.pr }}
echo "sha=$(git rev-parse HEAD)" >> $GITHUB_ENV
- name: Get Current Job Log URL
if: inputs.pr && always()
uses: Tiryoh/gha-jobid-action@v1
id: jobs
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
job_name: "Run Tests / ${{ env.JOB_NAME }}"
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}
- name: Install test tools - name: Install test tools
run: | run: |
sudo apt-get update sudo apt-get update
@ -315,3 +479,13 @@ jobs:
SECURE_BOOT_KEY_URL=${{ env.SECURE_BOOT_KEY_URL }} \ SECURE_BOOT_KEY_URL=${{ env.SECURE_BOOT_KEY_URL }} \
ENROLLMENT_PASSWORD=${{ env.ENROLLMENT_PASSWORD }} ENROLLMENT_PASSWORD=${{ env.ENROLLMENT_PASSWORD }}
kill $QEMU_PID kill $QEMU_PID
- name: Set status
if: inputs.pr && always()
uses: myrotvorets/set-commit-status-action@v2.0.1
with:
token: ${{ secrets.GITHUB_TOKEN }}
status: ${{ job.status }}
context: ${{ env.JOB_NAME }}
sha: ${{ env.sha }}
targetUrl: ${{ steps.jobs.outputs.html_url }}