diff --git a/test/cases/020_kernel/008_config_5.1.x/test.sh b/test/cases/020_kernel/008_config_5.1.x/test.sh new file mode 100644 index 000000000..fdfccb99c --- /dev/null +++ b/test/cases/020_kernel/008_config_5.1.x/test.sh @@ -0,0 +1,24 @@ +#!/bin/sh +# SUMMARY: Sanity check on the kernel config file +# LABELS: +# REPEAT: + +set -e + +# Source libraries. Uncomment if needed/defined +#. "${RT_LIB}" +. "${RT_PROJECT_ROOT}/_lib/lib.sh" + +NAME=kconfig + +clean_up() { + rm -rf ${NAME}-* +} +trap clean_up EXIT + +# Test code goes here +linuxkit build -format kernel+initrd -name "${NAME}" test.yml +RESULT="$(linuxkit run ${NAME})" +echo "${RESULT}" | grep -q "suite PASSED" + +exit 0 diff --git a/test/cases/020_kernel/008_config_5.1.x/test.yml b/test/cases/020_kernel/008_config_5.1.x/test.yml new file mode 100644 index 000000000..aec76d5ee --- /dev/null +++ b/test/cases/020_kernel/008_config_5.1.x/test.yml @@ -0,0 +1,15 @@ +kernel: + image: linuxkit/kernel:5.1.1 + cmdline: "console=ttyS0 console=ttyAMA0" +init: + - linuxkit/init:v0.7 + - linuxkit/runc:v0.7 +onboot: + - name: check-kernel-config + image: linuxkit/test-kernel-config:0e9308f871ac86c680d64836a050547a2feebb36 + - name: poweroff + image: linuxkit/poweroff:b498d30dd9660090565537fceb9e757618737a85 + command: ["/bin/sh", "/poweroff.sh", "3"] +trust: + org: + - linuxkit diff --git a/test/cases/020_kernel/018_kmod_5.1.x/Dockerfile b/test/cases/020_kernel/018_kmod_5.1.x/Dockerfile new file mode 100644 index 000000000..e9ad0538b --- /dev/null +++ b/test/cases/020_kernel/018_kmod_5.1.x/Dockerfile @@ -0,0 +1,23 @@ +# This Dockerfile extracts the kernel headers from the kernel image +# and then compiles a simple hello world kernel module against them. +# In the last stage, it creates a package, which can be used for +# testing. + +FROM linuxkit/kernel:5.1.1 AS ksrc + +# Extract headers and compile module +FROM linuxkit/alpine:86cd4f51b49fb9a078b50201d892a3c7973d48ec AS build +RUN apk add build-base elfutils-dev + +COPY --from=ksrc /kernel-dev.tar / +RUN tar xf kernel-dev.tar + +WORKDIR /kmod +COPY ./src/* ./ +RUN make all + +# Package +FROM alpine:3.9 +COPY --from=build /kmod/hello_world.ko / +COPY check.sh /check.sh +ENTRYPOINT ["/bin/sh", "/check.sh"] diff --git a/test/cases/020_kernel/018_kmod_5.1.x/check.sh b/test/cases/020_kernel/018_kmod_5.1.x/check.sh new file mode 100755 index 000000000..02e491624 --- /dev/null +++ b/test/cases/020_kernel/018_kmod_5.1.x/check.sh @@ -0,0 +1,15 @@ +#!/bin/sh +function failed { + printf "Kernel module test suite FAILED\n" + /sbin/poweroff -f +} + +uname -a +modinfo hello_world.ko || failed +insmod hello_world.ko || failed +[ -n "$(dmesg | grep -o 'Hello LinuxKit')" ] || failed +rmmod hello_world || failed + +printf "Kernel module test suite PASSED\n" + +/sbin/poweroff -f diff --git a/test/cases/020_kernel/018_kmod_5.1.x/src/Makefile b/test/cases/020_kernel/018_kmod_5.1.x/src/Makefile new file mode 100644 index 000000000..31c8215dd --- /dev/null +++ b/test/cases/020_kernel/018_kmod_5.1.x/src/Makefile @@ -0,0 +1,6 @@ +obj-m += hello_world.o +KVER=$(shell basename /usr/src/linux-headers-*) +all: + make -C /usr/src/$(KVER) M=$(PWD) modules +clean: + make -C /usr/src/$(KVER) M=$(PWD) clean diff --git a/test/cases/020_kernel/018_kmod_5.1.x/src/hello_world.c b/test/cases/020_kernel/018_kmod_5.1.x/src/hello_world.c new file mode 100644 index 000000000..7dd6d3ee2 --- /dev/null +++ b/test/cases/020_kernel/018_kmod_5.1.x/src/hello_world.c @@ -0,0 +1,22 @@ +/* + * A simple Hello World kernel module + */ +#include +#include + +int init_hello(void) +{ + printk(KERN_INFO "Hello LinuxKit\n"); + return 0; +} + +void exit_hello(void) +{ + printk(KERN_INFO "Goodbye LinuxKit.\n"); +} + +module_init(init_hello); +module_exit(exit_hello); +MODULE_AUTHOR("Rolf Neugebauer "); +MODULE_LICENSE("GPL"); +MODULE_DESCRIPTION("A simple Hello World kernel module for testing"); diff --git a/test/cases/020_kernel/018_kmod_5.1.x/test.sh b/test/cases/020_kernel/018_kmod_5.1.x/test.sh new file mode 100644 index 000000000..86e65248a --- /dev/null +++ b/test/cases/020_kernel/018_kmod_5.1.x/test.sh @@ -0,0 +1,31 @@ +#!/bin/sh +# SUMMARY: Test build and insertion of kernel modules +# LABELS: +# REPEAT: + +set -e + +# Source libraries. Uncomment if needed/defined +#. "${RT_LIB}" +. "${RT_PROJECT_ROOT}/_lib/lib.sh" + +NAME=kmod +IMAGE_NAME=kmod-test + +clean_up() { + docker rmi ${IMAGE_NAME} || true + rm -rf ${NAME}-* +} +trap clean_up EXIT + +# Make sure we have the latest kernel image +docker pull linuxkit/kernel:5.1.1 +# Build a package +docker build -t ${IMAGE_NAME} . + +# Build and run a LinuxKit image with kernel module (and test script) +linuxkit build -format kernel+initrd -name "${NAME}" test.yml +RESULT="$(linuxkit run ${NAME})" +echo "${RESULT}" | grep -q "Hello LinuxKit" + +exit 0 diff --git a/test/cases/020_kernel/018_kmod_5.1.x/test.yml b/test/cases/020_kernel/018_kmod_5.1.x/test.yml new file mode 100644 index 000000000..1695ebfc1 --- /dev/null +++ b/test/cases/020_kernel/018_kmod_5.1.x/test.yml @@ -0,0 +1,20 @@ +kernel: + image: linuxkit/kernel:5.1.1 + cmdline: "console=ttyS0 console=ttyAMA0" +init: + - linuxkit/init:v0.7 + - linuxkit/runc:v0.7 +onboot: + - name: check + image: kmod-test + binds: + - /dev:/dev + - /lib/modules:/lib/modules + capabilities: + - all + - name: poweroff + image: linuxkit/poweroff:b498d30dd9660090565537fceb9e757618737a85 + command: ["/bin/sh", "/poweroff.sh", "3"] +trust: + org: + - linuxkit