1 # autotest.mk > template > Group.mk
5 # make : すべてのテストを実行し、結果をログファイルに出力
7 # make checkall : すべてのテストを実行し、結果と実行時間をログファイルに出力
8 # make time : すべてのテストを実行し、実行時間をログファイルに出力
9 # make create : TESTNAMEで指定されたテストを新規に作成
10 # make clean : すべてのテストで、"make" で生成されたファイルをクリア
11 # make time-clean: すべてのテストで、実行時間のログファイルをクリア
19 ######################################################################
21 ######################################################################
24 GROUP_DIR := $(CURDIR)
27 GROUP := $(notdir $(GROUP_DIR))
29 # テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
30 TESTS = $(notdir $(shell $(FIND) -maxdepth 1 -name "[^A-Z.]*" -type d))
33 GROUP_LOG_FILE := $(shell $(ECHO) $(GROUP) | $(TR) '[a-z]' '[A-Z]').log
36 GROUP_REPORT_FILE := Summary.log
39 GROUP_TIME_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_time.log
42 GROUP_VALGRIND_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_valgrind.log
44 # グループで、テスト結果として作成されるファイル群
45 GROUP_RES_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE) $(GROUP_VALGRIND_FILE)
48 TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
50 ######################################################################
52 ######################################################################
54 # テストごとのファイルをグループファイルに出力
55 # 引数は、テストのリスト、グループファイル、テストファイル
56 # 用例: $(call group_log,files_test_log,file_group_log)
58 $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $(words $1) tests')
59 $(foreach target,$1,$(call group_log_each,$(target),$2))
60 $(if $(filter 1,$(verbose)),$(ECHO))
63 # テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
64 # 用例: $(call group_log_each,file_test_log,file_group_log)
66 $(if $(filter 1,$(verbose)),$(ECHO) -n '.')
67 $(ECHO) $(dir $1) >>$2;
68 if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
72 # 成功したテストの数。テストグループログファイルから取得
73 SUCCESS_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | $(LINECOUNT))
75 # 失敗したテストの数。テストグループログファイルから取得
76 FAIL_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | $(LINECOUNT))
79 ALL_TEST = $(shell $(EXPR) $(SUCCESS_TEST) + $(FAIL_TEST))
82 TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
85 TEST_VALGRIND_FILES := $(foreach test,$(TESTS),$(test)/$(VALGRIND_FILE))
87 # テストの結果を、グループログファイルを元にレポート。
88 # 引数は、グループ名、グループログファイル、グループレポートファイル
89 # 用例: $(call group_report,name,file_log,file_report)
91 $(ECHO) '$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $(GROUP_DIR)/$2' >$3
92 if test $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
95 # リストで指定したディレクトリーでmakeを実行
96 # 用例: $(call make_targets,list_dir,target)
98 $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $2';)
99 $(foreach dir,$1,$(call make_target_each,$(dir),$2))
102 # 指定したディレクトリーでmakeを実行
103 # 用例: $(call make_target_each,tests,target)
104 define make_target_each
108 .PHONY: check checkall time valgrind create clean time-clean valgrind-clean
110 check checkall: clean $(GROUP_REPORT_FILE)
111 @$(CAT) $(GROUP_REPORT_FILE)
114 time: time-clean $(GROUP_TIME_FILE)
115 @$(CAT) $(GROUP_TIME_FILE)
118 @$(call create_dir,$(TEST))
119 @$(call create_makefile,$(TEST)/$(MAKEFILE),$(MAKEFILES))
122 @$(call make_targets,$(TESTS),$@)
123 @$(RM) $(GROUP_RES_FILES);
126 @$(call make_targets,$(TESTS),$@)
127 @$(RM) $(GROUP_TIME_FILE);
130 @$(call make_targets,$(TESTS),$@)
131 @$(RM) $(GROUP_RES_FILES);
134 @$(call make_targets,$(TESTS),$@)
135 @$(RM) $(GROUP_VALGRIND_FILE);
137 $(GROUP_REPORT_FILE): $(GROUP_LOG_FILE)
138 @$(call group_report,$(GROUP),$^,$@)
140 $(GROUP_LOG_FILE): $(TEST_LOG_FILES)
141 @$(call group_log,$^,$@)
144 @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@) NODISP=1
146 $(GROUP_TIME_FILE): $(TEST_TIME_FILES)
147 @$(call group_log,$^,$@)
150 @$(MAKE) time -sC $(dir $@)
152 $(GROUP_VALGRIND_FILE): $(TEST_VALGRIND_FILES)
153 @$(call group_log,$^,$@)
155 $(TEST_VALGRIND_FILES):
156 @$(MAKE) time -sC $(dir $@)