This repository has been archived by the owner on May 28, 2024. It is now read-only.
test: add bib raw image test #155
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--- | |
name: bib image Test | |
on: | |
issue_comment: | |
types: | |
- created | |
jobs: | |
pr-info: | |
if: ${{ github.event.issue.pull_request && | |
(endsWith(github.event.comment.body, '/test-rhel94') || | |
endsWith(github.event.comment.body, '/test-rhel94-bib-image') || | |
endsWith(github.event.comment.body, '/test-cs9') || | |
endsWith(github.event.comment.body, '/test-cs9-bib-image') || | |
endsWith(github.event.comment.body, '/test-cs9-dev') || | |
endsWith(github.event.comment.body, '/test-cs9-dev-bib-image') || | |
endsWith(github.event.comment.body, '/test-cs9-dev-bib-cross-build')) }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: Query author repository permissions | |
uses: octokit/[email protected] | |
id: user_permission | |
with: | |
route: GET /repos/${{ github.repository }}/collaborators/${{ github.event.sender.login }}/permission | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
# restrict running of tests to users with admin or write permission for the repository | |
# see https://docs.github.com/en/free-pro-team@latest/rest/reference/repos#get-repository-permissions-for-a-user | |
- name: Check if user does have correct permissions | |
if: contains('admin write', fromJson(steps.user_permission.outputs.data).permission) | |
id: check_user_perm | |
run: | | |
echo "User '${{ github.event.sender.login }}' has permission '${{ fromJson(steps.user_permission.outputs.data).permission }}' allowed values: 'admin', 'write'" | |
echo "allowed_user=true" >> $GITHUB_OUTPUT | |
- name: Get information for pull request | |
uses: octokit/[email protected] | |
id: pr-api | |
with: | |
route: GET /repos/${{ github.repository }}/pulls/${{ github.event.issue.number }} | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
outputs: | |
allowed_user: ${{ steps.check_user_perm.outputs.allowed_user }} | |
sha: ${{ fromJson(steps.pr-api.outputs.data).head.sha }} | |
ref: ${{ fromJson(steps.pr-api.outputs.data).head.ref }} | |
repo_url: ${{ fromJson(steps.pr-api.outputs.data).head.repo.html_url }} | |
rhel94-bib-image: | |
needs: pr-info | |
if: ${{ needs.pr-info.outputs.allowed_user == 'true' && github.event.issue.pull_request && | |
(endsWith(github.event.comment.body, '/test-rhel94') || | |
endsWith(github.event.comment.body, '/test-rhel94-bib-image')) }} | |
continue-on-error: true | |
strategy: | |
matrix: | |
arch: [x86_64, aarch64] | |
image_type: [ami, qcow2, vmdk] | |
exclude: | |
- arch: aarch64 | |
image_type: vmdk | |
include: | |
- image_type: ami | |
platform: aws | |
- image_type: qcow2 | |
platform: libvirt | |
- image_type: vmdk | |
platform: vsphere | |
runs-on: ubuntu-latest | |
steps: | |
- name: Clone repository | |
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 | |
with: | |
ref: ${{ needs.pr-info.outputs.sha }} | |
fetch-depth: 0 | |
- name: Run the tests | |
uses: sclorg/testing-farm-as-github-action@v1 | |
with: | |
compose: RHEL-9.4.0-Nightly | |
api_key: ${{ secrets.TF_API_KEY }} | |
git_url: ${{ needs.pr-info.outputs.repo_url }} | |
git_ref: ${{ needs.pr-info.outputs.ref }} | |
arch: ${{ matrix.arch }} | |
tmt_context: "arch=${{ matrix.arch }}" | |
update_pull_request_status: true | |
pull_request_status_name: "bootc-rhel94-${{ matrix.arch }}-bib-${{ matrix.image_type }}" | |
tmt_plan_regex: "${{ matrix.image_type }}" | |
tf_scope: private | |
secrets: "QUAY_USERNAME=${{ secrets.QUAY_USERNAME }};QUAY_PASSWORD=${{ secrets.QUAY_PASSWORD }};QUAY_SECRET=${{ secrets.QUAY_SECRET }};RHEL_REGISTRY_URL=${{ secrets.RHEL_REGISTRY_URL }};DOWNLOAD_NODE=${{ secrets.DOWNLOAD_NODE }};AWS_ACCESS_KEY_ID=${{ secrets.AWS_ACCESS_KEY_ID }};AWS_SECRET_ACCESS_KEY=${{ secrets.AWS_SECRET_ACCESS_KEY }};GOVC_URL=${{ secrets.GOVC_URL }};GOVC_USERNAME=${{ secrets.GOVC_USERNAME }};GOVC_PASSWORD=${{ secrets.GOVC_PASSWORD }};RHC_AK=${{ secrets.RHC_AK }};RHC_ORGID=${{ secrets.RHC_ORGID }}" | |
variables: "TEST_OS=rhel-9-4;PLATFORM=${{ matrix.platform }};ARCH=${{ matrix.arch }};IMAGE_TYPE=${{ matrix.image_type }};AWS_REGION=${{ secrets.AWS_REGION }};GOVC_INSECURE=1" | |
cs9-bib-image: | |
needs: pr-info | |
if: ${{ needs.pr-info.outputs.allowed_user == 'true' && github.event.issue.pull_request && | |
(endsWith(github.event.comment.body, '/test-cs9') || | |
endsWith(github.event.comment.body, '/test-cs9-bib-image')) }} | |
continue-on-error: true | |
strategy: | |
matrix: | |
arch: [x86_64, aarch64] | |
image_type: [ami, qcow2, vmdk] | |
exclude: | |
- arch: aarch64 | |
image_type: vmdk | |
include: | |
- image_type: ami | |
platform: aws | |
- image_type: qcow2 | |
platform: libvirt | |
- image_type: vmdk | |
platform: vsphere | |
runs-on: ubuntu-latest | |
steps: | |
- name: Clone repository | |
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 | |
with: | |
ref: ${{ needs.pr-info.outputs.sha }} | |
fetch-depth: 0 | |
- name: Run the tests | |
uses: sclorg/testing-farm-as-github-action@v1 | |
with: | |
compose: CentOS-Stream-9 | |
api_key: ${{ secrets.TF_API_KEY }} | |
git_url: ${{ needs.pr-info.outputs.repo_url }} | |
git_ref: ${{ needs.pr-info.outputs.ref }} | |
arch: ${{ matrix.arch }} | |
tmt_context: "arch=${{ matrix.arch }}" | |
update_pull_request_status: true | |
pull_request_status_name: "bootc-cs9-${{ matrix.arch }}-bib-${{ matrix.image_type }}" | |
tmt_plan_regex: "${{ matrix.image_type }}" | |
tf_scope: private | |
secrets: "QUAY_USERNAME=${{ secrets.QUAY_USERNAME }};QUAY_PASSWORD=${{ secrets.QUAY_PASSWORD }};QUAY_SECRET=${{ secrets.QUAY_SECRET }};AWS_ACCESS_KEY_ID=${{ secrets.AWS_ACCESS_KEY_ID }};AWS_SECRET_ACCESS_KEY=${{ secrets.AWS_SECRET_ACCESS_KEY }};GOVC_URL=${{ secrets.GOVC_URL }};GOVC_USERNAME=${{ secrets.GOVC_USERNAME }};GOVC_PASSWORD=${{ secrets.GOVC_PASSWORD }}" | |
variables: "TEST_OS=centos-stream-9;PLATFORM=${{ matrix.platform }};ARCH=${{ matrix.arch }};IMAGE_TYPE=${{ matrix.image_type }};AWS_REGION=${{ secrets.AWS_REGION }};GOVC_INSECURE=1" | |
cs9-dev-bib-image: | |
needs: pr-info | |
if: ${{ needs.pr-info.outputs.allowed_user == 'true' && github.event.issue.pull_request && | |
(endsWith(github.event.comment.body, '/test-cs9-dev') || | |
endsWith(github.event.comment.body, '/test-cs9-dev-bib-image')) }} | |
continue-on-error: true | |
strategy: | |
matrix: | |
arch: [x86_64, aarch64] | |
image_type: [ami, qcow2, vmdk] | |
build_arch: [x86_64, aarch64] | |
exclude: | |
- image_type: vmdk | |
arch: aarch64 | |
- image_type: vmdk | |
build_arch: aarch64 | |
- image_type: qcow2 | |
arch: x86_64 | |
build_arch: aarch64 | |
- image_type: qcow2 | |
arch: aarch64 | |
build_arch: x86_64 | |
include: | |
- image_type: ami | |
platform: aws | |
- image_type: qcow2 | |
platform: libvirt | |
- image_type: vmdk | |
platform: vsphere | |
runs-on: ubuntu-latest | |
steps: | |
- name: Clone repository | |
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 | |
with: | |
ref: ${{ needs.pr-info.outputs.sha }} | |
fetch-depth: 0 | |
- name: Run the tests | |
uses: sclorg/testing-farm-as-github-action@v1 | |
with: | |
compose: Fedora-40 | |
api_key: ${{ secrets.TF_API_KEY }} | |
git_url: ${{ needs.pr-info.outputs.repo_url }} | |
git_ref: ${{ needs.pr-info.outputs.ref }} | |
arch: ${{ matrix.build_arch }} | |
tmt_context: "arch=${{ matrix.arch }}" | |
update_pull_request_status: true | |
pull_request_status_name: "bootc-cs9-dev-${{ matrix.arch }}-bib-${{ matrix.image_type }}-on-${{ matrix.build_arch }}" | |
tmt_plan_regex: "${{ matrix.image_type }}" | |
tf_scope: private | |
secrets: "QUAY_USERNAME=${{ secrets.QUAY_USERNAME }};QUAY_PASSWORD=${{ secrets.QUAY_PASSWORD }};QUAY_SECRET=${{ secrets.QUAY_SECRET }};AWS_ACCESS_KEY_ID=${{ secrets.AWS_ACCESS_KEY_ID }};AWS_SECRET_ACCESS_KEY=${{ secrets.AWS_SECRET_ACCESS_KEY }};GOVC_URL=${{ secrets.GOVC_URL }};GOVC_USERNAME=${{ secrets.GOVC_USERNAME }};GOVC_PASSWORD=${{ secrets.GOVC_PASSWORD }}" | |
variables: "TEST_OS=centos-stream-9;PLATFORM=${{ matrix.platform }};ARCH=${{ matrix.arch }};IMAGE_NAME=centos-bootc-dev;IMAGE_TYPE=${{ matrix.image_type }};AWS_REGION=${{ secrets.AWS_REGION }};GOVC_INSECURE=1" |