diff --git a/Makefile b/Makefile index daac32daf..354c05519 100644 --- a/Makefile +++ b/Makefile @@ -31,62 +31,15 @@ bin/linuxkit: $(LINUXKIT_DEPS) | bin rm tmp_linuxkit_bin.tar touch $@ -test-initrd.img: $(MOBY) test/test.yml - $(MOBY) build --pull test/test.yml - -test-bzImage: test-initrd.img - -.PHONY: test-qemu-efi -test-qemu-efi: $(LINUXKIT) test-efi.iso - $(LINUXKIT) run qemu test | tee test-efi.log - $(call check_test_log, test-efi.log) - bin: mkdir -p $@ install: cp -R ./bin/* $(PREFIX)/bin -define check_test_log - @cat $1 |grep -q 'test suite PASSED' -endef - -.PHONY: test-hyperkit -test-hyperkit: $(LINUXKIT) test-initrd.img test-bzImage test-cmdline - rm -f disk.img - $(LINUXKIT) run hyperkit test | tee test.log - $(call check_test_log, test.log) - -.PHONY: test-gcp -test-gcp: export CLOUDSDK_IMAGE_NAME?=test -test-gcp: $(LINUXKIT) test.img.tar.gz - $(LINUXKIT) push gcp test.img.tar.gz - $(LINUXKIT) run gcp $(CLOUDSDK_IMAGE_NAME) | tee test-gcp.log - $(call check_test_log, test-gcp.log) - .PHONY: test -test: $(LINUXKIT) test-initrd.img test-bzImage test-cmdline - $(LINUXKIT) run test | tee test.log - $(call check_test_log, test.log) - -test-ltp.img.tar.gz: $(MOBY) test/ltp/test-ltp.yml - $(MOBY) build --pull test/ltp/test-ltp.yml - -.PHONY: test-ltp -test-ltp: export CLOUDSDK_IMAGE_NAME?=test-ltp -test-ltp: $(LINUXKIT) artifacts/test-ltp.img.tar.gz - $(LINUXKIT) push gcp artifacts/test-ltp.img.tar.gz - $(LINUXKIT) run gcp -skip-cleanup -machine n1-highcpu-4 $(CLOUDSDK_IMAGE_NAME) | tee test-ltp.log - $(call check_test_log, test-ltp.log) - -artifacts: - mkdir -p $@ - -artifacts/test.img.tar.gz: test.img.tar.gz | artifacts - cp test.img.tar.gz artifacts/ - -artifacts/test-ltp.img.tar.gz: test-ltp.img.tar.gz | artifacts - cp test-ltp.img.tar.gz artifacts/ +test: + $(MAKE) -C test .PHONY: collect-artifacts collect-artifacts: artifacts/test.img.tar.gz artifacts/test-ltp.img.tar.gz @@ -95,23 +48,22 @@ collect-artifacts: artifacts/test.img.tar.gz artifacts/test-ltp.img.tar.gz ci: $(MAKE) clean $(MAKE) - $(MAKE) test - $(MAKE) collect-artifacts - $(MAKE) test-ltp + $(MAKE) install + $(MAKE) -C test all ci-tag: $(MAKE) clean $(MAKE) - $(MAKE) test - $(MAKE) collect-artifacts - $(MAKE) test-ltp + $(MAKE) install + $(MAKE) -C test all ci-pr: $(MAKE) clean $(MAKE) - $(MAKE) test - $(MAKE) artifacts/test.img.tar.gz + $(MAKE) install + $(MAKE) -C test pr .PHONY: clean clean: rm -rf bin *.log *-kernel *-cmdline *.img *.iso *.tar.gz *.qcow2 *.vhd *.vmx *.vmdk + $(MAKE) -C test clean diff --git a/test/Makefile b/test/Makefile new file mode 100644 index 000000000..d5520efce --- /dev/null +++ b/test/Makefile @@ -0,0 +1,68 @@ +.PHONY: default pr all + +default: check-deps kernel-config +pr: check-deps kernel-config ../artifacts/test.img.tar.gz +all: check-deps kernel-config ltp ../artifacts/test.img.tar.gz ../artifacts/test-ltp.img.tar.gz + +MOBY:=$(shell command -v moby 2> /dev/null) +LINUXKIT:=$(shell command -v linuxkit 2> /dev/null) + +.PHONY: check-deps +check-deps: +ifndef MOBY + $(error "moby is not available. please install it.") +endif +ifndef LINUXKIT + $(error "linuxkit binary not found. please install it.") +endif + +define check_test_log + @cat $1 |grep -q 'test suite PASSED' +endef + +../artifacts: + mkdir -p $@ + +test-kernel-config-initrd.img: $(MOBY) cases/test-kernel-config.yml + $(MOBY) build --pull cases/test-kernel-config.yml + +# uses qemu +.PHONY: kernel-config +kernel-config: $(LINUXKIT) test-kernel-config-initrd.img test-kernel-config-kernel test-kernel-config-cmdline + $(LINUXKIT) run qemu test-kernel-config 2>&1 | tee test.log + $(call check_test_log, test.log) + +# qemu only at this time +.PHONY: qemu-efi +efi: $(LINUXKIT) test-kernel-config-efi.iso + $(LINUXKIT) run qemu -uefi test-kernel-config | tee test-efi.log + $(call check_test_log, test-efi.log) + +# For GCP tests +../artifacts/test.img.tar.gz: test-kernel-config.img.tar.gz | ../artifacts + mv test-kernel-config.img.tar.gz ../artifacts/test.img.tar.gz + +.PHONY: gcp +gcp: export CLOUDSDK_IMAGE_NAME?=test-kernel-config +gcp: $(LINUXKIT) ../test.img.tar.gz + $(LINUXKIT) push gcp ../artifacts/test.img.tar.gz + $(LINUXKIT) run gcp $(CLOUDSDK_IMAGE_NAME) | tee test-gcp.log + $(call check_test_log, test-gcp.log) + +# For LTP tests +test-ltp.img.tar.gz: $(MOBY) cases/test-ltp.yml + $(MOBY) build --pull cases/test-ltp.yml + +../artifacts/test-ltp.img.tar.gz: test-ltp.img.tar.gz | ../artifacts + mv test-ltp.img.tar.gz ../artifacts + +.PHONY: ltp +ltp: export CLOUDSDK_IMAGE_NAME?=test-ltp +ltp: $(LINUXKIT) test-ltp.img.tar.gz + $(LINUXKIT) push gcp ../artifacts/test-ltp.img.tar.gz + $(LINUXKIT) run gcp -skip-cleanup -machine n1-highcpu-4 $(CLOUDSDK_IMAGE_NAME) | tee test-ltp.log + $(call check_test_log, test-ltp.log) + +.PHONY: clean +clean: + rm -rf bin *.log *-kernel *-cmdline *.img *.iso *.tar.gz *.qcow2 *.vhd *.vmx *.vmdk diff --git a/test/docker-bench/test-docker-bench.yml b/test/cases/test-docker-bench.yml similarity index 100% rename from test/docker-bench/test-docker-bench.yml rename to test/cases/test-docker-bench.yml diff --git a/test/test.yml b/test/cases/test-kernel-config.yml similarity index 74% rename from test/test.yml rename to test/cases/test-kernel-config.yml index 4412a9302..a3337cad8 100644 --- a/test/test.yml +++ b/test/cases/test-kernel-config.yml @@ -18,9 +18,14 @@ onboot: - CAP_NET_RAW net: host command: ["/sbin/dhcpcd", "--nobackground", "-f", "/dhcpcd.conf", "-1"] - - name: check - image: "linuxkit/check:43c4147dda4e02d066ef158cd81718dbff8c8bd0" + - name: check-kernel-config + image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c" + readonly: true +services: + - name: poweroff + image: "linuxkit/poweroff:961412b8ef5c5285de0d40ec076701d955eaa084" pid: host + command: ["/bin/sh", "/poweroff.sh", "3"] capabilities: - CAP_SYS_BOOT readonly: true diff --git a/test/ltp/test-ltp.yml b/test/cases/test-ltp.yml similarity index 100% rename from test/ltp/test-ltp.yml rename to test/cases/test-ltp.yml diff --git a/test/virtsock/test-virtsock-server.yml b/test/cases/test-virtsock-server.yml similarity index 100% rename from test/virtsock/test-virtsock-server.yml rename to test/cases/test-virtsock-server.yml diff --git a/test/docker-bench/Dockerfile b/test/pkg/docker-bench/Dockerfile similarity index 100% rename from test/docker-bench/Dockerfile rename to test/pkg/docker-bench/Dockerfile diff --git a/test/docker-bench/Makefile b/test/pkg/docker-bench/Makefile similarity index 100% rename from test/docker-bench/Makefile rename to test/pkg/docker-bench/Makefile diff --git a/test/docker-bench/bench_runner.sh b/test/pkg/docker-bench/bench_runner.sh similarity index 100% rename from test/docker-bench/bench_runner.sh rename to test/pkg/docker-bench/bench_runner.sh diff --git a/test/check/Dockerfile b/test/pkg/kernel-config/Dockerfile similarity index 100% rename from test/check/Dockerfile rename to test/pkg/kernel-config/Dockerfile diff --git a/test/check/Makefile b/test/pkg/kernel-config/Makefile similarity index 96% rename from test/check/Makefile rename to test/pkg/kernel-config/Makefile index de24bfc86..6aa8831a0 100644 --- a/test/check/Makefile +++ b/test/pkg/kernel-config/Makefile @@ -1,7 +1,7 @@ .PHONY: tag push BASE=alpine:3.5 -IMAGE=check +IMAGE=test-kernel-config default: push diff --git a/test/check/check-kernel-config.sh b/test/pkg/kernel-config/check-kernel-config.sh similarity index 100% rename from test/check/check-kernel-config.sh rename to test/pkg/kernel-config/check-kernel-config.sh diff --git a/test/check/check.sh b/test/pkg/kernel-config/check.sh similarity index 84% rename from test/check/check.sh rename to test/pkg/kernel-config/check.sh index b28311d9b..dd37b4239 100755 --- a/test/check/check.sh +++ b/test/pkg/kernel-config/check.sh @@ -2,7 +2,6 @@ function failed { printf "Kernel config test suite FAILED\n" - /sbin/poweroff -f } /check-kernel-config.sh || failed @@ -11,5 +10,3 @@ bash /check-config.sh || failed printf "Kernel config test suite PASSED\n" cat /etc/linuxkit - -/sbin/poweroff -f diff --git a/test/check/etc/linuxkit b/test/pkg/kernel-config/etc/linuxkit similarity index 100% rename from test/check/etc/linuxkit rename to test/pkg/kernel-config/etc/linuxkit diff --git a/test/ltp/.gitignore b/test/pkg/ltp/.gitignore similarity index 100% rename from test/ltp/.gitignore rename to test/pkg/ltp/.gitignore diff --git a/test/ltp/Dockerfile.build b/test/pkg/ltp/Dockerfile.build similarity index 100% rename from test/ltp/Dockerfile.build rename to test/pkg/ltp/Dockerfile.build diff --git a/test/ltp/Dockerfile.pkg b/test/pkg/ltp/Dockerfile.pkg similarity index 100% rename from test/ltp/Dockerfile.pkg rename to test/pkg/ltp/Dockerfile.pkg diff --git a/test/ltp/Makefile b/test/pkg/ltp/Makefile similarity index 100% rename from test/ltp/Makefile rename to test/pkg/ltp/Makefile diff --git a/test/ltp/README.md b/test/pkg/ltp/README.md similarity index 100% rename from test/ltp/README.md rename to test/pkg/ltp/README.md diff --git a/test/ltp/check.sh b/test/pkg/ltp/check.sh similarity index 100% rename from test/ltp/check.sh rename to test/pkg/ltp/check.sh diff --git a/test/poweroff/Dockerfile b/test/pkg/poweroff/Dockerfile similarity index 100% rename from test/poweroff/Dockerfile rename to test/pkg/poweroff/Dockerfile diff --git a/test/poweroff/Makefile b/test/pkg/poweroff/Makefile similarity index 100% rename from test/poweroff/Makefile rename to test/pkg/poweroff/Makefile diff --git a/test/poweroff/poweroff.sh b/test/pkg/poweroff/poweroff.sh similarity index 100% rename from test/poweroff/poweroff.sh rename to test/pkg/poweroff/poweroff.sh diff --git a/test/virtsock/.gitignore b/test/pkg/virtsock/.gitignore similarity index 100% rename from test/virtsock/.gitignore rename to test/pkg/virtsock/.gitignore diff --git a/test/virtsock/Dockerfile b/test/pkg/virtsock/Dockerfile similarity index 100% rename from test/virtsock/Dockerfile rename to test/pkg/virtsock/Dockerfile diff --git a/test/virtsock/Makefile b/test/pkg/virtsock/Makefile similarity index 100% rename from test/virtsock/Makefile rename to test/pkg/virtsock/Makefile diff --git a/test/virtsock/README.md b/test/pkg/virtsock/README.md similarity index 85% rename from test/virtsock/README.md rename to test/pkg/virtsock/README.md index 9b132f87d..7d7f41297 100644 --- a/test/virtsock/README.md +++ b/test/pkg/virtsock/README.md @@ -1,11 +1,11 @@ This directory contains the files to build and run a container containing the -virtio and Hyper-V socket stress tests. `test-virtsock-server.yml` builds images which start the server inside the VM. +virtio and Hyper-V socket stress tests. `../../cases/test-virtsock-server.yml` builds images which start the server inside the VM. The client, to be run on the host as per this [README](https://github.com/rneugeba/virtsock/blob/master/examples/README.md), can be obtained compiled from [here](https://github.com/rneugeba/virtsock). ## How to use (on Windows) -- Build the images: `moby build test-virtsock-server` +- Build the images: `moby build tests/cases/test-virtsock-server.yml` - Copy the `test-virtsock-server.iso` to a Windows system - Create a Type 1 Hyper-V VM (called `virtsock`). - No Disk or network required