Reduce test makefile verbosity under Emacs.

This commit is contained in:
Eric S. Raymond 2017-07-05 04:35:58 -04:00
parent c35cf99966
commit 3b64fb3bfd

View file

@ -6,6 +6,9 @@
PATH := $(realpath ..):$(realpath .):${PATH}
GCOV?=gcov
# Make this overrideable so it's easier to test old versions
advent?=advent
# Defeat annoying behavior under Mac OS X - builtin echo doesn't do -n
ECHO := /bin/echo
@ -39,17 +42,17 @@ listcheck:
# Generate bogus savegames.
savegames:
$(ECHO) "cheat: Generate save file with -1000 deaths"
../cheat -d -1000 -o cheat_numdie.adv > /tmp/cheat_numdie
$(ECHO) "cheat: Generate save file with version -1337"
../cheat -v -1337 -o resume_badversion.adv > /tmp/cheat_badversion
$(ECHO) "cheat: Generate save file 1000 saves"
../cheat -s -1000 -o thousand_saves.adv > /tmp/cheat_1000saves
$(ECHO) "cheat: Generate save file 1000 turns"
../cheat -t -1000 -o thousand_saves.adv > /tmp/cheat_1000turns
$(ECHO) "cheat: Generate save file 1000 turns"
../cheat -l -1000 -o thousand_lamp.adv > /tmp/cheat_1000lamp
rm -f /tmp/cheat*
@$(ECHO) "cheat: Generate save file with -1000 deaths"
@../cheat -d -1000 -o cheat_numdie.adv > /tmp/cheat_numdie
@$(ECHO) "cheat: Generate save file with version -1337"
@../cheat -v -1337 -o resume_badversion.adv > /tmp/cheat_badversion
@$(ECHO) "cheat: Generate save file 1000 saves"
@../cheat -s -1000 -o thousand_saves.adv > /tmp/cheat_1000saves
@$(ECHO) "cheat: Generate save file 1000 turns"
@../cheat -t -1000 -o thousand_saves.adv > /tmp/cheat_1000turns
@$(ECHO) "cheat: Generate save file 1000 turns"
@../cheat -l -1000 -o thousand_lamp.adv > /tmp/cheat_1000lamp
@rm -f /tmp/cheat*
# Rebuild characterizing tests
@ -63,21 +66,21 @@ buildregress: savegames
rm -f scratch.tmp
savecheck: savegames
$(ECHO) "TEST cheat: Bogus option for save file generation"
../cheat -QqQ 2> /tmp/coverage_cheat_batopt | true
$(ECHO) "TEST cheat: No save file specified"
../cheat 2>/dev/null | true
$(ECHO) "TEST cheat: Fail to save because we omit -o"
../cheat -d 1 2> /tmp/coverage_cheat_nooutput | true
$(ECHO) "TEST cheat: Fail to save to invalid path"
../cheat -o / 2> /tmp/coverage_cheat_badoutput | true
$(ECHO) "TEST advent: Start with invalid file with -r"
advent -r /badfilename < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1
$(ECHO) "TEST advent: Start with invalid file with -r"
advent -l / < pitfall.log > /tmp/coverage_advent_logfail 2>&1 || exit 1
$(ECHO) "TEST advent: Test -r with valid input"
advent -r thousand_saves.adv < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1
rm -f /tmp/coverage*
@$(ECHO) "TEST cheat: Bogus option for save file generation"
@../cheat -QqQ 2> /tmp/coverage_cheat_batopt | true
@$(ECHO) "TEST cheat: No save file specified"
@../cheat 2>/dev/null | true
@$(ECHO) "TEST cheat: Fail to save because we omit -o"
@../cheat -d 1 2> /tmp/coverage_cheat_nooutput | true
@$(ECHO) "TEST cheat: Fail to save to invalid path"
@../cheat -o / 2> /tmp/coverage_cheat_badoutput | true
@$(ECHO) "TEST advent: Start with invalid file with -r"
@advent -r /badfilename < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1
@$(ECHO) "TEST advent: Start with invalid file with -r"
@advent -l / < pitfall.log > /tmp/coverage_advent_logfail 2>&1 || exit 1
@$(ECHO) "TEST advent: Test -r with valid input"
@advent -r thousand_saves.adv < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1
@rm -f /tmp/coverage*
# General regression testing of commands and output; look at the *.log and
# corresponding *.chk files to see which tests this runs.
@ -85,7 +88,7 @@ regress:
@for file in $(TESTLOADS); do \
$(ECHO) -n " $${file} "; grep '##' $${file}.log || echo ' ## (no description)'; \
OPTS=`sed -n /#options:/s///p <$${file}.log`; \
if advent $$OPTS < $${file}.log >/tmp/regress$$$$ 2>&1; \
if $(advent) $$OPTS < $${file}.log >/tmp/regress$$$$ 2>&1; \
then diff --text -u $${file}.chk /tmp/regress$$$$ || exit 1; \
else echo "*** Nonzero return status on $${file}!"; exit 1; fi \
done; \