Compare commits

..

1 Commits

Author SHA1 Message Date
ade3e4293c build: Add virt-install steps
Some checks failed
build-image / Build image (push) Failing after 24s
2025-07-25 15:59:44 +10:00
2 changed files with 69 additions and 118 deletions

View File

@@ -2,70 +2,64 @@ name: build-image
on: [push] on: [push]
jobs: jobs:
semrel_dryrun: # semrel_dryrun:
name: Semantic Release (Dry-run) # name: Semantic Release (Dry-run)
runs-on: ubuntu-latest # runs-on: ubuntu-latest
outputs: # outputs:
version: ${{ steps.sem_rel.outputs.version }} # version: ${{ steps.sem_rel.outputs.version }}
steps: # steps:
- name: Check out repository code # - name: Check out repository code
uses: actions/checkout@v3 # uses: actions/checkout@v3
- name: Install dependencies # - name: Set up Node
run: | # uses: actions/setup-node@v3
npm install \ # with:
semantic-release \ # node-version: 20
@semantic-release/commit-analyzer \ # - name: Install dependencies
@semantic-release/exec # run: |
- name: Semantic Release (dry-run) # npm install \
id: sem_rel # semantic-release \
run: | # @semantic-release/commit-analyzer \
npx semantic-release \ # @semantic-release/exec
--package @semantic-release/exec \ # - name: Semantic Release (dry-run)
--package semantic-release \ # id: sem_rel
--branches ${{ gitea.refname }} \ # run: |
--tag-format 'v${version}' \ # npx semantic-release \
--dry-run \ # --package @semantic-release/exec \
--plugins @semantic-release/commit-analyzer,@semantic-release/exec \ # --package semantic-release \
--analyzeCommits @semantic-release/commit-analyzer \ # --branches ${{ gitea.refname }} \
--verifyRelease @semantic-release/exec \ # --tag-format 'v${version}' \
--verifyReleaseCmd 'echo "version=${nextRelease.version}" >> $GITHUB_OUTPUT' # --dry-run \
- name: Assert semantic release output # --plugins @semantic-release/commit-analyzer,@semantic-release/exec \
run: | # --analyzeCommits @semantic-release/commit-analyzer \
[[ -z "${{ steps.sem_rel.outputs.version }}" ]] && { # --verifyRelease @semantic-release/exec \
echo 'No release tag - exiting'; exit 1 # --verifyReleaseCmd 'echo "version=${nextRelease.version}" >> $GITHUB_OUTPUT'
} || { # env:
echo 'Release tag set correctly: ${{ steps.sem_rel.outputs.version }}'; exit 0 # 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: build_image:
name: Build image name: Build image
container: code.spamasaurus.com/djpbessems/act-runner-extended:1.0.0-cth20250815
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: semrel_dryrun # needs: semrel_dryrun
steps: steps:
- name: Check out repository code - name: Check out repository code
uses: actions/checkout@v4 uses: actions/checkout@v4
- name: Set up build container - name: Create folder structure
run: |
mkdir -p \
ubuntu-vm
- name: Generate seed ISO
run: | run: |
apt-get update && \ apt-get update && \
apt-get install -y \ apt-get install -y \
linux-image-generic \ genisoimage
linux-modules-extra-$(uname -r) \
linux-headers-generic
mkdir -p \
$PWD/ubuntu-vm \
/mnt/vmimage
- name: Retrieve source Ubuntu image
run: |
curl -L \
https://sn.itch.fyi/Repository/iso/Canonical/Ubuntu%20Server%2024.04/ubuntu-24.04-server-cloudimg-amd64.img \
-o ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img \
-u ${{ secrets.REPO_USERNAME }}:${{ secrets.REPO_PASSWORD }}
qemu-img resize ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img +5G
- name: Generate seed ISO
run: |
envsubst < cloud-init/user-data.template > cloud-init/user-data envsubst < cloud-init/user-data.template > cloud-init/user-data
genisoimage \ genisoimage \
@@ -74,64 +68,33 @@ jobs:
-joliet \ -joliet \
-rock \ -rock \
cloud-init/meta-data cloud-init/user-data cloud-init/meta-data cloud-init/user-data
ls -lash ubuntu-vm
env: env:
ROOT_HASHED_PASSWORD: ${{ secrets.VM_ROOT_HASHED_PASSWORD }} ROOT_HASHED_PASSWORD: ${{ secrets.ROOT_HASHED_PASSWORD }}
PUBLIC_SSHKEY: ${{ secrets.VM_PUBLIC_SSHKEY }} PUBLIC_SSHKEY: ${{ secrets.PUBLIC_SSHKEY }}
- name: Provision template virtual machine - name: Download Ubuntu ISO
run: | run: |
[ -e /dev/kvm ] && kvm_flag="-enable-kvm" || kvm_flag="" if [ ! -f ubuntu-vm/ubuntu-24.04.iso ]; then
curl -L -o ubuntu-vm/ubuntu-24.04.iso https://releases.ubuntu.com/24.04/ubuntu-24.04.2-desktop-amd64.iso
qemu-system-x86_64 \
$kvm_flag \
-m 3072 \
-smp 2 \
-cpu host \
-drive file=ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img,if=virtio,format=qcow2 \
-drive file=ubuntu-vm/seed.iso,format=raw,media=cdrom \
-nographic \
-net nic \
-net user \
-device virtio-serial-pci,id=virtio-serial0 \
-chardev socket,path=qga.sock,server=on,wait=off,id=qga0 \
-device virtserialport,chardev=qga0,name=org.qemu.guest_agent.0
if ! guestfish --ro -a ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img -i stat /var/log/template-generation-success; then
echo "VM provisioning encountered errors - exiting"
exit 1
fi fi
- name: Compress image file - name: Create empty QCOW2 disk
run: | run: |
virt-sparsify --compress \ qemu-img create -f qcow2 ubuntu-vm/ubuntu.qcow2 10G
ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img \ - name: Run virt-install
ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}-compacted.img
- name: Upload image file
run: | run: |
REPO_TOKEN=$(curl -fsSL -X POST \ virt-install \
http://filebrowser.filebrowser.svc.cluster.local:80/api/login \ --name ubuntu-harvester \
-H "Content-Type: application/json" \ --ram 2048 \
-d '{"username": "admin", "password": "${{ secrets.REPO_PASSWORD }}"}' \ --vcpus 2 \
) --disk path=ubuntu-vm/ubuntu.qcow2,size=10,format=qcow2 \
curl -fsSL -X POST \ --disk path=ubuntu-vm/seed.iso,device=cdrom \
http://filebrowser.filebrowser.svc.cluster.local:80/api/resources/rel/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img?override=true \ --cdrom ubuntu-vm/ubuntu-24.04.iso \
--header "X-Auth: $REPO_TOKEN" \ --os-variant ubuntu24.04 \
--upload-file "ubuntu-vm/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}-compacted.img" --graphics none \
--network network=default \
curl -ksS -X PUT "https://lab-hv-vip.bessems.lan/v1/harvesterhci.io.virtualmachineimages" \ --noautoconsole \
-H "Authorization: Bearer ${{ secrets.HV_TOKEN }}" \ --wait -1
-H "Content-Type: application/json" \
-d @- <<EOF
{
"type": "harvesterhci.io.virtualmachineimage",
"metadata": {
"namespace": "default"
},
"spec": {
"displayName": "ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}",
"sourceType": "download",
"url": "https://${{ secrets.REPO_USERNAME }}:${{ secrets.REPO_PASSWORD }}@sn.itch.fyi/Repository/rel/ubuntu-24.04.2-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img"
}
}
EOF
# semrel: # semrel:
# name: Semantic Release # name: Semantic Release

View File

@@ -12,15 +12,8 @@ packages:
runcmd: runcmd:
- apt-get install -y linux-modules-extra-$(uname -r) - apt-get install -y linux-modules-extra-$(uname -r)
- sed -i '/"${distro_id}:${distro_codename}-updates"/s|^//||' /etc/apt/apt.conf.d/50unattended-upgrades
- sysctl -w net.ipv6.conf.all.disable_ipv6=1 - sysctl -w net.ipv6.conf.all.disable_ipv6=1
- systemctl enable --now qemu-guest-agent.service - systemctl enable --now qemu-guest-agent.service
- cloud-init clean --logs
- truncate -s 0 /etc/hostname /etc/machine-id
- rm -f /etc/ssh/ssh_host_* /var/lib/dbus/machine-id
- ln -s /etc/machine-id /var/lib/dbus/machine-id
- echo "TEMPLATE_GENERATION_SUCCESS" | tee /var/log/template-generation-success
- sync
disable_root: false disable_root: false
users: users:
@@ -32,8 +25,3 @@ users:
- ${PUBLIC_SSHKEY} - ${PUBLIC_SSHKEY}
ssh_authorized_keys: ssh_authorized_keys:
- ${PUBLIC_SSHKEY} - ${PUBLIC_SSHKEY}
power_state:
delay: now
mode: poweroff
condition: true