# make create : TESTNAMEで指定されたテストを新規に作成
# make clean : すべてのテストで、"make" で生成されたファイルをクリア
# make time-clean: すべてのテストで、実行時間のログファイルをクリア
-
-SHELL = /bin/sh
+# make valgrind: すべてのテストで、valgrindによるメモリリークチェックを実行する
+# make valgrind-clean: すべてのテストで、valgrindのログファイルをクリア
include Define.mk
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
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
+ if $(TEST) -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
$(ECHO) >>$2;
endef
# テストごとの実行時間ファイル
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)
define group_report
$(ECHO) '$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $(GROUP_DIR)/$2' >$3
- if test $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
+ if $(TEST) $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
endef
# リストで指定したディレクトリーでmakeを実行
check checkall: clean $(GROUP_REPORT_FILE)
@$(CAT) $(GROUP_REPORT_FILE)
+ @(if $(TEST) $(FAIL_TEST) -gt 0; then $(GREP) 'Failure' $(GROUP_LOG_FILE); fi)
@exit $(FAIL_TEST)
time: time-clean $(GROUP_TIME_FILE)