mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-27 05:20:50 +00:00
tests/tcg: add run, diff, and skip helper macros
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>
This commit is contained in:
parent
8ba0a8206a
commit
607bf9b5a5
@ -34,6 +34,15 @@
|
||||
|
||||
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)
|
||||
|
@ -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)
|
||||
|
@ -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
|
||||
|
@ -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)
|
||||
|
@ -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)")
|
||||
|
Loading…
Reference in New Issue
Block a user