X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=test%2FTEST.mk;h=863acd379721f258e3288e11e723fdd6b0406e01;hp=12299d7cc0f61bf5ea6b4b0fe282b5e57ff825f3;hb=8c79c17479ba941bb9cba604143f99137928d52f;hpb=fb54b1c9d2fbc3d4a62c6b4d38ff68e9d3b25c26 diff --git a/test/TEST.mk b/test/TEST.mk index 12299d7..863acd3 100644 --- a/test/TEST.mk +++ b/test/TEST.mk @@ -1,38 +1,29 @@ # テストのテンプレート +# 次の変数を定義する +# CMD: 実行するコマンド +# MAINTARGET_OVERRIDE: メインターゲットを独自に定義し、オーバーライドする # make : CMDで設定されたコマンドを実行した出力結果を1.txtに出力し、0.txtと比較し、レポート -# make all : ↓ # make check : ↓ # make prepare : CMDで設定されたコマンドを実行した出力結果を0.txt(テストの想定結果)に出力 # make clean : 「make」で生成されたファイルをクリア -# make cleanall: 「make」と「make clean」で生成されたファイルをクリア -LOGFILE = ../test.log +# make cleanall: 「make」と「make prepare」で生成されたファイルをクリア ERRFILE = err.txt -CURDIR = `pwd` -define report - @echo -n "`basename $$PWD`: Test " >$@ - @if test ! -s $^; then \ - echo -n "Success " >>$@; \ - rm -f $^; \ - else \ - echo -n "Failure " >>$@; \ - fi - @echo `date +"%F %T"` >>$@ -endef +UNITNAME = `pwd | xargs basename` -.PHPNY: all check prepare clean cleanall logadd -check: clean logadd -all: check +.PHPNY: check prepare clean cleanall +check: clean report.txt prepare: cleanall 0.txt clean: - @rm -f 1.txt diff.txt report.txt + @rm -f 1.txt diff.txt report.txt err.txt cleanall: clean @rm -f 0.txt -0.txt 1.txt: $(CMDFILE) $(OBJFILE) - @$(CMD) >$@ 2>$(ERRFILE); \ +ifndef MAINTARGET_OVERRIDE +0.txt 1.txt: + @echo $(CMD) >$@; \ + $(CMD) >>$@ 2>$(ERRFILE); \ if test -s $(ERRFILE); then cat err.txt >>$@; else rm -f $(ERRFILE); fi +endif diff.txt: 1.txt - @-diff 0.txt 1.txt >$@ 2>&1 + @-diff -c 0.txt 1.txt >$@ 2>&1 report.txt: diff.txt - $(report) -logadd: report.txt - @cat $^ >>$(LOGFILE) + @if test ! -s $^; then echo "$(UNITNAME): Test Success " `date +"%F %T"` >>$@; rm -f $^; else echo "$(UNITNAME): Test Failure " `date +"%F %T"` >>$@; fi; \