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 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: Cache source iso # id: cache-iso # uses: actions/cache@v4 # with: # path: ubuntu-vm/ubuntu.iso # key: ubuntu-24.04.2-live-server-amd64 # - if: ${{ steps.cache-iso.outputs.cache-hit != 'true' }} # name: Download source Ubuntu iso # continue-on-error: true - name: Download source Ubuntu iso run: | # curl -L -o ubuntu-vm/ubuntu.iso https://releases.ubuntu.com/24.04/ubuntu-24.04.2-live-server-amd64.iso curl -L \ https://sn.itch.fyi/Repository/iso/Canonical/Ubuntu%20Server%2024.04/ubuntu-24.04.2-live-server-amd64.iso \ -o ubuntu-vm/ubuntu.iso \ -u ${{ secrets.REPO_USERNAME }}:${{ secrets.REPO_PASSWORD }} - 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 && virtlogd -d virt-install \ --name ubuntu-harvester \ --ram 3072 \ --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 \ --security=none \ --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 }}