From 18bf4a0b8712e3a0caba0f3ded5abe16c190f528 Mon Sep 17 00:00:00 2001 From: j8takagi Date: Tue, 1 Oct 2013 19:01:20 +0900 Subject: [PATCH] =?utf8?q?make=20valgrind=E3=81=AB=E3=82=88=E3=82=8B?= =?utf8?q?=E3=83=A1=E3=83=A2=E3=83=AA=E3=83=AA=E3=83=BC=E3=82=AF=E3=83=81?= =?utf8?q?=E3=82=A7=E3=83=83=E3=82=AF=E6=A9=9F=E8=83=BD=E3=82=92=E8=BF=BD?= =?utf8?q?=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit --- template/Define.mk | 5 +++++ template/Group.mk | 26 ++++++++++++++++++++++++-- template/Test.mk | 21 +++++++++++++++++++-- 3 files changed, 48 insertions(+), 4 deletions(-) diff --git a/template/Define.mk b/template/Define.mk index e736c50..bb55bd4 100644 --- a/template/Define.mk +++ b/template/Define.mk @@ -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 diff --git a/template/Group.mk b/template/Group.mk index 79bb68b..238e48b 100644 --- a/template/Group.mk +++ b/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 @@ -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)) @@ -78,6 +83,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 +107,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 +128,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 +150,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 $@) diff --git a/template/Test.mk b/template/Test.mk index e72ba6d..56c0766 100644 --- a/template/Test.mk +++ b/template/Test.mk @@ -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,$^,$@) -- 2.18.0