feat: ubuntu 24.04
This commit is contained in:
		
							
								
								
									
										1
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/e2e.yml
									
									
									
									
										vendored
									
									
								
							| @@ -31,6 +31,7 @@ jobs: | ||||
|           { distro: Ubuntu, release: 18.04 }, | ||||
|           { distro: Ubuntu, release: 20.04 }, | ||||
|           { distro: Ubuntu, release: 22.04 }, | ||||
|           { distro: Ubuntu, release: 24.04 }, | ||||
|           { distro: CentOS, release: 6 }, | ||||
|           { distro: CentOS, release: 7 }, | ||||
|           { distro: CentOS, release: 8 }, | ||||
|   | ||||
							
								
								
									
										89
									
								
								.github/workflows/images-ubuntu.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								.github/workflows/images-ubuntu.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | ||||
| name: Ubuntu images | ||||
|  | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   push: | ||||
|     paths: | ||||
|       - 'tools/qemu-ubuntu-img/**' | ||||
|       - '.github/workflows/images-ubuntu.yml' | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow_ref }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| jobs: | ||||
|   images: | ||||
|     name: Qemu Images | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: digitalocean/action-doctl@v2 | ||||
|       with: | ||||
|         token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }} | ||||
|  | ||||
|     - uses: webfactory/ssh-agent@v0.8.0 | ||||
|       with: | ||||
|         ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }} | ||||
|  | ||||
|     - name: create droplet | ||||
|       run: doctl compute droplet create --ssh-keys='b4:4c:66:7d:be:19:25:43:1c:e0:02:61:9f:49:12:94,37:46:77:a8:4a:96:3b:20:16:46:35:04:95:ca:0c:5c' --tag-name=github-actions ga-out-of-tree-images-ubuntu-$GITHUB_SHA --size s-1vcpu-1gb --image ubuntu-22-04-x64 --wait | ||||
|  | ||||
|       # TODO Move to common script | ||||
|     - name: generate images | ||||
|       shell: bash | ||||
|       run: | | ||||
|         set -x | ||||
|  | ||||
|         sleep 1m | ||||
|  | ||||
|         IP=$(doctl compute droplet list --tag-name=github-actions --format "Name,Public IPv4" | grep -v ID | grep ga-out-of-tree-images-ubuntu-$GITHUB_SHA | awk '{print $2}') | ||||
|  | ||||
|         while ! ssh -o StrictHostKeyChecking=accept-new root@$IP echo | ||||
|         do | ||||
|           sleep 1s | ||||
|         done | ||||
|  | ||||
|         ssh root@$IP "cloud-init status --wait | grep done" | ||||
|  | ||||
|         ssh root@$IP apt-get update | ||||
|         ssh root@$IP apt-get install -y git podman s3cmd | ||||
|         ssh root@$IP git clone https://github.com/out-of-tree/out-of-tree | ||||
|         ssh root@$IP "cd out-of-tree && git checkout $GITHUB_SHA" | ||||
|  | ||||
|         ssh root@$IP "echo -e '[Unit]\nDescription=Ubuntu image generator and uploader\n[Service]\nRemainAfterExit=yes\nStandardError=append:/var/log/images-ubuntu.log\nStandardOutput=append:/var/log/images-ubuntu.log\nType=oneshot' >> /etc/systemd/system/images-ubuntu.service" | ||||
|  | ||||
|         ssh root@$IP "echo Environment=HOST=fra1.digitaloceanspaces.com >> /etc/systemd/system/images-ubuntu.service" | ||||
|         ssh root@$IP "echo Environment=HOST_BUCKET=out-of-tree.fra1.digitaloceanspaces.com >> /etc/systemd/system/images-ubuntu.service" | ||||
|         ssh root@$IP "echo Environment=ACCESS_KEY=${{ secrets.DIGITALOCEAN_SPACES_ACCESS_KEY }} >> /etc/systemd/system/images-ubuntu.service" | ||||
|         ssh root@$IP "echo Environment=SECRET_KEY=${{ secrets.DIGITALOCEAN_SPACES_SECRET_KEY }} >> /etc/systemd/system/images-ubuntu.service" | ||||
|  | ||||
|         ssh root@$IP "echo 'ExecStart=/root/out-of-tree/tools/qemu-ubuntu-img/generate-images.py' >> /etc/systemd/system/images-ubuntu.service" | ||||
|  | ||||
|         ssh root@$IP 'echo ExecStart=/bin/sh -c \"s3cmd put --acl-public /root/out-of-tree/tools/qemu-ubuntu-img/*.tar.gz s3://out-of-tree/1.0.0/ --host=\$HOST --host-bucket=\$HOST_BUCKET --access_key=\$ACCESS_KEY --secret_key=\$SECRET_KEY\" >> /etc/systemd/system/images-ubuntu.service' | ||||
|  | ||||
|         ssh root@$IP "echo TimeoutStopSec=1 >> /etc/systemd/system/images-ubuntu.service" | ||||
|  | ||||
|         ssh root@$IP systemctl daemon-reload | ||||
|  | ||||
|         ssh root@$IP systemctl start images-ubuntu --no-block | ||||
|  | ||||
|         while ! ssh root@$IP systemctl show images-ubuntu -p SubState --value | grep -E '(failed|exited)' | ||||
|         do | ||||
|           sleep 1m | ||||
|         done | ||||
|  | ||||
|         scp root@$IP:/var/log/images-ubuntu.log . | ||||
|  | ||||
|         cat images-ubuntu.log | ||||
|  | ||||
|         ssh root@$IP systemctl is-active images-ubuntu | ||||
|  | ||||
|     - name: Archive logs | ||||
|       if: always() | ||||
|       uses: actions/upload-artifact@v4 | ||||
|       with: | ||||
|         name: images-ubuntu-log | ||||
|         path: images-ubuntu.log | ||||
|  | ||||
|     - name: delete droplet | ||||
|       if: always() | ||||
|       run: doctl compute droplet delete -f ga-out-of-tree-images-ubuntu-$GITHUB_SHA | ||||
							
								
								
									
										1
									
								
								.github/workflows/ubuntu.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/ubuntu.yml
									
									
									
									
										vendored
									
									
								
							| @@ -113,6 +113,7 @@ jobs: | ||||
|           { distro: Ubuntu, release: 18.04 }, | ||||
|           { distro: Ubuntu, release: 20.04 }, | ||||
|           { distro: Ubuntu, release: 22.04 }, | ||||
|           { distro: Ubuntu, release: 24.04 }, | ||||
|           { distro: CentOS, release: 6 }, | ||||
|           { distro: CentOS, release: 7 }, | ||||
|           { distro: CentOS, release: 8 }, | ||||
|   | ||||
| @@ -17,6 +17,7 @@ func init() { | ||||
| 		"18.04", | ||||
| 		"20.04", | ||||
| 		"22.04", | ||||
| 		"24.04", | ||||
| 	} | ||||
|  | ||||
| 	for _, release := range releases { | ||||
|   | ||||
							
								
								
									
										70
									
								
								tools/qemu-ubuntu-img/generate-images.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										70
									
								
								tools/qemu-ubuntu-img/generate-images.py
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| #!/usr/bin/env python3 | ||||
|  | ||||
| import os | ||||
| import subprocess | ||||
|  | ||||
| script_dir = os.path.dirname(os.path.realpath(__file__)) | ||||
| os.chdir(script_dir) | ||||
|  | ||||
| releases = [ | ||||
|     # ('12.04', 'precies'), | ||||
|     # ('14.04', 'trusty'), | ||||
|     # ('16.04', 'xenial'), | ||||
|     # ('18.04', 'bionic'), | ||||
|     # ('20.04', 'focal'), | ||||
|     # ('22.04', 'jammy'), | ||||
|     ('24.04', 'noble'), | ||||
| ] | ||||
|  | ||||
| template = ''' | ||||
| FROM ubuntu:{version} | ||||
|  | ||||
| ENV DEBIAN_FRONTEND=noninteractive | ||||
| RUN apt update | ||||
| RUN apt install -y debootstrap qemu-utils | ||||
| RUN apt install -y linux-image-generic | ||||
|  | ||||
| ENV TMPDIR=/tmp/ubuntu | ||||
| ENV IMAGEDIR=/tmp/image | ||||
| ENV IMAGE=/shared/out_of_tree_ubuntu_{img_version}.img | ||||
| ENV REPOSITORY=http://archive.ubuntu.com/ubuntu | ||||
| ENV RELEASE={codename} | ||||
|  | ||||
| RUN mkdir $IMAGEDIR | ||||
|  | ||||
| # Must be executed with --privileged because of /dev/loop | ||||
| CMD debootstrap --include=openssh-server,policykit-1 \ | ||||
| 	$RELEASE $TMPDIR $REPOSITORY && \ | ||||
| 	/shared/setup.sh $TMPDIR && \ | ||||
| 	qemu-img create $IMAGE 2G && \ | ||||
| 	mkfs.ext4 -F $IMAGE && \ | ||||
| 	mount -o loop $IMAGE $IMAGEDIR && \ | ||||
| 	cp -a $TMPDIR/* $IMAGEDIR/ && \ | ||||
| 	umount $IMAGEDIR | ||||
| ''' | ||||
|  | ||||
| def run_cmd(cmd): | ||||
|     print(f"+ {cmd}") | ||||
|     subprocess.run(cmd, shell=True, check=True, executable='/bin/bash') | ||||
|  | ||||
| for version, codename in releases: | ||||
|     numeric_version = version.replace('.', '') | ||||
|     img_version=version.replace(".","__") | ||||
|  | ||||
|     dockerfile_content = template.format( | ||||
|         version=version, | ||||
|         img_version=img_version, | ||||
|         codename=codename, | ||||
|         numeric_version=numeric_version) | ||||
|  | ||||
|     os.makedirs(str(version), exist_ok=True) | ||||
|     with open(f"{version}/Dockerfile", "w") as dockerfile: | ||||
|         dockerfile.write(dockerfile_content) | ||||
|  | ||||
|     run_cmd(f"podman build -t gen-ubuntu{numeric_version}-image {version}") | ||||
|     run_cmd(f"rm -rf {version}") | ||||
|  | ||||
|     run_cmd(f"podman run --privileged -v {os.getcwd()}:/shared -t gen-ubuntu{numeric_version}-image") | ||||
|  | ||||
|     run_cmd(f"tar -Szcf out_of_tree_ubuntu_{img_version}.img.tar.gz out_of_tree_ubuntu_{img_version}.img") | ||||
|  | ||||
| @@ -13,5 +13,5 @@ sed -i '/PermitRootLogin/d' $TMPDIR/etc/ssh/sshd_config | ||||
| echo PermitRootLogin yes >> $TMPDIR/etc/ssh/sshd_config | ||||
|  | ||||
| echo '#!/bin/sh' > $TMPDIR/etc/rc.local | ||||
| echo 'dhclient' >> $TMPDIR/etc/rc.local | ||||
| echo 'dhclient || dhcpcd' >> $TMPDIR/etc/rc.local | ||||
| chmod +x $TMPDIR/etc/rc.local | ||||
|   | ||||
		Reference in New Issue
	
	Block a user