projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
メモリーリークの修正
[YACASL2.git]
/
test
/
template
/
Test.mk
diff --git
a/test/template/Test.mk
b/test/template/Test.mk
index
11b8cbf
..
13178f6
100644
(file)
--- a/
test/template/Test.mk
+++ b/
test/template/Test.mk
@@
-1,7
+1,7
@@
# autotest.mk > test_template > Test.mk
# 自動テスト用のMakefile
#
# autotest.mk > test_template > Test.mk
# 自動テスト用のMakefile
#
-# 要: Define.mk
Define_test.mk
+# 要: Define.mk
#
# オペレーター
# make : CMDの標準出力をTEST1_FILEに保存したあと、TEST0_FILEとの差分を比較し、結果をLOG_FILEに出力
#
# オペレーター
# 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 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 clean : "make" で作成されたファイルをクリア
-# make cleanall: "make" と "make set" で作成されたファイルをクリア
-SHELL = /bin/bash
+# make all-clean: "make" と "make set" で作成されたファイルをクリア
######################################################################
# マクロ
######################################################################
######################################################################
# マクロ
######################################################################
-
# 指定されたファイルをチェックし、空の場合は削除
# 引数は、対象ファイル
# 用例: $(call rm_null,file_target)
# 指定されたファイルをチェックし、空の場合は削除
# 引数は、対象ファイル
# 用例: $(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
($(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
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%$(CUR
R
DIR)%\$$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
$(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
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 $(CUR
R
DIR)/$(DETAIL_FILE)" >>$3
+ $(ECHO) "Details in $(CURDIR)/$(DETAIL_FILE)" >>$3
endef
# NODISPが設定されていない時は、ログファイルを表示
endef
# NODISPが設定されていない時は、ログファイルを表示
@@
-97,12
+103,12
@@
define echo_hr
endef
# テスト名。カレントディレクトリー名から取得
endef
# テスト名。カレントディレクトリー名から取得
-TEST = $(notdir $(CUR
R
DIR))
+TEST = $(notdir $(CURDIR))
# コマンドファイルのソース
CMDSRC_FILE ?= $(CMD_FILE)
# コマンドファイルのソース
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))
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)
@-$(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:
@-$(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)
@$(RM) $(TEST0_FILE)
-time:
cleantime
$(TIME_FILE)
+time:
time-clean
$(TIME_FILE)
@$(CAT) $(TIME_FILE)
@$(CAT) $(TIME_FILE)
-
cleantime
:
+
time-clean
:
@$(RM) $(TIME_FILE)
@$(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))
$(TEST1_FILE): $(CMD_FILE)
@-$(call exec_cmd,$^,$@,$(ERR_FILE))
@@
-146,3
+158,6
@@
$(DETAIL_FILE): $(LOG_FILE)
$(TIME_FILE): $(CMD_FILE)
@$(call time_cmd,$^,$@)
$(TIME_FILE): $(CMD_FILE)
@$(call time_cmd,$^,$@)
+
+$(VALGRIND_FILE): $(CMD_FILE)
+ $(call valgrind_cmd,$^,$@)