]> xenbits.xensource.com Git - qemu-xen-unstable.git/commitdiff
tests/tcg: add run, diff, and skip helper macros
authorAlex Bennée <alex.bennee@linaro.org>
Mon, 21 May 2018 09:38:37 +0000 (10:38 +0100)
committerAlex Bennée <alex.bennee@linaro.org>
Wed, 20 Jun 2018 19:22:34 +0000 (20:22 +0100)
As we aren't using the default runners for all the test cases it is
easy to miss out things like timeouts. To help with this we add some
helpers and use them so we only need to make core changes in one
place.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
tests/tcg/Makefile
tests/tcg/aarch64/Makefile.target
tests/tcg/arm/Makefile.target
tests/tcg/i386/Makefile.target
tests/tcg/multiarch/Makefile.target

index e7dbcdb5bfc3c72dfa6e34b27c3285ffdcdbc81b..bf064153900a438e4ad8e2d79eaaac8a27d66062 100644 (file)
 
 quiet-command = $(if $(V),$1,$(if $(2),@printf "  %-7s %s\n" $2 $3 && $1, @$1))
 
+# $1 = test name, $2 = cmd, $3 = desc
+run-test = $(call quiet-command, timeout $(TIMEOUT) $2 > $1.out,"TEST",$3)
+
+# $1 = test name, $2 = reference
+diff-out = $(call quiet-command, diff -u $1.out $2 | head -n 10,"DIFF","$1.out with $2")
+
+# $1 = test name, $2 = reason
+skip-test = @printf "  SKIPPED %s on $(TARGET_NAME) because %s\n" $1 $2
+
 # Tests we are building
 TESTS=
 
@@ -84,9 +93,7 @@ RUN_TESTS=$(patsubst %,run-%, $(TESTS))
 RUN_TESTS+=$(EXTRA_RUNS)
 
 run-%: %
-       $(call quiet-command, \
-               timeout $(TIMEOUT) $(QEMU) $< > $<.out, \
-               "TEST", "$< on $(TARGET_NAME)")
+       $(call run-test, $<, $(QEMU) $<, "$< on $(TARGET_NAME)")
 
 .PHONY: run
 run: $(RUN_TESTS)
index 7dba32138d891b3bd8e906428275cc398b9703ee..08c45b8470c382a28d811fbf458d8414a99f4152 100644 (file)
@@ -13,7 +13,5 @@ TESTS:=$(AARCH64_TESTS)
 fcvt: LDFLAGS+=-lm
 
 run-fcvt: fcvt
-       $(call quiet-command, \
-               $(QEMU) $< > fcvt.out && \
-               diff -u $(AARCH64_SRC)/fcvt.ref fcvt.out, \
-               "TEST", "$< (default) on $(TARGET_NAME)")
+       $(call run-test,$<,$(QEMU) $<, "$< on $(TARGET_NAME)")
+       $(call diff-out,$<,$(AARCH64_SRC)/fcvt.ref)
index 14b5435fc6abdf4cc3b19ae12a11982e1595f5d4..aa4e4e3782c9a6ea3858d4cfd6f6338a72e4f1e8 100644 (file)
@@ -24,10 +24,8 @@ fcvt: LDFLAGS+=-lm
 # fcvt: CFLAGS+=-march=armv8.2-a+fp16 -mfpu=neon-fp-armv8
 
 run-fcvt: fcvt
-       $(call quiet-command, \
-               $(QEMU) $< > fcvt.out && \
-               diff -u $(ARM_SRC)/fcvt.ref fcvt.out, \
-               "TEST", "$< (default) on $(TARGET_NAME)")
+       $(call run-test,fcvt,$(QEMU) $<,"$< on $(TARGET_NAME)")
+       $(call diff-out,fcvt,$(ARM_SRC)/fcvt.ref)
 endif
 
 # On ARM Linux only supports 4k pages
index cd173363eee9fc59c656d6ebda018f607ba4f701..97b7c23cf118bd1d4a0e0e9cc4a9d2009bb6c29f 100644 (file)
@@ -31,7 +31,7 @@ test-i386: test-i386.c test-i386-code16.S test-i386-vm86.S test-i386.h test-i386
 
 # Specialist test runners
 run-runcom: runcom pi_10.com
-       $(call quiet-command, $(QEMU) ./runcom $(I386_SRC)/pi_10.com > runcom.out, "TEST", "$< on $(TARGET_NAME)")
+       $(call run-test,$<,$(QEMU) ./runcom $(I386_SRC)/pi_10.com,"$< on $(TARGET_NAME)")
 
 ifeq ($(SPEED), slow)
 
@@ -40,13 +40,11 @@ test-i386-fprem.ref: test-i386-fprem
 
 run-test-i386-fprem: TIMEOUT=60
 run-test-i386-fprem: test-i386-fprem
-       $(call quiet-command, \
-               $(QEMU) $< > $<.out && \
-               diff -u $(I386_SRC)/$<.ref $<.out, \
-               "TEST", "$< (default) on $(TARGET_NAME)")
+       $(call run-test,test-i386-fprem, $(QEMU) $<,"$< on $(TARGET_NAME)")
+       $(call diff-out,test-i386-fprem, $(I386_SRC)/$<.ref)
 else
 run-test-i386-fprem: test-i386-fprem
-       $(call quiet-command, /bin/true, "SLOW TEST", "$< SKIPPED on $(TARGET_NAME)")
+       $(call skip-test, $<, "SLOW")
 endif
 
 # On i386 and x86_64 Linux only supports 4k pages (large pages are a different hack)
index 90e45a881e637ae4a2813d8a815c4e5330917417..b77084c146095009b132db29d53ba4b9974e8f8f 100644 (file)
@@ -27,10 +27,10 @@ testthread: LDFLAGS+=-lpthread
 
 # default case (host page size)
 run-test-mmap: test-mmap
-       $(call quiet-command, $(QEMU) $< > test-mmap.out, "TEST", \
+       $(call run-test, test-mmap, $(QEMU) $<, \
                "$< (default) on $(TARGET_NAME)")
 
 # additional page sizes (defined by each architecture adding to EXTRA_RUNS)
 run-test-mmap-%: test-mmap
-       $(call quiet-command, $(QEMU) -p $* $< > test-mmap-$*.out, "TEST", \
+       $(call run-test, test-mmap-$*, $(QEMU) -p $* $<,\
                "$< ($* byte pages) on $(TARGET_NAME)")