Skip to content

feat: bump rancher to v2.14.2-alpha6 and rke2 to v1.35.5+rke2r1 (#1278) #2732

feat: bump rancher to v2.14.2-alpha6 and rke2 to v1.35.5+rke2r1 (#1278)

feat: bump rancher to v2.14.2-alpha6 and rke2 to v1.35.5+rke2r1 (#1278) #2732

name: Vagrant install
on:
pull_request:
types: [opened, reopened, synchronize]
push:
branches:
- master
- 'v**'
schedule:
- cron: '30 19 * * *'
env:
LIBVIRT_DEFAULT_URI: "qemu:///system"
KEEP_ENV_WHEN_FAILURE: ${{ secrets.KEEP_CI_FAILURE }}
jobs:
main:
name: Build and deploy
runs-on:
- self-hosted
- Linux
- kvm
- vagrant
- equinix
steps:
- uses: actions/checkout@34e114876b0b11c390a56381ad16ebd13914f8d5 # v4
- name: Build Harvester artifacts
env:
DISABLE_BUILD_NET_INSTALL_ISO: "true"
run: |
make
- name: Clone and checkout ipxe-examples
id: ipxe
run: |
cd $HOME
if [ ! -d ipxe-examples ]; then
git clone https://github.com/harvester/ipxe-examples.git
fi
cd ipxe-examples
git reset && git checkout .
git clean -fd
git pull
echo "VAGRANT_HOME=$HOME/ipxe-examples/vagrant-pxe-harvester" >> $GITHUB_OUTPUT
- name: Clean up previous vagrant deployment
working-directory: ${{ steps.ipxe.outputs.VAGRANT_HOME }}
run: |
vagrant destroy -f
- name: Generate SSH keys
run: |
ssh-keygen -t rsa -q -N "" -f ./ci/terraform/tmp-ssh-key
- name: Set SSH key in ipxe-examples settings
run: |
export PUB_KEY=$(cat ./ci/terraform/tmp-ssh-key.pub)
yq e -i ".harvester_config.ssh_authorized_keys += [ strenv(PUB_KEY) ]" ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
- name: Set artifacts in ipxe-examples settings
run: |
yq e -i ".harvester_iso_url = \"file://${{ github.workspace }}/dist/artifacts/harvester-master-amd64.iso\"" ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
yq e -i ".harvester_kernel_url = \"file://${{ github.workspace }}/dist/artifacts/harvester-master-vmlinuz-amd64\"" ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
yq e -i ".harvester_ramdisk_url = \"file://${{ github.workspace }}/dist/artifacts/harvester-master-initrd-amd64\"" ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
yq e -i ".harvester_rootfs_url = \"file://${{ github.workspace }}/dist/artifacts/harvester-master-rootfs-amd64.squashfs\"" ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
- name: Setup cluster
working-directory: ${{ steps.ipxe.outputs.VAGRANT_HOME }}
run: |
./setup_harvester.sh
- name: Clean the previous temp files
working-directory: ./ci/terraform
run: |
./cleanup_test_files.sh
- name: Testing existing files
working-directory: ./ci/terraform
run: |
./check_files.sh ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
- name: Testing services status
working-directory: ./ci/terraform
run: |
./check_services_status.sh ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
- name: Testing basic operations with terraform
working-directory: ./ci/terraform
run: |
TERRAFORM_VERSION="1.14.8"
TERRAFORM_SUM_amd64="56a5d12f47cbc1c6bedb8f5426ae7d5df984d1929572c24b56f4c82e9f9bf709"
curl https://releases.hashicorp.com/terraform/$TERRAFORM_VERSION/terraform_${TERRAFORM_VERSION}_linux_amd64.zip -o terraform_bin.zip
echo "$TERRAFORM_SUM_amd64 terraform_bin.zip" | sha256sum -c -
unzip -o terraform_bin.zip
./get_kubeconfig.sh ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
./terraform init -no-color
./terraform apply -auto-approve -no-color
- name: Test network on the VMs
working-directory: ./ci/terraform
run: |
./test_terraform_vm.sh ${{ steps.ipxe.outputs.VAGRANT_HOME }}/settings.yml
- name: Clean up vagrant cluster
working-directory: ${{ steps.ipxe.outputs.VAGRANT_HOME }}
if: ${{ env.KEEP_ENV_WHEN_FAILURE != 'true' }}
run: |
vagrant destroy -f