テスト(Autotest.mk)実行方法の変更
[YACASL2.git] / test / template / Group.mk
1 # autotest.mk > template > Group.mk
2 # テストグループのMakefile
3 #
4 # オペレーター
5 # make          : すべてのテストを実行し、結果をログファイルに出力
6 # make check    : ↓
7 # make checkall : すべてのテストを実行し、結果と実行時間をログファイルに出力
8 # make time     : すべてのテストを実行し、実行時間をログファイルに出力
9 # make create   : TESTNAMEで指定されたテストを新規に作成
10 # make clean    : すべてのテストで、"make" で生成されたファイルをクリア
11 # make time-clean: すべてのテストで、実行時間のログファイルをクリア
12
13 SHELL = /bin/sh
14
15 include Define.mk
16
17 verbose ?= 1
18
19 ######################################################################
20 # テストグループのディレクトリー
21 ######################################################################
22
23 # グループディレクトリー
24 GROUP_DIR := $(CURDIR)
25
26 # グループ名。ディレクトリ名から取得
27 GROUP := $(notdir $(GROUP_DIR))
28
29 # テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
30 TESTS = $(notdir $(shell $(FIND) -maxdepth 1 -name "[^A-Z.]*" -type d))
31
32 # テストグループログファイル
33 GROUP_LOG_FILE := $(shell $(ECHO) $(GROUP) | $(TR) '[a-z]' '[A-Z]').log
34
35 # テストグループレポートファイル
36 GROUP_REPORT_FILE := Summary.log
37
38 # テストグループ実行時間ファイル
39 GROUP_TIME_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_time.log
40
41 # グループで、テスト結果として作成されるファイル群
42 GROUP_RES_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE)
43
44 # テストごとのログファイル
45 TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
46
47 ######################################################################
48 # テストグループのマクロ
49 ######################################################################
50
51 # テストごとのファイルをグループファイルに出力
52 # 引数は、テストのリスト、グループファイル、テストファイル
53 # 用例: $(call group_log,files_test_log,file_group_log)
54 define group_log
55     $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $(words $1) tests')
56     $(foreach target,$1,$(call group_log_each,$(target),$2))
57     $(if $(filter 1,$(verbose)),$(ECHO))
58 endef
59
60 # テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
61 # 用例: $(call group_log_each,file_test_log,file_group_log)
62 define group_log_each
63     $(if $(filter 1,$(verbose)),$(ECHO) -n '.')
64     $(ECHO) $(dir $1) >>$2;
65     if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
66     $(ECHO) >>$2;
67 endef
68
69 # 成功したテストの数。テストグループログファイルから取得
70 SUCCESS_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | $(LINECOUNT))
71
72 # 失敗したテストの数。テストグループログファイルから取得
73 FAIL_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | $(LINECOUNT))
74
75 # すべてのテストの数
76 ALL_TEST = $(shell $(EXPR) $(SUCCESS_TEST) + $(FAIL_TEST))
77
78 # テストごとの実行時間ファイル
79 TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
80
81 # テストの結果を、グループログファイルを元にレポート。
82 # 引数は、グループ名、グループログファイル、グループレポートファイル
83 # 用例: $(call group_report,name,file_log,file_report)
84 define group_report
85     $(ECHO) '$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $(GROUP_DIR)/$2' >$3
86     if test $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
87 endef
88
89 # リストで指定したディレクトリーでmakeを実行
90 # 用例: $(call make_targets,list_dir,target)
91 define make_targets
92     $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $2';)
93     $(foreach dir,$1,$(call make_target_each,$(dir),$2))
94 endef
95
96 # 指定したディレクトリーでmakeを実行
97 # 用例: $(call make_target_each,tests,target)
98 define make_target_each
99     $(MAKE) $2 -sC $1;
100 endef
101
102 .PHONY: check checkall time create clean time-clean
103
104 check checkall: clean $(GROUP_REPORT_FILE)
105         @$(CAT) $(GROUP_REPORT_FILE)
106         @exit $(FAIL_TEST)
107
108 time: time-clean $(GROUP_TIME_FILE)
109         @$(CAT) $(GROUP_TIME_FILE)
110
111 create:
112         @$(call create_dir,$(TEST))
113         @$(call create_makefile,$(TEST)/$(MAKEFILE),$(MAKEFILES))
114
115 clean:
116         @$(call make_targets,$(TESTS),$@)
117         @$(RM) $(GROUP_RES_FILES);
118
119 time-clean:
120         @$(call make_targets,$(TESTS),$@)
121         @$(RM) $(GROUP_TIME_FILE);
122
123 $(GROUP_REPORT_FILE): $(GROUP_LOG_FILE)
124         @$(call group_report,$(GROUP),$^,$@)
125
126 $(GROUP_LOG_FILE): $(TEST_LOG_FILES)
127         @$(call group_log,$^,$@)
128
129 $(TEST_LOG_FILES):
130         @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@) NODISP=1
131
132 $(GROUP_TIME_FILE): $(TEST_TIME_FILES)
133         @$(call group_log,$^,$@)
134
135 $(TEST_TIME_FILES):
136         @$(MAKE) time -sC $(dir $@)