テスト(Autotest.mk)に、Valgrindによるメモリーチェック機能を追加
authorj8takagi <j8takagi@nifty.com>
Wed, 13 Feb 2013 13:40:59 +0000 (22:40 +0900)
committerj8takagi <j8takagi@nifty.com>
Wed, 13 Feb 2013 13:40:59 +0000 (22:40 +0900)
test/template/Define.mk
test/template/Group.mk
test/template/Makefile
test/template/Test.mk

index e736c50..bb55bd4 100644 (file)
@@ -30,6 +30,8 @@ MV := mv
 SED := sed
 TIME := time
 TR := tr
+VALGRIND := valgrind
+VALGRINDFLAG :=  -q --leak-check=full --log-file=valgrind.log
 
 ######################################################################
 # テストグループとテストでの共通マクロ
@@ -126,6 +128,9 @@ LOG_FILE := summary.log
 # 実行時間ファイル
 TIME_FILE := time.log
 
+# valgrindによるメモリーチェックファイル
+VALGRIND_FILE := valgrind.log
+
 # テスト詳細レポートファイル
 DETAIL_FILE := detail.log
 
index 79bb68b..be569aa 100644 (file)
@@ -38,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))
@@ -78,6 +81,9 @@ ALL_TEST = $(shell $(EXPR) $(SUCCESS_TEST) + $(FAIL_TEST))
 # テストごとの実行時間ファイル
 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)
@@ -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 $@)
index e88f17a..d5acfb9 100644 (file)
@@ -28,5 +28,5 @@ copymk:
        @$(CP) $(MAKEFILES) $(GROUPDIR)/
 
 linkmk:
-       @$(LN) $(CURDIR)/$(GROUP_MAKEFILE) $(GROUPDIR)/Makefile
+       @$(LN) $(CURRDIR)/$(GROUP_MAKEFILE) $(GROUPDIR)/Makefile
        @$(LN) $(MAKEFILES_ABS) $(GROUPDIR)/
index e72ba6d..56c0766 100644 (file)
@@ -10,6 +10,7 @@
 # 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
@@ -40,6 +41,13 @@ define time_cmd
     ($(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
+
 # テスト実行コマンド。
 # コマンドファイルを実行し、標準出力を指定されたファイルに保存。
 # エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
@@ -102,7 +110,7 @@ TEST = $(notdir $(CURDIR))
 # コマンドファイルのソース
 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))
@@ -121,7 +129,7 @@ reset: all-clean $(CMD_FILE)
        @$(CAT) $(TEST0_FILE)
 
 clean:
-       @$(RM) $(TEST_RES_FILES)
+       @$(RM) $(TEST_RES_FILES) $(TIME_FILE) $(VALGRIND_FILE)
 
 all-clean: clean
        @$(RM) $(TEST0_FILE)
@@ -132,6 +140,12 @@ time: time-clean $(TIME_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))
 
@@ -146,3 +160,6 @@ $(DETAIL_FILE): $(LOG_FILE)
 
 $(TIME_FILE): $(CMD_FILE)
        @$(call time_cmd,$^,$@)
+
+$(VALGRIND_FILE): $(CMD_FILE)
+       $(call valgrind_cmd,$^,$@)