SED := sed
TIME := time
TR := tr
+VALGRIND := valgrind
+VALGRINDFLAG := -q --leak-check=full --log-file=valgrind.log
######################################################################
# テストグループとテストでの共通マクロ
# 実行時間ファイル
TIME_FILE := time.log
+# valgrindによるメモリーチェックファイル
+VALGRIND_FILE := valgrind.log
+
# テスト詳細レポートファイル
DETAIL_FILE := detail.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_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
+# テストごとの実行時間ファイル
+TEST_VALGRIND_FILES := $(foreach test,$(TESTS),$(test)/$(VALGRIND_FILE))
+
# テストの結果を、グループログファイルを元にレポート。
# 引数は、グループ名、グループログファイル、グループレポートファイル
# 用例: $(call group_report,name,file_log,file_report)
$(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)
@$(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),$^,$@)
$(TEST_TIME_FILES):
@$(MAKE) time -sC $(dir $@)
+
+$(GROUP_VALGRIND_FILE): $(TEST_VALGRIND_FILES)
+ @$(call group_log,$^,$@)
+
+$(TEST_VALGRIND_FILES):
+ @$(MAKE) time -sC $(dir $@)
@$(CP) $(MAKEFILES) $(GROUPDIR)/
linkmk:
- @$(LN) $(CURDIR)/$(GROUP_MAKEFILE) $(GROUPDIR)/Makefile
+ @$(LN) $(CURRDIR)/$(GROUP_MAKEFILE) $(GROUPDIR)/Makefile
@$(LN) $(MAKEFILES_ABS) $(GROUPDIR)/
# make reset : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は上書き
# make time : CMDの実行にかかった時間をTIME_FILEに保存し、出力
# make time-clean: "make time" で作成されたファイルをクリア
+# make valgrind: valgrind CMDの標準出力をVARGRIND_FILEに保存
# make clean : "make" で作成されたファイルをクリア
# make all-clean: "make" と "make set" で作成されたファイルをクリア
SHELL = /bin/bash
($(TIME) ./$1 1>$(DEV_NULL) 2>$(DEV_NULL)) 2>&1 | $(GREP) '^real' >$2
endef
+# valgrindによるメモリーチェック結果を、指定されたファイルに出力して表示
+# 引数は、テスト名、コマンドファイル、出力ファイル
+# 用例: $(call valgrind_cmd,file_cmd,file_out)
+define valgrind_cmd
+ -$(VALGRIND) $(VALGRINDFLAG) $(strip $(shell tail -1 $(CMD_FILE))) 1>/dev/null 2>&1
+endef
+
# テスト実行コマンド。
# コマンドファイルを実行し、標準出力を指定されたファイルに保存。
# エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
# コマンドファイルのソース
CMDSRC_FILE ?= $(CMD_FILE)
-.PHONY: check set reset clean all-clean time time-clean
+.PHONY: check set reset clean all-clean time time-clean valgrind valgrind-clean
check: clean $(DETAIL_FILE)
@$(call disp_test_log,$(LOG_FILE))
@$(CAT) $(TEST0_FILE)
clean:
- @$(RM) $(TEST_RES_FILES)
+ @$(RM) $(TEST_RES_FILES) $(TIME_FILE) $(VALGRIND_FILE)
all-clean: clean
@$(RM) $(TEST0_FILE)
time-clean:
@$(RM) $(TIME_FILE)
+valgrind: valgrind-clean $(VALGRIND_FILE)
+ if test -s $(VALGRIND_FILE); then $(ECHO) $(CURDIR) && $(CAT) $(VALGRIND_FILE); else $(RM) $(VALGRIND_FILE); fi
+
+valgrind-clean:
+ @$(RM) $(VALGRIND_FILE)
+
$(TEST1_FILE): $(CMD_FILE)
@-$(call exec_cmd,$^,$@,$(ERR_FILE))
$(TIME_FILE): $(CMD_FILE)
@$(call time_cmd,$^,$@)
+
+$(VALGRIND_FILE): $(CMD_FILE)
+ $(call valgrind_cmd,$^,$@)