projects
/
YACASL2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Doxygenの対応バージョンを1.8.7に変更
[YACASL2.git]
/
test
/
template
/
Group.mk
diff --git
a/test/template/Group.mk
b/test/template/Group.mk
index
79bb68b
..
fc69391
100644
(file)
--- a/
test/template/Group.mk
+++ b/
test/template/Group.mk
@@
-9,6
+9,8
@@
# make create : TESTNAMEで指定されたテストを新規に作成
# make clean : すべてのテストで、"make" で生成されたファイルをクリア
# make time-clean: すべてのテストで、実行時間のログファイルをクリア
# make create : TESTNAMEで指定されたテストを新規に作成
# make clean : すべてのテストで、"make" で生成されたファイルをクリア
# make time-clean: すべてのテストで、実行時間のログファイルをクリア
+# make valgrind: すべてのテストで、valgrindによるメモリリークチェックを実行する
+# make valgrind-clean: すべてのテストで、valgrindのログファイルをクリア
SHELL = /bin/sh
SHELL = /bin/sh
@@
-27,7
+29,7
@@
GROUP_DIR := $(CURDIR)
GROUP := $(notdir $(GROUP_DIR))
# テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
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
@@
-38,8
+40,11
@@
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_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))
# テストごとのログファイル
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))
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
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;
$(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))
# テストごとの実行時間ファイル
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)
# テストの結果を、グループログファイルを元にレポート。
# 引数は、グループ名、グループログファイル、グループレポートファイル
# 用例: $(call group_report,name,file_log,file_report)
@@
-99,7
+105,7
@@
define make_target_each
$(MAKE) $2 -sC $1;
endef
$(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)
check checkall: clean $(GROUP_REPORT_FILE)
@$(CAT) $(GROUP_REPORT_FILE)
@@
-120,6
+126,14
@@
time-clean:
@$(call make_targets,$(TESTS),$@)
@$(RM) $(GROUP_TIME_FILE);
@$(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),$^,$@)
$(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 $@)
$(TEST_TIME_FILES):
@$(MAKE) time -sC $(dir $@)
+
+$(GROUP_VALGRIND_FILE): $(TEST_VALGRIND_FILES)
+ @$(call group_log,$^,$@)
+
+$(TEST_VALGRIND_FILES):
+ @$(MAKE) time -sC $(dir $@)