X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=test%2Ftemplate%2FGroup.mk;h=ba47088d177bcbe3d722cb4a29bf24c2b00b791b;hb=20c59ff39f0c752e0885fa0406ab9b93c5f147b9;hp=01d5a278fff4309cdca0c8719ad6e3bddc05c80a;hpb=b28737297c67a30322051100910d2152d7bfb9fd;p=YACASL2.git diff --git a/test/template/Group.mk b/test/template/Group.mk index 01d5a27..ba47088 100644 --- a/test/template/Group.mk +++ b/test/template/Group.mk @@ -8,18 +8,20 @@ # make time : すべてのテストを実行し、実行時間をログファイルに出力 # make create : TESTNAMEで指定されたテストを新規に作成 # make clean : すべてのテストで、"make" で生成されたファイルをクリア -# make cleantime: すべてのテストで、実行時間のログファイルをクリア +# make time-clean: すべてのテストで、実行時間のログファイルをクリア SHELL = /bin/sh include Define.mk +verbose ?= 1 + ###################################################################### # テストグループのディレクトリー ###################################################################### # グループディレクトリー -GROUP_DIR := $(CURRDIR) +GROUP_DIR := $(CURDIR) # グループ名。ディレクトリ名から取得 GROUP := $(notdir $(GROUP_DIR)) @@ -36,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)) @@ -50,16 +55,18 @@ TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE)) # 引数は、テストのリスト、グループファイル、テストファイル # 用例: $(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)) + $(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 $(ECHO) >>$2; - endef # 成功したテストの数。テストグループログファイルから取得 @@ -74,33 +81,37 @@ 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 +# 用例: $(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: @@ -108,12 +119,20 @@ create: @$(call create_makefile,$(TEST)/$(MAKEFILE),$(MAKEFILES)) clean: - @$(call make_tests,$(TESTS),$@) - @$(RM) $(GROUP_RES_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),$^,$@) @@ -129,3 +148,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 $@)