BSD findで動作するように修正
[autotest_mk.git] / template / Group.mk
index 2214574..fa222d9 100644 (file)
 # テストグループのMakefile
 #
 # オペレーター
-# make         : すべてのテストを実施し、ログファイルを作成
-# make check   : ↓
-# make create  : TESTNAMEで指定されたテストを新規に作成
-# make set     : すべてのテストの、想定結果を出力
-# make checkeach: すべてのテストを実施
-# make report  : ログファイルから、テストの結果をレポート
-# make clean   : すべてのテストで、"make" で生成されたファイルをクリア
-# make cleanall: すべてのテストで、"make" と "make set" で生成されたファイルをクリア
+# make          : すべてのテストを実行し、結果をログファイルに出力
+# make check    : ↓
+# make checkall : すべてのテストを実行し、結果と実行時間をログファイルに出力
+# make time     : すべてのテストを実行し、実行時間をログファイルに出力
+# make create   : TESTNAMEで指定されたテストを新規に作成
+# make clean    : すべてのテストで、"make" で生成されたファイルをクリア
+# make time-clean: すべてのテストで、実行時間のログファイルをクリア
+# make valgrind: すべてのテストで、valgrindによるメモリリークチェックを実行する
+# make valgrind-clean: すべてのテストで、valgrindのログファイルをクリア
 
 SHELL = /bin/sh
 
+include Define.mk
+
+verbose ?= 1
+
 ######################################################################
-# テストグループの定義
+# テストグループのディレクトリー
 ######################################################################
 
-include Define.mk
-
 # グループディレクトリー
-GROUP_DIR := $(shell pwd)
+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
+GROUP_LOG_FILE := $(shell $(ECHO) $(GROUP) | $(TR) '[a-z]' '[A-Z]').log
 
 # テストグループレポートファイル
-GROUP_REPORT_FILE := Report.log
+GROUP_REPORT_FILE := Summary.log
 
 # テストグループ実行時間ファイル
-GROUP_TIME_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]')_time.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_TEMP_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))
 
-# 指定したディレクトリーを作成
-# 用例: $(call create_dir,name)
-define create_dir
-    $(call chk_var_null,$1)
-    $(call chk_file_ext,$1)
-    $(MKDIR) $1
-endef
-
-# テストごとのMakefileを作成
-# 用例: $(call create_makefile,file)
-define create_makefile
-    $(RM) $1
-    $(foreach mkfile,$(DEF_FILE) $(TEST_MAKEFILE),$(ECHO) "include ../$(mkfile)" >>$1; )
-endef
+######################################################################
+# テストグループのマクロ
+######################################################################
 
 # テストごとのファイルをグループファイルに出力
 # 引数は、テストのリスト、グループファイル、テストファイル
 # 用例: $(call group_log,files_test_log,file_group_log)
 define group_log
+    $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $(words $1) tests')
     $(foreach target,$1,$(call group_log_each,$(target),$2))
 endef
 
 # テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
 # 用例: $(call group_log_each,file_test_log,file_group_log)
 define group_log_each
+    $(ECHO) $(dir $1) >>$2;
     if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
-    echo >>$2;
-
+    $(ECHO) >>$2;
 endef
 
 # 成功したテストの数。テストグループログファイルから取得
-SUCCESS_TEST = $(shell grep "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | wc -l)
+SUCCESS_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | $(LINECOUNT))
 
 # 失敗したテストの数。テストグループログファイルから取得
-FAIL_TEST = $(shell grep "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | wc -l)
+FAIL_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | $(LINECOUNT))
 
 # すべてのテストの数
-ALL_TEST = $(shell expr $(SUCCESS_TEST) + $(FAIL_TEST))
+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;
+    $(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
 endef
 
 # リストで指定したディレクトリーでmakeを実行
-# 用例: $(call make_tests,list_dir,target)
-define make_tests
-    $(foreach dir,$1,$(call make_test_each,$(dir),$2))
+# 用例: $(call make_targets,list_dir,target)
+define make_targets
+    $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $2';)
+    $(foreach dir,$1,$(call make_target_each,$(dir),$2))
 endef
 
-# 指定したディレクトリーでMakeを実行
-# 用例: $(call make_test_each,tests,target)
-define make_test_each
+# 指定したディレクトリーでmakeを実行
+# 用例: $(call make_target_each,tests,target)
+define make_target_each
     $(MAKE) $2 -sC $1;
-
 endef
 
-######################################################################
-# ターゲット
-######################################################################
-
-.PHONY: check checkall time create clean cleantime
+.PHONY: check checkall time valgrind create clean time-clean valgrind-clean
 
 check checkall: clean $(GROUP_REPORT_FILE)
        @$(CAT) $(GROUP_REPORT_FILE)
+       @exit $(FAIL_TEST)
 
-time: cleantime $(GROUP_TIME_FILE)
+time: time-clean $(GROUP_TIME_FILE)
        @$(CAT) $(GROUP_TIME_FILE)
 
 create:
        @$(call create_dir,$(TEST))
-       @$(call create_makefile,$(TEST)/$(MAKEFILE))
+       @$(call create_makefile,$(TEST)/$(MAKEFILE),$(MAKEFILES))
 
 clean:
-       @$(call make_tests,$(TESTS),$@)
-       @$(RM) $(GROUP_TEMP_FILES)
+       @$(call make_targets,$(TESTS),$@)
+       @$(RM) $(GROUP_RES_FILES);
+
+time-clean:
+       @$(call make_targets,$(TESTS),$@)
+       @$(RM) $(GROUP_TIME_FILE);
 
-cleantime:
-       @$(call make_tests,$(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),$^,$@)
@@ -137,10 +141,16 @@ $(GROUP_LOG_FILE): $(TEST_LOG_FILES)
        @$(call group_log,$^,$@)
 
 $(TEST_LOG_FILES):
-       @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@)
+       @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@) NODISP=1
 
 $(GROUP_TIME_FILE): $(TEST_TIME_FILES)
        @$(call group_log,$^,$@)
 
 $(TEST_TIME_FILES):
        @$(MAKE) time -sC $(dir $@)
+
+$(GROUP_VALGRIND_FILE): $(TEST_VALGRIND_FILES)
+       @$(call group_log,$^,$@)
+
+$(TEST_VALGRIND_FILES):
+       @$(MAKE) time -sC $(dir $@)