name: build-image on: [push] jobs: # semrel_dryrun: # name: Semantic Release (Dry-run) # runs-on: ubuntu-latest # outputs: # version: ${{ steps.sem_rel.outputs.version }} # steps: # - name: Check out repository code # uses: actions/checkout@v3 # - name: Set up Node # uses: actions/setup-node@v3 # with: # node-version: 20 # - name: Install dependencies # run: | # npm install \ # semantic-release \ # @semantic-release/commit-analyzer \ # @semantic-release/exec # - name: Semantic Release (dry-run) # id: sem_rel # run: | # npx semantic-release \ # --package @semantic-release/exec \ # --package semantic-release \ # --branches ${{ gitea.refname }} \ # --tag-format 'v${version}' \ # --dry-run \ # --plugins @semantic-release/commit-analyzer,@semantic-release/exec \ # --analyzeCommits @semantic-release/commit-analyzer \ # --verifyRelease @semantic-release/exec \ # --verifyReleaseCmd 'echo "version=${nextRelease.version}" >> $GITHUB_OUTPUT' # env: # GIT_CREDENTIALS: ${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_APIKEY }} # - name: Assert semantic release output # run: | # [[ -z "${{ steps.sem_rel.outputs.version }}" ]] && { # echo 'No release tag - exiting'; exit 1 # } || { # echo 'Release tag set correctly: ${{ steps.sem_rel.outputs.version }}'; exit 0 # } build_image: name: Build image container: volumes: - /iso:/iso runs-on: ubuntu-latest # needs: semrel_dryrun steps: - name: Check out repository code uses: actions/checkout@v4 - name: Create folder structure run: | mkdir -p \ ubuntu-vm - name: Assert source Ubuntu ISO run: | # TODO: Make this path configurable in a yaml file # TODO: Add checksum verification # d6dab0c3a657988501b4bd76f1297c053df710e06e0c3aece60dead24f270b4d *ubuntu-24.04.2-live-server-amd64.iso ls /iso -lashR ls / -lashR [[ -f '/iso/Canonical/Ubuntu Server 24.04/ubuntu-24.04.2-live-server-amd64.iso' ]] && { echo 'Source iso file exists - creating symbolic link' ln -s "/iso/Canonical/Ubuntu Server 24.04/ubuntu-24.04.2-live-server-amd64.iso" ubuntu-vm/ubuntu.iso ls ubuntu-vm -lash } || { echo 'Missing source iso file - exiting'; exit 1 } - name: Generate seed ISO run: | apt-get update && \ apt-get install -y \ gettext \ genisoimage envsubst < cloud-init/user-data.template > cloud-init/user-data genisoimage \ -output ubuntu-vm/seed.iso \ -volid cidata \ -joliet \ -rock \ cloud-init/meta-data cloud-init/user-data env: ROOT_HASHED_PASSWORD: ${{ secrets.ROOT_HASHED_PASSWORD }} PUBLIC_SSHKEY: ${{ secrets.PUBLIC_SSHKEY }} - name: Create empty QCOW2 disk run: | apt-get update && \ apt-get install -y \ qemu-utils qemu-img create -f qcow2 ubuntu-vm/ubuntu.qcow2 10G - name: Run virt-install # container: quay.io/kubevirt/libvirt run: | apt-get update && \ apt-get install -y \ libvirt-daemon-system \ libvirt-clients \ virtinst \ qemu-utils libvirtd -d virt-install \ --name ubuntu-harvester \ --ram 2048 \ --vcpus 2 \ --disk path=ubuntu-vm/ubuntu.qcow2,size=10,format=qcow2 \ --disk path=ubuntu-vm/seed.iso,device=cdrom \ --cdrom ubuntu-vm/ubuntu.iso \ --os-variant ubuntu24.04 \ --graphics none \ --network network=default \ --noautoconsole \ --wait -1 # semrel: # name: Semantic Release # runs-on: ubuntu-latest # needs: build_image # steps: # - name: Check out repository code # uses: actions/checkout@v3 # - name: Set up Node # uses: actions/setup-node@v3 # with: # node-version: 20 # - name: Install dependencies # run: | # npm install \ # semantic-release \ # @semantic-release/changelog \ # @semantic-release/commit-analyzer \ # @semantic-release/git \ # @semantic-release/release-notes-generator # - name: Semantic Release # run: | # npx semantic-release \ # --branches ${{ gitea.refname }} \ # --tag-format 'v${version}' \ # --plugins @semantic-release/commit-analyzer,@semantic-release/release-notes-generator,@semantic-release/changelog,@semantic-release/git # env: # GIT_CREDENTIALS: ${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_APIKEY }}