forked from lix-project/lix
60ecbd7934
I got sick of trying to find the failures in the sea of debug output, so we now: - Hide test output unless it fails - Sprinkle in some simple color - Pad results for a more tabular look If Nix is getting a more friendly user interface, we might as well get a friendlier developer interface, right? :)
45 lines
1.1 KiB
Makefile
45 lines
1.1 KiB
Makefile
# Run program $1 as part of ‘make installcheck’.
|
||
define run-install-test
|
||
|
||
installcheck: $1
|
||
|
||
_installcheck-list += $1
|
||
|
||
endef
|
||
|
||
# Color code from https://unix.stackexchange.com/a/10065
|
||
installcheck:
|
||
@total=0; failed=0; \
|
||
pad=" "; \
|
||
red=""; \
|
||
green=""; \
|
||
normal=""; \
|
||
if [ -t 1 ]; then \
|
||
ncolors="$$(tput colors)"; \
|
||
if [[ -n "$$ncolors" && $$ncolors -ge 8 ]]; then \
|
||
red="$$(tput setaf 1)"; \
|
||
green="$$(tput setaf 2)"; \
|
||
normal="$$(tput sgr0)"; \
|
||
fi; \
|
||
fi; \
|
||
for i in $(_installcheck-list); do \
|
||
total=$$((total + 1)); \
|
||
printf "running test $$i... $${pad:$${#i}}"; \
|
||
log="$$(cd $$(dirname $$i) && $(tests-environment) $$(basename $$i) 2>&1)"; \
|
||
if [ $$? == 0 ]; then \
|
||
echo "[$${green}PASS$$normal]"; \
|
||
else \
|
||
echo "[$${red}FAIL$$normal]"; \
|
||
echo "$$log" | sed 's/^/ /'; \
|
||
failed=$$((failed + 1)); \
|
||
fi; \
|
||
done; \
|
||
if [ "$$failed" != 0 ]; then \
|
||
echo "$${red}$$failed out of $$total tests failed $$normal"; \
|
||
exit 1; \
|
||
else \
|
||
echo "$${green}All tests succeeded"; \
|
||
fi
|
||
|
||
.PHONY: check installcheck
|