Skip to content

Commit

Permalink
run-tests: fetch kernels and selftests from containers
Browse files Browse the repository at this point in the history
Use the new GH Actions built containers as a source for run-tests.sh.

Fixes: cilium#1258

Signed-off-by: Lorenz Bauer <lmb@isovalent.com>
  • Loading branch information
lmb committed Dec 8, 2023
1 parent 14adc78 commit c76d255
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 30 deletions.
2 changes: 1 addition & 1 deletion docs/ebpf/contributing/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ go test -exec sudo ./...
```

To test the current package with a different kernel version you can use the [run-tests.sh] script.
It requires [virtme] and qemu to be installed.
It requires [virtme], qemu and docker to be installed.
Unfortunately virtme is not well maintained at the moment, so we recommend installing
a known working version:

Expand Down
65 changes: 36 additions & 29 deletions run-tests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,8 @@ elif [[ "${1:-}" = "--exec-test" ]]; then
mount -t bpf bpf /sys/fs/bpf
mount -t tracefs tracefs /sys/kernel/debug/tracing

if [[ -d "/run/input/bpf" ]]; then
export KERNEL_SELFTESTS="/run/input/bpf"
if [[ -d "/run/input/tools/testing/selftests/bpf" ]]; then
export KERNEL_SELFTESTS="/run/input/tools/testing/selftests/bpf"
fi

if [[ -d "/run/input/lib/modules" ]]; then
Expand All @@ -121,42 +121,49 @@ readonly input="$(mktemp -d)"
readonly tmp_dir="${TMPDIR:-/tmp}"

fetch() {
echo Fetching "${1}"
pushd "${tmp_dir}" > /dev/null
curl --no-progress-meter -L -O --fail --etag-compare "${1}.etag" --etag-save "${1}.etag" "https://github.com/cilium/ci-kernels/raw/${BRANCH:-master}/${1}"
local ret=$?
popd > /dev/null
return $ret
echo Fetching "${1}"
pushd "${tmp_dir}" > /dev/null
curl --no-progress-meter -L -O --fail --etag-compare "${1}.etag" --etag-save "${1}.etag" "https://github.com/cilium/ci-kernels/raw/${BRANCH:-master}/${1}"
local ret=$?
popd > /dev/null
return $ret
}

machine="$(uname -m)"
readonly machine
docker_image_exists() {
local image_name="$1"
if docker manifest inspect "$image_name" > /dev/null 2>&1; then
return 0
else
return 1
fi
}

extract_docker_image() {
local image_name=$1
local target_directory=$2

echo "Fetching $image_name"

# We abuse the --output flag of docker buildx to obtain a copy of the image.
# This is simpler than creating a temporary container and using docker cp.
# It also automatically fetches the image for us if necessary.
echo "FROM $image_name" | docker buildx build --quiet --output="$target_directory" - > /dev/null
}

if [[ -f "${1}" ]]; then
# First argument is a local file.
readonly kernel="${1}"
cp "${1}" "${input}/bzImage"
cp "${1}" "${input}/boot/vmlinuz"
else
# LINUX_VERSION_CODE test compares this to discovered value.
export KERNEL_VERSION="${1}"
readonly kernel="${1}"

if [ "${machine}" = "x86_64" ]; then
readonly kernel="linux-${1}-amd64.tgz"
readonly selftests="linux-${1}-amd64-selftests-bpf.tgz"
elif [ "${machine}" = "aarch64" ]; then
readonly kernel="linux-${1}-arm64.tgz"
readonly selftests=""
else
echo "Arch ${machine} is not supported"
exit 1
fi
# LINUX_VERSION_CODE test compares this to discovered value.
export KERNEL_VERSION="${1}"

fetch "${kernel}"
tar xf "${tmp_dir}/${kernel}" -C "${input}"
extract_docker_image "ghcr.io/cilium/ci-kernels:${kernel}" "${input}"

if [ -n "${selftests}" ] && fetch "${selftests}"; then
echo "Decompressing selftests"
mkdir "${input}/bpf"
tar --strip-components=5 -xf "${tmp_dir}/${selftests}" -C "${input}/bpf"
if docker_image_exists "ghcr.io/cilium/ci-kernels:${kernel}-selftests"; then
extract_docker_image "ghcr.io/cilium/ci-kernels:${kernel}-selftests" "${input}"
else
echo "No selftests found, disabling"
fi
Expand Down

0 comments on commit c76d255

Please sign in to comment.