テストの動作を一通り確認
[autotest_mk.git] / template / Test.mk
1 # autotest.mk > test_template > Test.mk
2 # 自動テスト用のMakefile
3 #
4 # 要: Define.mk
5 #
6 # オペレーター
7 # make         : CMDの標準出力をTEST1_FILEに保存したあと、TEST0_FILEとの差分を比較し、結果をLOG_FILEに出力
8 # make check   : ↓
9 # make set     : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は実行しない
10 # make reset   : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は上書き
11 # make time    : CMDの実行にかかった時間をTIME_FILEに保存し、出力
12 # make cleantime: "make time" で作成されたファイルをクリア
13 # make clean   : "make" で作成されたファイルをクリア
14 # make cleanall: "make" と "make set" で作成されたファイルをクリア
15
16 SHELL = /bin/sh
17
18 ######################################################################
19 # マクロ
20 ######################################################################
21
22 # 引数のファイルをチェックし、内容がない場合は削除
23 # 用例: $(call rm_null,file)
24 define rm_null
25     if test ! -s $1; then $(RM) $1; fi
26 endef
27
28 # 説明ファイルの内容を、引数のファイルに出力。
29 # 用例: $(call desc_log,file_out)
30 define desc_log
31     if test -s $(DESC_FILE); then $(CAT) $(DESC_FILE) >>$1; fi
32 endef
33
34 # テスト実行の経過時間を、ファイルに出力して表示。
35 # 引数は、テスト名、コマンドファイル、出力ファイル
36 # 用例: $(call time_cmd,name,file_cmd,file_out)
37 define time_cmd
38     $(call chk_file_notext,$2)
39     $(CHMOD) u+x $2
40     $(TIME) -f"$1: %E" -o $3 ./$2 >$(DEV_NULL) 2>&1
41 endef
42
43 # テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
44 # ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存。
45 # エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
46 # 用例: $(call exec_cmd,file_cmd,file_out,file_err)
47 define exec_cmd
48     $(call chk_file_notext,$1)
49     $(CAT) $1 >$2
50     $(CHMOD) u+x $1
51     ./$1 >>$2 2>$3
52     if test -s $3; then $(CAT) $3 >>$2; fi
53     $(call rm_null,$3)
54 endef
55
56 # 2つのファイルを比較し、差分ファイルを作成。
57 # 引数は、2ファイルのリスト、差分ファイル
58 # 用例: $(call diff_files,files,file_out)
59 define diff_files
60     $(DIFF) $1 >$2 2>&1
61     $(call rm_null,$2)
62 endef
63
64 # 差分ファイルの内容をログファイルに出力。
65 # 引数は、テスト名、差分ファイル、ログファイル
66 # 用例: $(call test_log,name,file_diff,file_log)
67 define test_log
68     if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3
69 endef
70
71 # テスト名。カレントディレクトリー名から取得
72 TEST = $(notdir $(shell pwd))
73
74 ######################################################################
75 # ターゲット
76 ######################################################################
77
78 .PHONY: check set reset time cleantime clean cleanall
79
80 check: clean $(LOG_FILE)
81
82 checkall: check $(TIME_FILE)
83         @$(CAT) $(TIME_FILE) >>$(LOG_FILE)
84
85 set: $(TEST0_FILE)
86         @$(CAT) $^
87
88 reset: cleanall $(TEST0_FILE)
89         @$(CAT) $(TEST0_FILE)
90
91 time: cleantime $(TIME_FILE)
92
93 cleantime:
94         @$(RM) $(TIME_FILE)
95
96 clean:
97         @$(RM) $(TEST1_FILE) $(DIFF_FILE) $(LOG_FILE) $(ERR_FILE) $(TIME_FILE)
98
99 cleanall: clean
100         @$(RM) $(TEST0_FILE)
101
102 $(CMD_FILE):
103         @$(call chk_file_notext,$@)
104         @$(CHMOD) u+x $@
105
106 $(TEST0_FILE) $(TEST1_FILE): $(CMD_FILE)
107         @-$(call exec_cmd,$^,$@,$(ERR_FILE))
108
109 $(DIFF_FILE): $(TEST0_FILE) $(TEST1_FILE)
110         @-$(call diff_files,$^,$@)
111
112 $(LOG_FILE): $(DIFF_FILE)
113         @$(RM) $@
114         @$(call desc_log,$@)
115         @$(call test_log,$(TEST),$^,$@)
116
117 $(TIME_FILE): $(CMD_FILE)
118         @-$(call time_cmd,$(TEST),$^,$@)