Skip to content

almalinux-compose-test-arm64 #122

almalinux-compose-test-arm64

almalinux-compose-test-arm64 #122

name: almalinux-compose-test-arm64
on:
workflow_dispatch:
inputs:
version_major:
description: 'AlmaLinux major version'
required: true
default: '9'
type: choice
options:
- 9
- 8
pungi_repository:
description: 'Add AlmaLinux pungi repositories'
type: boolean
pulp_repository:
description: 'Add AlmaLinux pulp repositories'
type: boolean
rerun_failed:
description: 'Re-run failed tests'
type: boolean
jobs:
start-runner:
timeout-minutes: 10 # normally it only takes 1-2 minutes
name: Setup and start self-hosted EC2 runner
runs-on: ubuntu-latest
permissions:
actions: write
steps:
- name: Check inputs
run: |
# Fail tasts if both pungi and pulp repositories are used
if [ "x${{ inputs.pungi_repository }}" = "xtrue" -a "x${{ inputs.pulp_repository }}" = "xtrue" ]; then
echo "[Debug] Both pungi and pulp repositories can't be used."
exit 1
fi
exit 0
- name: Setup and start runner
id: start-ec2-runner
uses: NextChapterSoftware/[email protected]
with:
github_token: ${{ secrets.GIT_HUB_TOKEN }}
aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws_region: ${{ secrets.AWS_REGION }}
ec2_ami_id: ${{ inputs.version_major == '9' && secrets.EC2_AMI_ID_AL9 || secrets.EC2_AMI_ID_AL8 }}
ec2_subnet_id: ${{ secrets.EC2_SUBNET_ID}}
ec2_security_group_id: ${{ secrets.EC2_SECURITY_GROUP_ID }}
ec2_instance_type: t4g.small # 2 vCPU and 2 GiM Memory are enought to run tests
ec2_root_disk_size_gb: "16" # override default size which is too small for actions and tests stuff
ec2_root_disk_ebs_class: "gp3" # use faster and cheeper storage instead of default 'gp2'
ec2_instance_ttl: 60 # Optional (default is 60 minutes)
ec2_spot_instance_strategy: None # Other options are: SpotOnly, BestEffort, MaxPerformance
ec2_instance_tags: > # Required for IAM role resource permission scoping
[
{"Key": "Project", "Value": "GitHub Actions Self-hosted Runners"}
]
compose-test:
name: Testing AlmaLinux ${{ inputs.version_major }}
runs-on: ${{ github.run_id }}
needs: start-runner # required to start the main job when the runner is ready
steps:
- uses: actions/checkout@v4
- name: Prepare stuff
run: |
# Name of repository to enable (PowerTools/CRB)
dnf_crb_repo='PowerTools'
if [ "${{ inputs.version_major }}" = "9" ]; then
dnf_crb_repo='CRB'
fi
if [ "x${{ inputs.pulp_repository }}" = "xtrue" ]; then
# Lowercase the name for path in pulp's URL
dnf_crb_repo="${dnf_crb_repo,,}"
fi
echo "dnf_crb_repo=${dnf_crb_repo}" >> $GITHUB_ENV
# TMT tests run directory
echo "tmt_run_dir=/var/tmp/tmt/run-001" >> $GITHUB_ENV
- name: Create AlmaLinux pungi repository
if: inputs.pungi_repository
run: |
cat <<'EOF'>/etc/yum.repos.d/almalinux-pungi.repo
[almalinux-${{ inputs.version_major }}-appstream-pungi]
baseurl = http://$arch-pungi-${{ inputs.version_major }}.almalinux.org/almalinux/${{ inputs.version_major }}/$arch/latest_result/compose/AppStream/$arch/os/
enabled = 1
name = almalinux-${{ inputs.version_major }}-appstream-pungi
[almalinux-${{ inputs.version_major }}-baseos-pungi]
baseurl = http://$arch-pungi-${{ inputs.version_major }}.almalinux.org/almalinux/${{ inputs.version_major }}/$arch/latest_result/compose/BaseOS/$arch/os/
enabled = 1
name = almalinux-${{ inputs.version_major }}-baseos-pungi
[almalinux-${{ inputs.version_major }}-${{ env.dnf_crb_repo }}-pungi]
baseurl = http://$arch-pungi-${{ inputs.version_major }}.almalinux.org/almalinux/${{ inputs.version_major }}/$arch/latest_result/compose/${{ env.dnf_crb_repo }}/$arch/os/
enabled = 1
name = almalinux-${{ inputs.version_major }}-${{ env.dnf_crb_repo }}-pungi
EOF
- name: Create AlmaLinux pulp repository
if: inputs.pulp_repository
run: |
cat <<'EOF'>/etc/yum.repos.d/almalinux-pulp.repo
[almalinux-${{ inputs.version_major }}-appstream-pulp]
baseurl = https://build.almalinux.org/pulp/content/prod/almalinux-${{ inputs.version_major }}-appstream-$arch/
enabled = 1
name = almalinux-${{ inputs.version_major }}-appstream-pulp
[almalinux-${{ inputs.version_major }}-baseos-pulp]
baseurl = https://build.almalinux.org/pulp/content/prod/almalinux-${{ inputs.version_major }}-baseos-$arch/
enabled = 1
name = almalinux-${{ inputs.version_major }}-baseos-pulp
[almalinux-${{ inputs.version_major }}-${{ env.dnf_crb_repo }}-pulp]
baseurl = https://build.almalinux.org/pulp/content/prod/almalinux-${{ inputs.version_major }}-${{ env.dnf_crb_repo }}-$arch/
enabled = 1
name = almalinux-${{ inputs.version_major }}-${{ env.dnf_crb_repo }}-pulp
EOF
# - name: Update the system
# run: |
# sudo dnf -y clean all
# sudo dnf -y update
- name: Prepare test infrastructure
run: |
sudo dnf -y install epel-release wget
enable_repo=${{ env.dnf_crb_repo }}
sudo dnf install -y --enablerepo=${enable_repo,,} tmt
# - name: Run tests
# id: run-tests
# run: |
# # If re-run, do not fail the step even some tests fail
# exit_with=false
# [ "${{ inputs.rerun_failed }}" = "true" ] && exit_with=true
# # Use envirounment variable to idicate tests state
# echo "run_tests=fail" >> $GITHUB_ENV
# sudo sh -c 'export pungi_repository=${{ inputs.pungi_repository }}; export pulp_repository=${{ inputs.pulp_repository }}; tmt -vvv -c distro=centos-stream-${{ inputs.version_major }} run --all provision --how=local' \
# || $exit_with
# echo "run_tests=success" >> $GITHUB_ENV
# - name: Print tests results
# # if: success() || failure()
# run: |
# #[Debug]
# sudo cat ${{ env.tmt_run_dir }}/plans/legacy/execute/results.yaml ${{ env.tmt_run_dir }}/plans/ng/execute/results.yaml
# sudo /bin/cp -av ${{ env.tmt_run_dir }}/plans/legacy/execute/results.yaml ${{github.action_path}}/legacy.results.yaml
# sudo /bin/cp -av ${{ env.tmt_run_dir }}/plans/ng/execute/results.yaml ${{github.action_path}}/ng.results.yaml
# - name: Print tests log
# # if: success() || failure()
# run: |
# #[Debug]
# sudo cat ${{ env.tmt_run_dir }}/log.txt
# sudo /bin/cp -av ${{ env.tmt_run_dir }}/log.txt ${{github.action_path}}/log.txt
# - name: Collect tests output
# # if: success() || failure()
# run: |
# cd ${{ env.tmt_run_dir }}/
# tar cf ${{github.action_path}}/output.tar $( find . -name output.txt ) || true
# - uses: actions/upload-artifact@v4
# # if: success() || failure()
# with:
# name: Tests log
# path: ${{github.action_path}}/log.txt
# - uses: actions/upload-artifact@v4
# # if: success() || failure()
# with:
# name: Tests results
# path: ${{github.action_path}}/*.results.yaml
# - uses: actions/upload-artifact@v4
# # if: success() || failure()
# with:
# name: Tests output
# path: ${{github.action_path}}/output.tar
- name: Create .yaml
run: |
mkdir -p ${{ env.tmt_run_dir }}/plans/legacy/execute/ ${{ env.tmt_run_dir }}/plans/ng/execute/
cat <<'EOF'>${{ env.tmt_run_dir }}/plans/legacy/execute/results.yaml
- name: /tests/legacy/p_osbuild
serialnumber: 73
fmf_id:
url: https://github.com/AlmaLinux/compose-tests.git
ref: almalinux
name: /tests/legacy/p_osbuild
result: pass
note:
ids:
id:
extra-nitrate:
extra-task:
log:
- data/guest/default-0/tests/legacy/p_osbuild-73/output.txt
guest:
name: default-0
role:
__class__:
module: tmt.result
name: ResultGuestData
starttime: '2024-06-12T13:02:56.919857+00:00'
endtime: '2024-06-12T13:10:59.855935+00:00'
duration: 00:08:02
__class__:
module: tmt.result
name: Result
- name: /tests/legacy/p_passwd
serialnumber: 74
fmf_id:
url: https://github.com/AlmaLinux/compose-tests.git
ref: almalinux
name: /tests/legacy/p_passwd
result: fail
note:
ids:
id:
extra-nitrate:
extra-task:
log:
- data/guest/default-0/tests/legacy/p_passwd-74/output.txt
guest:
name: default-0
role:
__class__:
module: tmt.result
name: ResultGuestData
starttime: '2024-06-12T13:10:59.928800+00:00'
endtime: '2024-06-12T13:11:12.358420+00:00'
duration: 00:00:12
__class__:
module: tmt.result
name: Result
EOF
cat <<'EOF'>${{ env.tmt_run_dir }}/plans/ng/execute/results.yaml
- name: /tests/acl
serialnumber: 73
fmf_id:
url: https://github.com/AlmaLinux/compose-tests.git
ref: almalinux
name: /tests/legacy/p_osbuild
result: fail
note:
ids:
id:
extra-nitrate:
extra-task:
log:
- data/guest/default-0/tests/legacy/p_osbuild-73/output.txt
guest:
name: default-0
role:
__class__:
module: tmt.result
name: ResultGuestData
starttime: '2024-06-12T13:02:56.919857+00:00'
endtime: '2024-06-12T13:10:59.855935+00:00'
duration: 00:08:02
__class__:
module: tmt.result
name: Result
- name: /tests/curl
serialnumber: 74
fmf_id:
url: https://github.com/AlmaLinux/compose-tests.git
ref: almalinux
name: /tests/legacy/p_passwd
result: pass
note:
ids:
id:
extra-nitrate:
extra-task:
log:
- data/guest/default-0/tests/legacy/p_passwd-74/output.txt
guest:
name: default-0
role:
__class__:
module: tmt.result
name: ResultGuestData
starttime: '2024-06-12T13:10:59.928800+00:00'
endtime: '2024-06-12T13:11:12.358420+00:00'
duration: 00:00:12
__class__:
module: tmt.result
name: Result
EOF
- name: Run tests
id: run-tests
run: |
# If re-run, do not fail the step even some tests fail
exit_with=false
[ "${{ inputs.rerun_failed }}" = "true" ] && exit_with=true
# Use envirounment variable to idicate tests state
echo "run_tests=fail" >> $GITHUB_ENV
echo "run_tests=fail" >> "$GITHUB_OUTPUT"
echo "${{ env.run_tests }}"
false \
|| $exit_with
echo "run_tests=success" >> $GITHUB_ENV
echo "run_tests=success" >> "$GITHUB_OUTPUT"
echo "${{ env.run_tests }}"
- name: Get list of failed tests
if: success() || failure()
# if: ${{ env.run_tests }} == 'fail' && ( success() || failure() )
id: get-failed
run: |
# Install 'yq'
wget https://github.com/mikefarah/yq/releases/latest/download/yq_linux_arm64 -O /usr/bin/yq
chmod +x /usr/bin/yq
# Get failed tests list
yq --no-doc '.[] | select(.result == "fail") | .name' ${{ env.tmt_run_dir }}/plans/legacy/execute/results.yaml ${{ env.tmt_run_dir }}/plans/ng/execute/results.yaml > ${{ env.tmt_run_dir }}/tests_failed.txt
cat ${{ env.tmt_run_dir }}/tests_failed.txt
- name: Re-run failed tests or prepare results summary
if: success() || failure()
# if: ${{ env.run_tests }} == 'fail' && ( success() || failure() )
run: |
rerun_results=
while IFS= read -r test_failed ; do
# Include failed test name into resiults summary
test_result="${test_failed}"
if [ "${{ inputs.rerun_failed }}" = "true" ]; then
#[Debug]
sudo sh -c "export pungi_repository=${{ inputs.pungi_repository }}; export pulp_repository=${{ inputs.pulp_repository }}; tmt -vvv -c distro=centos-stream-${{ inputs.version_major }} run --all provision --how=local test --name $test_failed" && \
test_result="${test_failed} [re-run ✅]" || \
test_result="${test_failed} [re-run ❌]"
fi
# Format re-run results in list format: 'item1', 'item2', ...
[ "x${rerun_results}" = "x" ] && rerun_results="'${test_result}'" || rerun_results="${rerun_results}, '${test_result}'"
done < ${{ env.tmt_run_dir }}/tests_failed.txt
echo "rerun_results=${rerun_results}" >> $GITHUB_ENV
- name: Print failed tests
if: success() || failure() && env.rerun_results != ''
uses: actions/github-script@v7
with:
result-encoding: string
script: |
core.summary
.addHeading('Failed tests:', '4')
.addList([${{ env.rerun_results }}], true)
.write()