最新版Autotest.mkを反映
[YACASL2.git] / test / template / Group.mk
index 79bb68b..5a6f8d6 100644 (file)
@@ -9,8 +9,8 @@
 # make create   : TESTNAMEで指定されたテストを新規に作成
 # make clean    : すべてのテストで、"make" で生成されたファイルをクリア
 # make time-clean: すべてのテストで、実行時間のログファイルをクリア
-
-SHELL = /bin/sh
+# make valgrind: すべてのテストで、valgrindによるメモリリークチェックを実行する
+# make valgrind-clean: すべてのテストで、valgrindのログファイルをクリア
 
 include Define.mk
 
@@ -27,7 +27,7 @@ GROUP_DIR := $(CURDIR)
 GROUP := $(notdir $(GROUP_DIR))
 
 # テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
-TESTS = $(notdir $(shell $(FIND) -maxdepth 1 -name "[^A-Z.]*" -type d))
+TESTS := $(notdir $(shell $(FIND) . -maxdepth 1 -name "[^A-Z.]*" -type d))
 
 # テストグループログファイル
 GROUP_LOG_FILE := $(shell $(ECHO) $(GROUP) | $(TR) '[a-z]' '[A-Z]').log
@@ -38,8 +38,11 @@ GROUP_REPORT_FILE := Summary.log
 # テストグループ実行時間ファイル
 GROUP_TIME_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_time.log
 
+# テストグループvalgrindファイル
+GROUP_VALGRIND_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_valgrind.log
+
 # グループで、テスト結果として作成されるファイル群
-GROUP_RES_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE)
+GROUP_RES_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE) $(GROUP_VALGRIND_FILE)
 
 # テストごとのログファイル
 TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
@@ -54,15 +57,13 @@ TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
 define group_log
     $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $(words $1) tests')
     $(foreach target,$1,$(call group_log_each,$(target),$2))
-    $(if $(filter 1,$(verbose)),$(ECHO))
 endef
 
 # テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
 # 用例: $(call group_log_each,file_test_log,file_group_log)
 define group_log_each
-    $(if $(filter 1,$(verbose)),$(ECHO) -n '.')
     $(ECHO) $(dir $1) >>$2;
-    if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
+    if $(TEST) -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
     $(ECHO) >>$2;
 endef
 
@@ -78,12 +79,15 @@ ALL_TEST = $(shell $(EXPR) $(SUCCESS_TEST) + $(FAIL_TEST))
 # テストごとの実行時間ファイル
 TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
 
+# テストごとのvalgrindファイル
+TEST_VALGRIND_FILES := $(foreach test,$(TESTS),$(test)/$(VALGRIND_FILE))
+
 # テストの結果を、グループログファイルを元にレポート。
 # 引数は、グループ名、グループログファイル、グループレポートファイル
 # 用例: $(call group_report,name,file_log,file_report)
 define group_report
     $(ECHO) '$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $(GROUP_DIR)/$2' >$3
-    if test $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
+    if $(TEST) $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
 endef
 
 # リストで指定したディレクトリーでmakeを実行
@@ -99,10 +103,11 @@ define make_target_each
     $(MAKE) $2 -sC $1;
 endef
 
-.PHONY: check checkall time create clean time-clean
+.PHONY: check checkall time valgrind create clean time-clean valgrind-clean
 
 check checkall: clean $(GROUP_REPORT_FILE)
        @$(CAT) $(GROUP_REPORT_FILE)
+       @(if $(TEST) $(FAIL_TEST) -gt 0; then $(GREP) 'Failure' $(GROUP_LOG_FILE); fi)
        @exit $(FAIL_TEST)
 
 time: time-clean $(GROUP_TIME_FILE)
@@ -120,6 +125,14 @@ time-clean:
        @$(call make_targets,$(TESTS),$@)
        @$(RM) $(GROUP_TIME_FILE);
 
+valgrind:
+       @$(call make_targets,$(TESTS),$@)
+       @$(RM) $(GROUP_RES_FILES);
+
+valgrind-clean:
+       @$(call make_targets,$(TESTS),$@)
+       @$(RM) $(GROUP_VALGRIND_FILE);
+
 $(GROUP_REPORT_FILE): $(GROUP_LOG_FILE)
        @$(call group_report,$(GROUP),$^,$@)
 
@@ -134,3 +147,9 @@ $(GROUP_TIME_FILE): $(TEST_TIME_FILES)
 
 $(TEST_TIME_FILES):
        @$(MAKE) time -sC $(dir $@)
+
+$(GROUP_VALGRIND_FILE): $(TEST_VALGRIND_FILES)
+       @$(call group_log,$^,$@)
+
+$(TEST_VALGRIND_FILES):
+       @$(MAKE) time -sC $(dir $@)