X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=test%2Ftemplate%2FTest.mk;h=13178f60b4cab146b40212a21bb6ea6dd476e50a;hb=ae04e48ee62a95f6f77794d5611db189a19e70de;hp=11b8cbf0cf1dc06e17ff796e495acfdf86ff9bbc;hpb=b28737297c67a30322051100910d2152d7bfb9fd;p=YACASL2.git diff --git a/test/template/Test.mk b/test/template/Test.mk index 11b8cbf..13178f6 100644 --- a/test/template/Test.mk +++ b/test/template/Test.mk @@ -1,7 +1,7 @@ # autotest.mk > test_template > Test.mk # 自動テスト用のMakefile # -# 要: Define.mk Define_test.mk +# 要: Define.mk # # オペレーター # make : CMDの標準出力をTEST1_FILEに保存したあと、TEST0_FILEとの差分を比較し、結果をLOG_FILEに出力 @@ -9,15 +9,14 @@ # make set : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は実行しない # make reset : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は上書き # make time : CMDの実行にかかった時間をTIME_FILEに保存し、出力 -# make cleantime: "make time" で作成されたファイルをクリア +# make time-clean: "make time" で作成されたファイルをクリア +# make valgrind: valgrind CMDの標準出力をVARGRIND_FILEに保存 # make clean : "make" で作成されたファイルをクリア -# make cleanall: "make" と "make set" で作成されたファイルをクリア -SHELL = /bin/bash +# make all-clean: "make" と "make set" で作成されたファイルをクリア ###################################################################### # マクロ ###################################################################### - # 指定されたファイルをチェックし、空の場合は削除 # 引数は、対象ファイル # 用例: $(call rm_null,file_target) @@ -40,6 +39,13 @@ define time_cmd ($(TIME) ./$1 1>$(DEV_NULL) 2>$(DEV_NULL)) 2>&1 | $(GREP) '^real' >$2 endef +# valgrindによるメモリーチェック結果を、指定されたファイルに出力して表示 +# 引数は、テスト名、コマンドファイル、出力ファイル +# 用例: $(call valgrind_cmd,file_cmd,file_out) +define valgrind_cmd + -$(VALGRIND) $(VALGRINDFLAG) $(strip $(shell tail -1 $(CMD_FILE))) 1>/dev/null 2>&1 +endef + # テスト実行コマンド。 # コマンドファイルを実行し、標準出力を指定されたファイルに保存。 # エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。 @@ -49,7 +55,7 @@ define exec_cmd if test ! -x $1; then $(CHMOD) u+x $1; fi ./$1 >>$2 2>$3 if test -s $3; then $(CAT) $3 >>$2; fi - $(MV) $2 $2.tmp && $(SED) -e "s%$(CURRDIR)%\$$PWD%g" $2.tmp >$2 && $(RM) $2.tmp + $(MV) $2 $2.tmp && $(SED) -e "s%$(CURDIR)%\$$PWD%g" $2.tmp >$2 && $(RM) $2.tmp $(call rm_null,$3) endef @@ -67,7 +73,7 @@ endef define test_log $(call desc_log,$3) if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3 - $(ECHO) "Details in $(CURRDIR)/$(DETAIL_FILE)" >>$3 + $(ECHO) "Details in $(CURDIR)/$(DETAIL_FILE)" >>$3 endef # NODISPが設定されていない時は、ログファイルを表示 @@ -97,12 +103,12 @@ define echo_hr endef # テスト名。カレントディレクトリー名から取得 -TEST = $(notdir $(CURRDIR)) +TEST = $(notdir $(CURDIR)) # コマンドファイルのソース CMDSRC_FILE ?= $(CMD_FILE) -.PHONY: check set reset clean cleanall time cleantime +.PHONY: check set reset clean all-clean time time-clean valgrind valgrind-clean check: clean $(DETAIL_FILE) @$(call disp_test_log,$(LOG_FILE)) @@ -116,22 +122,28 @@ set: $(CMD_FILE) @-$(call exec_cmd,$(CMD_FILE),$(TEST0_FILE),$(ERR_FILE)) @$(CAT) $(TEST0_FILE) -reset: cleanall $(CMD_FILE) +reset: all-clean $(CMD_FILE) @-$(call exec_cmd,$(CMD_FILE),$(TEST0_FILE),$(ERR_FILE)) @$(CAT) $(TEST0_FILE) clean: - @$(RM) $(TEST_RES_FILES) + @$(RM) $(TEST_RES_FILES) $(TIME_FILE) $(VALGRIND_FILE) -cleanall: clean +all-clean: clean @$(RM) $(TEST0_FILE) -time: cleantime $(TIME_FILE) +time: time-clean $(TIME_FILE) @$(CAT) $(TIME_FILE) -cleantime: +time-clean: @$(RM) $(TIME_FILE) +valgrind: valgrind-clean $(VALGRIND_FILE) + if test -s $(VALGRIND_FILE); then $(ECHO) $(CURDIR) && $(CAT) $(VALGRIND_FILE); else $(RM) $(VALGRIND_FILE); fi + +valgrind-clean: + @$(RM) $(VALGRIND_FILE) + $(TEST1_FILE): $(CMD_FILE) @-$(call exec_cmd,$^,$@,$(ERR_FILE)) @@ -146,3 +158,6 @@ $(DETAIL_FILE): $(LOG_FILE) $(TIME_FILE): $(CMD_FILE) @$(call time_cmd,$^,$@) + +$(VALGRIND_FILE): $(CMD_FILE) + $(call valgrind_cmd,$^,$@)