almalinux-compose-test-arm64 #41
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: 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 | |
jobs: | |
# start-runner: | |
# name: Setup and start self-hosted EC2 runner | |
# 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: ${{ secrets.AWS_REGION }} | |
# - name: Start EC2 runner | |
# id: start-ec2-runner | |
# uses: bitovi/[email protected] | |
# with: | |
# aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
# aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
# aws_default_region: ${{ secrets.AWS_REGION }} | |
# aws_ec2_additional_tags: '{\"github-actions\":\"ssh-access\"}' | |
# aws_ec2_instance_type: t4g.small | |
# aws_ec2_ami_id: ${{ inputs.version_major == '9' && 'ami-0ce12a8fbc3cc15a5' || 'ami-01e3e647c7acbc64b' }} | |
# # aws_ec2_security_group_name: sg-07e22182e33675edc | |
# # aws_vpc_subnet_id: subnet-64063c29 | |
# aws_vpc_create: false | |
# aws_ec2_instance_public_ip: true | |
# # ec2_instance_public_ip: false | |
# # ec2_additional_tags: '{\"key3\":\"value3\",\"key4\":\"value4\"}' | |
# repo_url: https://github.com/yuravk/compose-tests | |
# repo_access_token: AAL376ZHV6H5WYSS7NLLWFTGMBSKY | |
# # stack_destroy: false | |
# # tf_state_bucket_destroy: true | |
start-runner: | |
timeout-minutes: 5 # normally it only takes 1-2 minutes | |
name: Setup and start self-hosted EC2 runner | |
runs-on: ubuntu-latest | |
permissions: | |
actions: write | |
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: ${{ secrets.AWS_REGION }} | |
- name: Start EC2 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_instance_type: t4g.small | |
ec2_ami_id: ${{ inputs.version_major == '9' && 'ami-0ce12a8fbc3cc15a5' || 'ami-01e3e647c7acbc64b' }} | |
ec2_subnet_id: subnet-64063c29 | |
ec2_security_group_id: sg-07e22182e33675edc | |
ec2_instance_ttl: 60 # Optional (default is 60 minutes) | |
ec2_spot_instance_strategy: None # Other options are: SpotOnly, BestEffort, MaxPerformance | |
# start-runner: | |
# name: Start self-hosted EC2 runner | |
# runs-on: ubuntu-latest | |
# outputs: | |
# label: ${{ steps.start-ec2-runner.outputs.label }} | |
# ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} | |
# 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: ${{ secrets.AWS_REGION }} | |
# - name: Start EC2 runner | |
# id: start-ec2-runner | |
# uses: machulav/ec2-github-runner@v2 | |
# with: | |
# mode: start | |
# github-token: ${{ secrets.GIT_HUB_TOKEN }} | |
# ec2-image-id: ${{ inputs.version_major == '9' && 'ami-0f76592d493cc4dbb' || 'ami-0b68c0cf818f25ecf' }} | |
# ec2-instance-type: t4g.small | |
# subnet-id: subnet-64063c29 | |
# security-group-id: sg-07e22182e33675edc | |
compose-test: | |
name: Testing AlmaLinux ${{ inputs.version_major }} | |
# runs-on: almalinux${{ inputs.version_major }}-arm64-aws-ec2-us-east-1 | |
# runs-on: ${{ needs.start-runner.outputs.label }} # run the job on the newly created runner | |
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 | |
# # Clean up tmt run results and repos | |
# sudo rm -rf /var/tmp/tmt/run-* \ | |
# /etc/yum.repos.d/almalinux-pungi.repo \ | |
# /etc/yum.repos.d/almalinux-pulp.repo | |
# # Verify that CPU supports hardware virtualization | |
# echo -n "Number of vmx|svm CPUs: " && grep -E -c '(vmx|svm)' /proc/cpuinfo | |
# # Use proper Vagrantfile and set ENV variable of config.vm.box | |
# cp -av ci/Vagrant/Vagrantfile ./ | |
# echo vm_box='almalinux/${{ inputs.version_major }}' > .env | |
# - name: Install KVM Packages and Start libvirt | |
# run: | | |
# sudo apt-get -y update | |
# sudo apt-get -y install qemu-kvm libvirt-daemon-system libvirt-clients bridge-utils | |
# sudo systemctl enable --now libvirtd | |
# sudo adduser "$(id -un)" libvirt | |
# sudo adduser "$(id -un)" kvm | |
# - name: Enable KVM group perms | |
# run: | | |
# echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules | |
# sudo udevadm control --reload-rules | |
# sudo udevadm trigger --name-match=kvm | |
# - name: Tune libvirt | |
# run: virsh list --all | |
# - name: Install Vagrant | |
# run: | | |
# sudo apt-get -y install vagrant | |
# sudo vagrant --version | |
# sudo vagrant plugin install vagrant-reload | |
# sudo vagrant plugin install vagrant-env | |
# - name: Install the Vagrant libvirt Plugin | |
# run: | | |
# sudo cp /etc/apt/sources.list /etc/apt/sources.list."$(date +"%F")" | |
# sudo sed -i -e '/^# deb-src.*universe$/s/# //g' /etc/apt/sources.list | |
# sudo apt-get -y update | |
# sudo apt-get -y install nfs-kernel-server | |
# sudo systemctl enable --now nfs-server | |
# sudo apt-get -y build-dep vagrant ruby-libvirt | |
# sudo apt-get -y install ebtables dnsmasq-base | |
# sudo apt-get -y install libxslt-dev libxml2-dev libvirt-dev zlib1g-dev ruby-dev | |
# sudo vagrant plugin install vagrant-libvirt | |
# sudo vagrant plugin install vagrant-scp | |
- 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: Run vagrant up | |
# run: sudo vagrant up almalinux | |
- name: Update the system | |
run: | | |
sudo dnf -y clean all | |
sudo dnf -y update | |
- name: Prepare test infrastructure (dnf install epel-release) | |
run: sudo dnf -y install epel-release | |
- name: Prepare test infrastructure (dnf install tmt) | |
run: | | |
enable_repo=${{ env.dnf_crb_repo }} | |
sudo dnf install -y --enablerepo=${enable_repo,,} tmt | |
# - name: Get compose-tests | |
# run: sudo vagrant ssh almalinux -c 'sudo cp -a /vagrant /compose-tests' | |
- name: Run tests | |
run: 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 "/tests/legacy/p_cpio"' | |
- name: Print tests results | |
if: success() || failure() | |
run: | | |
sudo cat /var/tmp/tmt/run-001/plans/legacy/execute/results.yaml /var/tmp/tmt/run-001/plans/ng/execute/results.yaml | |
sudo /bin/cp -av /var/tmp/tmt/run-001/plans/legacy/execute/results.yaml ${{github.action_path}}/legacy.results.yaml | |
sudo /bin/cp -av /var/tmp/tmt/run-001/plans/ng/execute/results.yaml ${{github.action_path}}/ng.results.yaml | |
- name: Print tests log | |
if: success() || failure() | |
run: | | |
sudo cat /var/tmp/tmt/run-001/log.txt | |
sudo /bin/cp -av /var/tmp/tmt/run-001/log.txt ${{github.action_path}}/log.txt | |
- name: Collect tests output | |
if: success() || failure() | |
run: | | |
cd /var/tmp/tmt/run-001/ | |
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: Clean up tmt run results and repos | |
# if: success() || failure() | |
# run: | | |
# sudo rm -rf /var/tmp/tmt/run-* \ | |
# ${{github.action_path}}/output.tar \ | |
# ${{github.action_path}}/*.results.yaml \ | |
# ${{github.action_path}}/log.txt \ | |
# /etc/yum.repos.d/almalinux-pungi.repo \ | |
# /etc/yum.repos.d/almalinux-pulp.repo | |
# stop-runner: | |
# name: Stop self-hosted EC2 runner | |
# needs: | |
# - start-runner # required to get output from the start-runner job | |
# - compose-test # required to wait when the main job is done | |
# runs-on: ubuntu-latest | |
# if: ${{ always() }} # required to stop the runner even if the error happened in the previous jobs | |
# 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: ${{ secrets.AWS_REGION }} | |
# - name: Stop EC2 runner | |
# uses: machulav/ec2-github-runner@v2 | |
# with: | |
# mode: stop | |
# github-token: ${{ secrets.GIT_HUB_TOKEN }} | |
# label: ${{ needs.start-runner.outputs.label }} | |
# ec2-instance-id: ${{ needs.start-runner.outputs.ec2-instance-id }} |