From 6c5ac2dd85418cb243e962d418a0a13294a7a4dc Mon Sep 17 00:00:00 2001 From: Yashodhan Joshi Date: Sat, 17 Feb 2024 20:02:15 +0530 Subject: [PATCH] Update workflow for new required deps, add vagrantfile --- .github/workflows/podman_tests.yaml | 10 ++++- Vagrantfile.podmane2e | 68 +++++++++++++++++++++++++++++ 2 files changed, 77 insertions(+), 1 deletion(-) create mode 100644 Vagrantfile.podmane2e diff --git a/.github/workflows/podman_tests.yaml b/.github/workflows/podman_tests.yaml index 51de02b303..a85675d755 100644 --- a/.github/workflows/podman_tests.yaml +++ b/.github/workflows/podman_tests.yaml @@ -14,8 +14,16 @@ jobs: uses: taiki-e/install-action@just - name: Install requirements run: sudo env PATH=$PATH just ci-prepare + - name: Install skopeo and podman requirements - run: sudo apt-get install -y pkg-config libsystemd-dev libelf-dev libseccomp-dev libgpgme-dev libassuan-dev libbtrfs-dev libdevmapper-dev bats socat + run: | + sudo apt-get install -y pkg-config libsystemd-dev libelf-dev libseccomp-dev libgpgme-dev libassuan-dev libbtrfs-dev libdevmapper-dev bats socat protobuf-compiler jq conmon + cargo install netavark aardvark-dns + + - name: Copy binaries + run: | + sudo mkdir -p /usr/local/lib/podman + sudo cp $(which netavark) /usr/local/lib/podman && sudo cp $(which netavark)-dhcp-proxy-client /usr/local/lib/podman && sudo cp $(which aardvark-dns) /usr/local/lib/podman # setup go - uses: actions/setup-go@v4 diff --git a/Vagrantfile.podmane2e b/Vagrantfile.podmane2e new file mode 100644 index 0000000000..afd897161c --- /dev/null +++ b/Vagrantfile.podmane2e @@ -0,0 +1,68 @@ +# -*- mode: ruby -*- +# vi: set ft=ruby : + +GO_VERSION = "1.20.12" +PODMAN_BRANCH = "main" +SKOPEO_VERSION = "1.13.1" + +Vagrant.configure("2") do |config| + config.vm.box = "generic/ubuntu2204" + config.vm.synced_folder '.', '/vagrant/youki', disabled: false + + config.vm.provider "virtualbox" do |v| + v.memory = 8192 + v.cpus = 8 + end + + config.vm.provision "bootstrap", type: "shell" do |s| + s.inline = <<-SHELL + set -e -u -o pipefail + export DEBIAN_FRONTEND=noninteractive + apt-get update && apt-get install -y \ + make \ + pkg-config \ + libsystemd-dev \ + libdbus-glib-1-dev \ + build-essential \ + libelf-dev \ + libseccomp-dev \ + libbtrfs-dev \ + btrfs-progs \ + libgpgme-dev \ + libassuan-dev \ + libdevmapper-dev \ + bats \ + socat \ + jq \ + conmon \ + protobuf-compiler + + wget --quiet https://go.dev/dl/go#{GO_VERSION}.linux-amd64.tar.gz -O /tmp/go#{GO_VERSION}.linux-amd64.tar.gz + rm -rf /usr/local/go && tar -C /usr/local -xzf /tmp/go#{GO_VERSION}.linux-amd64.tar.gz + echo "export PATH=$PATH:/usr/local/go/bin" >> ~/.bashrc + echo "export GOPATH=$HOME/go" >> ~/.bashrc + export PATH=$PATH:$HOME/.cargo/bin:/usr/local/go/bin + export GOPATH=$HOME/go + + curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y + source "$HOME/.cargo/env" + cargo install netavark aardvark-dns + mkdir -p /usr/local/lib/podman + sudo cp /home/vagrant/.cargo/bin/netavark* /usr/local/lib/podman/ + sudo cp /home/vagrant/.cargo/bin/aardvark-dns /usr/local/lib/podman + + mkdir /tmp/skopeo + curl -fsSL "https://github.com/containers/skopeo/archive/v#{SKOPEO_VERSION}.tar.gz" | tar -xzf - -C /tmp/skopeo --strip-components=1 + cd /tmp/skopeo && DISABLE_DOCS=1 make + sudo mkdir /etc/containers && sudo cp /tmp/skopeo/bin/skopeo /usr/local/bin/skopeo && sudo cp /tmp/skopeo/default-policy.json /etc/containers/policy.json + + git clone https://github.com/containers/podman /vagrant/podman -b #{PODMAN_BRANCH} + + cd /vagrant/podman && make binaries install.tools + + rm -rf /bin/runc /sbin/runc /usr/sbin/runc /usr/bin/runc + + cp /vagrant/youki/youki /usr/bin/runc + SHELL + end +end