X-Git-Url: https://jxself.org/git/?p=open-adventure.git;a=blobdiff_plain;f=tests%2FMakefile;h=0aace2fd3476d2fa3aac17c73a4f6fd7d626e0fb;hp=d200888d70c9aad6fe2b5ac80fc4e886a9228c7d;hb=7b1eb1ec58db038bca2a02dbb7984f85af7a8242;hpb=708d728bb502ab1b97fb798203352484945e152c diff --git a/tests/Makefile b/tests/Makefile index d200888..0aace2f 100644 --- a/tests/Makefile +++ b/tests/Makefile @@ -1,8 +1,5 @@ # Test-suite makefile for reposurgeon -# By setting the REPOSURGEON environment variable and using -e -# a different implementation can be plugged in to the tests. - # Use absolute path so tests that change working directory still use # scripts from parent directory. Note that using $PWD seems to fail # here under Gitlab's CI environment. @@ -11,44 +8,58 @@ PATH := $(realpath ..):$(realpath .):${PATH} # Defeat annoying behavior under Mac OS X - builtin echo doesn't do -n ECHO := /bin/echo -default: - make -e --quiet all - -all: listcheck regress +check: regress @echo "=== No diff output is good news." + @-advent -x 2>/dev/null # Get usage message into coverage tests + @-advent -l /dev/null /dev/null .SUFFIXES: .chk clean: - rm -fr *~ adventure.text adventure.data + rm -fr *~ adventure.text *.adv scratch.tmp # Show summary lines for all tests. testlist: - @grep --text '^##' *.log + @grep '^##' *.log listcheck: @for f in *.log; do \ - if ( head -3 $$f | grep --text -q '^ *##' ); then :; else echo "$$f needs a description"; fi; \ + if ( head -3 $$f | grep -q '^ *##' ); then :; else echo "$$f needs a description"; fi; \ done # General regression testing of commands and output; look at the *.log and # corresponding *.chk files to see which tests this runs. -TESTLOADS := $(shell ls -1 *.log | sed '/.log/s///') -buildregress: adventure.data +TESTLOADS := $(shell ls -1 *.log | sed '/.log/s///' | sort) +buildregress: + $(ECHO) -n "Generate save file with -1000 deaths: " + ../cheat -d -1000 -o cheat_numdie.adv + $(ECHO) -n "Generate save file with version -1337: " + ../cheat -v -1337 -o resume_badversion.adv @for file in $(TESTLOADS); do \ echo "Remaking $${file}.chk"; \ - advent <$${file}.log >$${file}.chk 2>&1 || exit 1; \ - done -regress: adventure.data + OPTS=`sed -n /#options:/s///p <$${file}.log`; \ + advent $$OPTS <$${file}.log >$${file}.chk 2>&1 || exit 1; \ + done; \ + rm -f scratch.tmp +regress: + $(ECHO) -n "Generate save file with -1000 deaths: " + ../cheat -d -1000 -o cheat_numdie.adv + $(ECHO) -n "Generate save file with version -1337: " + ../cheat -v -1337 -o resume_badversion.adv + $(ECHO) -n "Generate save file 1000 saves: " + ../cheat -s -1000 -o thousand_saves.adv + $(ECHO) -n "Bogus option for save file generation: " + ../cheat -QqQ | true + $(ECHO) -n "Fail to save because we omit -o: " + ../cheat -d 1 | true + $(ECHO) -n "Fail to save to invalid path: " + ../cheat -o /badfilename.adv | true @for file in $(TESTLOADS); do \ - $(ECHO) -n " $${file} "; grep --text '##' $${file}.log || echo ' ## (no description)'; \ - if advent < $${file}.log >/tmp/regress$$$$ 2>&1; \ + $(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; \ then diff --text -u $${file}.chk /tmp/regress$$$$ || exit 1; \ else echo "*** Nonzero return status on $${file}!"; exit 1; fi \ - done - @rm -f /tmp/regress$$$$ - -adventure.data: - cp "$(realpath ..)"/adventure.text . - timeout 1 advent >/dev/null 2>&1; true + done; \ + rm -f scratch.tmp /tmp/regress$$$$ # end