X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=test%2Ftemplate%2FGroup.mk;h=fc6939138e1ae93e46952d8295c224f230c6621d;hb=df3941c7355d0427cbf9f869802400b0cf05e27f;hp=79bb68b4c630eae463c3133cd6e34a79e55aa5c8;hpb=e7a3adce53223b35b7a30b4ac587f9415b8b61f5;p=YACASL2.git diff --git a/test/template/Group.mk b/test/template/Group.mk index 79bb68b..fc69391 100644 --- a/test/template/Group.mk +++ b/test/template/Group.mk @@ -9,6 +9,8 @@ # make create : TESTNAMEで指定されたテストを新規に作成 # make clean : すべてのテストで、"make" で生成されたファイルをクリア # make time-clean: すべてのテストで、実行時間のログファイルをクリア +# make valgrind: すべてのテストで、valgrindによるメモリリークチェックを実行する +# make valgrind-clean: すべてのテストで、valgrindのログファイルをクリア SHELL = /bin/sh @@ -27,7 +29,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 +40,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,13 +59,11 @@ 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 $(ECHO) >>$2; @@ -78,6 +81,9 @@ 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) @@ -99,7 +105,7 @@ 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) @@ -120,6 +126,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 +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 $@)