# autotest.mk > test_template > Define.mk
# 自動テスト用の変数、マクロ定義
-SHELL=/bin/sh
+ifndef DEFINE_INCLUDED
+DEFINE_INCLUDED = 1
######################################################################
# テストグループのディレクトリー
######################################################################
# Makefile
-MAKEFILE ?= Makefile
-
-# 現在の日時
-DATE = $(shell date +"%F %T")
+MAKEFILE := Makefile
# テストコマンドファイル
-CMD_FILE ?= cmd
+CMD_FILE := cmd
# テスト説明ファイル
-DESC_FILE ?= desc.txt
+DESC_FILE := desc.txt
# テスト想定結果ファイル
-TEST0_FILE ?= 0.txt
+TEST0_FILE := 0.txt
# テスト結果ファイル
-TEST1_FILE ?= 1.txt
+TEST1_FILE := 1.txt
# テストの、想定結果と結果の差分ファイル
-DIFF_FILE ?= diff.txt
+DIFF_FILE := diff.txt
# テストエラーファイル
-ERR_FILE ?= err.txt
+ERR_FILE := err.txt
# テストログファイル
-LOG_FILE ?= test.log
+LOG_FILE := test.log
# 実行時間ファイル
-TIME_FILE ?= time.log
+TIME_FILE := time.log
+
+# 現在の日時
+DATE = $(shell date +"%F %T")
######################################################################
# コマンド
CHMOD ?= chmod
######################################################################
-# ã\82¨ã\83©ã\83¼
+# ã\83\9eã\82¯ã\83
######################################################################
# chk_var_null: 引数がNULLの場合、エラー
# chk_file_ext: 指定されたファイルが実在する場合、エラー
# 用例: $(call chk_file_ext,file)
define chk_file_ext
- $(if $(wildcard $1),$(error $1 exists in $(shell pwd)))
+ $(if $(wildcard $1),$(error $1 exists in $(CURRDIR)))
endef
# chk_file_notext: 指定されたファイルが実在しない場合、エラー
# 用例: $(call chk_file_notext,file)
define chk_file_notext
- if test ! -s $1; then $(error $1 not exists in $(shell pwd)); fi
-endef
-
-######################################################################
-# マクロ
-######################################################################
-
-# 指定したディレクトリーを作成
-# 用例: $(call create_dir,name)
-define create_dir
- $(call chk_var_null,$1)
- $(call chk_file_ext,$1)
- $(MKDIR) $1
-endef
-
-# テストごとのMakefileを作成
-# 用例: $(call create_makefile,file)
-define create_makefile
- $(RM) $1
- $(foreach mkfile,$(DEF_FILE) $(TEST_MAKEFILE),$(ECHO) "include ../$(mkfile)" >>$1; )
-endef
-
-# リストで指定したディレクトリーでmakeを実行
-# 用例: $(call make_tests,list_dir,target)
-define make_tests
- $(foreach dir,$1,$(call make_test_each,$(dir),$2))
-endef
-
-# 指定したディレクトリーでMakeを実行
-# 用例: $(call make_test_each,tests,target)
-define make_test_each
- $(MAKE) $2 -sC $1;
-
-endef
-
-# 引数のファイルをチェックし、内容がない場合は削除
-# 用例: $(call rm_null,file)
-define rm_null
- if test ! -s $1; then $(RM) $1; fi
-endef
-
-# 説明ファイルの内容を、引数のファイルに出力。
-# 用例: $(call desc_log,file_out)
-define desc_log
- if test -s $(DESC_FILE); then $(CAT) $(DESC_FILE) >>$1; fi
+ $(if $(wildcard $1),,$(error $1 not exists in $(CURRDIR)))
endef
-# テスト実行の経過時間を、ファイルに出力して表示。
-# 引数は、テスト名、コマンドファイル、出力ファイル
-# 用例: $(call time_cmd,name,file_cmd,file_out)
-define time_cmd
- $(TIME) -f"$1: %E" -o $3 ./$2 >$(DEV_NULL) 2>&1
-endef
-
-# テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
-# ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存。
-# エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
-# 用例: $(call exec_cmd,file_cmd,file_out,file_err)
-define exec_cmd
- $(CAT) $1 >$2
- ./$1 >>$2 2>$3
- if test -s $3; then $(CAT) $3 >>$2; fi
- $(call rm_null,$3)
-endef
-
-# 2つのファイルを比較し、差分ファイルを作成。
-# 引数は、2ファイルのリスト、差分ファイル
-# 用例: $(call diff_files,files,file_out)
-define diff_files
- $(DIFF) $1 >$2 2>&1
- $(call rm_null,$2)
-endef
-
-# 差分ファイルの内容をログファイルに出力。
-# 引数は、テスト名、差分ファイル、ログファイル
-# 用例: $(call test_log,name,file_diff,file_log)
-define test_log
- if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3
-endef
-
-# テストごとのファイルをグループファイルに出力
-# 引数は、テストのリスト、グループファイル、テストファイル
-# 用例: $(call group_log,files_test_log,file_group_log)
-define group_log
- $(foreach target,$1,$(call group_log_each,$(target),$2))
-endef
-
-# テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
-# 用例: $(call group_log_each,file_test_log,file_group_log)
-define group_log_each
- if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
- echo >>$2;
-
-endef
-
-# テストの結果を、グループログファイルを元にレポート。
-# 引数は、グループログファイル
-# 用例: $(call group_report,name,file_log,file_report)
-define group_report
- $(ECHO) "$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $2" >$3;
- if test $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
-endef
+endif
# テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
TESTS = $(notdir $(shell find -maxdepth 1 -name "[^A-Z.]*" -type d))
-# テストごとのログファイル
-TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
-
# テストグループログファイル
GROUP_LOG_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]').log
# テストグループレポートファイル
GROUP_REPORT_FILE := Report.log
+# テストグループ実行時間ファイル
+GROUP_TIME_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]')_time.log
+
+# グループで、テスト時に作成されるファイル群
+GROUP_TEMP_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE)
+
+# テストごとのログファイル
+TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
+
+# 指定したディレクトリーを作成
+# 用例: $(call create_dir,name)
+define create_dir
+ $(call chk_var_null,$1)
+ $(call chk_file_ext,$1)
+ $(MKDIR) $1
+endef
+
+# テストごとのMakefileを作成
+# 用例: $(call create_makefile,file)
+define create_makefile
+ $(RM) $1
+ $(foreach mkfile,$(DEF_FILE) $(TEST_MAKEFILE),$(ECHO) "include ../$(mkfile)" >>$1; )
+endef
+
+# テストごとのファイルをグループファイルに出力
+# 引数は、テストのリスト、グループファイル、テストファイル
+# 用例: $(call group_log,files_test_log,file_group_log)
+define group_log
+ $(foreach target,$1,$(call group_log_each,$(target),$2))
+endef
+
+# テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
+# 用例: $(call group_log_each,file_test_log,file_group_log)
+define group_log_each
+ if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
+ echo >>$2;
+
+endef
+
# 成功したテストの数。テストグループログファイルから取得
SUCCESS_TEST = $(shell grep "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | wc -l)
# テストごとの実行時間ファイル
TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
-# テストグループ実行時間ファイル
-GROUP_TIME_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]')_time.log
+# テストの結果を、グループログファイルを元にレポート。
+# 引数は、グループログファイル
+# 用例: $(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
+endef
+
+# リストで指定したディレクトリーでmakeを実行
+# 用例: $(call make_tests,list_dir,target)
+define make_tests
+ $(foreach dir,$1,$(call make_test_each,$(dir),$2))
+endef
+
+# 指定したディレクトリーでMakeを実行
+# 用例: $(call make_test_each,tests,target)
+define make_test_each
+ $(MAKE) $2 -sC $1;
+
+endef
######################################################################
# ターゲット
clean:
@$(call make_tests,$(TESTS),$@)
- @$(RM) $(GROUP_REPORT_FILE) $(GROUP_LOG_FILE) $(GROUP_TIME_FILE)
+ @$(RM) $(GROUP_TEMP_FILES)
cleantime:
@$(call make_tests,$(TESTS),$@)
@$(call group_report,$(GROUP),$^,$@)
$(GROUP_LOG_FILE): $(TEST_LOG_FILES)
- @$(call make_tests,$(TESTS),$(MAKECMDGOALS))
@$(call group_log,$^,$@)
-$(GROUP_TIME_FILE): cleantime $(TEST_TIME_FILES)
- @$(call group_log,$(TEST_TIME_FILES),$@)
-
$(TEST_LOG_FILES):
- @$(MAKE) check -sC $(dir $@)
+ @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@)
+
+$(GROUP_TIME_FILE): $(TEST_TIME_FILES)
+ @$(call group_log,$^,$@)
$(TEST_TIME_FILES):
@$(MAKE) time -sC $(dir $@)
SHELL = /bin/sh
+######################################################################
+# マクロ
+######################################################################
+
+# 引数のファイルをチェックし、内容がない場合は削除
+# 用例: $(call rm_null,file)
+define rm_null
+ if test ! -s $1; then $(RM) $1; fi
+endef
+
+# 説明ファイルの内容を、引数のファイルに出力。
+# 用例: $(call desc_log,file_out)
+define desc_log
+ if test -s $(DESC_FILE); then $(CAT) $(DESC_FILE) >>$1; fi
+endef
+
+# テスト実行の経過時間を、ファイルに出力して表示。
+# 引数は、テスト名、コマンドファイル、出力ファイル
+# 用例: $(call time_cmd,name,file_cmd,file_out)
+define time_cmd
+ $(call chk_file_notext,$2)
+ $(CHMOD) u+x $2
+ $(TIME) -f"$1: %E" -o $3 ./$2 >$(DEV_NULL) 2>&1
+endef
+
+# テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
+# ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存。
+# エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
+# 用例: $(call exec_cmd,file_cmd,file_out,file_err)
+define exec_cmd
+ $(call chk_file_notext,$1)
+ $(CAT) $1 >$2
+ $(CHMOD) u+x $1
+ ./$1 >>$2 2>$3
+ if test -s $3; then $(CAT) $3 >>$2; fi
+ $(call rm_null,$3)
+endef
+
+# 2つのファイルを比較し、差分ファイルを作成。
+# 引数は、2ファイルのリスト、差分ファイル
+# 用例: $(call diff_files,files,file_out)
+define diff_files
+ $(DIFF) $1 >$2 2>&1
+ $(call rm_null,$2)
+endef
+
+# 差分ファイルの内容をログファイルに出力。
+# 引数は、テスト名、差分ファイル、ログファイル
+# 用例: $(call test_log,name,file_diff,file_log)
+define test_log
+ if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3
+endef
+
# テスト名。カレントディレクトリー名から取得
TEST = $(notdir $(shell pwd))
+######################################################################
+# ターゲット
+######################################################################
+
.PHONY: check set reset time cleantime clean cleanall
check: clean $(LOG_FILE)
# autotest.mk > test_template > Define.mk
# 自動テスト用の変数、マクロ定義
-SHELL=/bin/sh
+ifndef DEFINE_INCLUDED
+DEFINE_INCLUDED = 1
######################################################################
# テストグループのディレクトリー
######################################################################
# Makefile
-MAKEFILE ?= Makefile
-
-# 現在の日時
-DATE = $(shell date +"%F %T")
+MAKEFILE := Makefile
# テストコマンドファイル
-CMD_FILE ?= cmd
+CMD_FILE := cmd
# テスト説明ファイル
-DESC_FILE ?= desc.txt
+DESC_FILE := desc.txt
# テスト想定結果ファイル
-TEST0_FILE ?= 0.txt
+TEST0_FILE := 0.txt
# テスト結果ファイル
-TEST1_FILE ?= 1.txt
+TEST1_FILE := 1.txt
# テストの、想定結果と結果の差分ファイル
-DIFF_FILE ?= diff.txt
+DIFF_FILE := diff.txt
# テストエラーファイル
-ERR_FILE ?= err.txt
+ERR_FILE := err.txt
# テストログファイル
-LOG_FILE ?= test.log
+LOG_FILE := test.log
# 実行時間ファイル
-TIME_FILE ?= time.log
+TIME_FILE := time.log
+
+# 現在の日時
+DATE = $(shell date +"%F %T")
######################################################################
# コマンド
CHMOD ?= chmod
######################################################################
-# ã\82¨ã\83©ã\83¼
+# ã\83\9eã\82¯ã\83
######################################################################
# chk_var_null: 引数がNULLの場合、エラー
# chk_file_ext: 指定されたファイルが実在する場合、エラー
# 用例: $(call chk_file_ext,file)
define chk_file_ext
- $(if $(wildcard $1),$(error $1 exists in $(shell pwd)))
+ $(if $(wildcard $1),$(error $1 exists in $(CURRDIR)))
endef
# chk_file_notext: 指定されたファイルが実在しない場合、エラー
# 用例: $(call chk_file_notext,file)
define chk_file_notext
- if test ! -s $1; then $(error $1 not exists in $(shell pwd)); fi
-endef
-
-######################################################################
-# マクロ
-######################################################################
-
-# 指定したディレクトリーを作成
-# 用例: $(call create_dir,name)
-define create_dir
- $(call chk_var_null,$1)
- $(call chk_file_ext,$1)
- $(MKDIR) $1
-endef
-
-# テストごとのMakefileを作成
-# 用例: $(call create_makefile,file)
-define create_makefile
- $(RM) $1
- $(foreach mkfile,$(DEF_FILE) $(TEST_MAKEFILE),$(ECHO) "include ../$(mkfile)" >>$1; )
-endef
-
-# リストで指定したディレクトリーでmakeを実行
-# 用例: $(call make_tests,list_dir,target)
-define make_tests
- $(foreach dir,$1,$(call make_test_each,$(dir),$2))
-endef
-
-# 指定したディレクトリーでMakeを実行
-# 用例: $(call make_test_each,tests,target)
-define make_test_each
- $(MAKE) $2 -sC $1;
-
-endef
-
-# 引数のファイルをチェックし、内容がない場合は削除
-# 用例: $(call rm_null,file)
-define rm_null
- if test ! -s $1; then $(RM) $1; fi
-endef
-
-# 説明ファイルの内容を、引数のファイルに出力。
-# 用例: $(call desc_log,file_out)
-define desc_log
- if test -s $(DESC_FILE); then $(CAT) $(DESC_FILE) >>$1; fi
+ $(if $(wildcard $1),,$(error $1 not exists in $(CURRDIR)))
endef
-# テスト実行の経過時間を、ファイルに出力して表示。
-# 引数は、テスト名、コマンドファイル、出力ファイル
-# 用例: $(call time_cmd,name,file_cmd,file_out)
-define time_cmd
- $(TIME) -f"$1: %E" -o $3 ./$2 >$(DEV_NULL) 2>&1
-endef
-
-# テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
-# ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存。
-# エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
-# 用例: $(call exec_cmd,file_cmd,file_out,file_err)
-define exec_cmd
- $(CAT) $1 >$2
- ./$1 >>$2 2>$3
- if test -s $3; then $(CAT) $3 >>$2; fi
- $(call rm_null,$3)
-endef
-
-# 2つのファイルを比較し、差分ファイルを作成。
-# 引数は、2ファイルのリスト、差分ファイル
-# 用例: $(call diff_files,files,file_out)
-define diff_files
- $(DIFF) $1 >$2 2>&1
- $(call rm_null,$2)
-endef
-
-# 差分ファイルの内容をログファイルに出力。
-# 引数は、テスト名、差分ファイル、ログファイル
-# 用例: $(call test_log,name,file_diff,file_log)
-define test_log
- if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3
-endef
-
-# テストごとのファイルをグループファイルに出力
-# 引数は、テストのリスト、グループファイル、テストファイル
-# 用例: $(call group_log,files_test_log,file_group_log)
-define group_log
- $(foreach target,$1,$(call group_log_each,$(target),$2))
-endef
-
-# テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
-# 用例: $(call group_log_each,file_test_log,file_group_log)
-define group_log_each
- if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
- echo >>$2;
-
-endef
-
-# テストの結果を、グループログファイルを元にレポート。
-# 引数は、グループログファイル
-# 用例: $(call group_report,name,file_log,file_report)
-define group_report
- $(ECHO) "$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $2" >$3;
- if test $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi
-endef
+endif
# テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
TESTS = $(notdir $(shell find -maxdepth 1 -name "[^A-Z.]*" -type d))
-# テストごとのログファイル
-TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
-
# テストグループログファイル
GROUP_LOG_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]').log
# テストグループレポートファイル
GROUP_REPORT_FILE := Report.log
+# テストグループ実行時間ファイル
+GROUP_TIME_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]')_time.log
+
+# グループで、テスト時に作成されるファイル群
+GROUP_TEMP_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE)
+
+# テストごとのログファイル
+TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE))
+
+# 指定したディレクトリーを作成
+# 用例: $(call create_dir,name)
+define create_dir
+ $(call chk_var_null,$1)
+ $(call chk_file_ext,$1)
+ $(MKDIR) $1
+endef
+
+# テストごとのMakefileを作成
+# 用例: $(call create_makefile,file)
+define create_makefile
+ $(RM) $1
+ $(foreach mkfile,$(DEF_FILE) $(TEST_MAKEFILE),$(ECHO) "include ../$(mkfile)" >>$1; )
+endef
+
+# テストごとのファイルをグループファイルに出力
+# 引数は、テストのリスト、グループファイル、テストファイル
+# 用例: $(call group_log,files_test_log,file_group_log)
+define group_log
+ $(foreach target,$1,$(call group_log_each,$(target),$2))
+endef
+
+# テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
+# 用例: $(call group_log_each,file_test_log,file_group_log)
+define group_log_each
+ if test -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi
+ echo >>$2;
+
+endef
+
# 成功したテストの数。テストグループログファイルから取得
SUCCESS_TEST = $(shell grep "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | wc -l)
# テストごとの実行時間ファイル
TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
-# テストグループ実行時間ファイル
-GROUP_TIME_FILE := $(shell echo $(GROUP) | tr '[a-z]' '[A-Z]')_time.log
+# テストの結果を、グループログファイルを元にレポート。
+# 引数は、グループログファイル
+# 用例: $(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
+endef
+
+# リストで指定したディレクトリーでmakeを実行
+# 用例: $(call make_tests,list_dir,target)
+define make_tests
+ $(foreach dir,$1,$(call make_test_each,$(dir),$2))
+endef
+
+# 指定したディレクトリーでMakeを実行
+# 用例: $(call make_test_each,tests,target)
+define make_test_each
+ $(MAKE) $2 -sC $1;
+
+endef
######################################################################
# ターゲット
clean:
@$(call make_tests,$(TESTS),$@)
- @$(RM) $(GROUP_REPORT_FILE) $(GROUP_LOG_FILE) $(GROUP_TIME_FILE)
+ @$(RM) $(GROUP_TEMP_FILES)
cleantime:
@$(call make_tests,$(TESTS),$@)
@$(call group_report,$(GROUP),$^,$@)
$(GROUP_LOG_FILE): $(TEST_LOG_FILES)
- @$(call make_tests,$(TESTS),$(MAKECMDGOALS))
@$(call group_log,$^,$@)
-$(GROUP_TIME_FILE): cleantime $(TEST_TIME_FILES)
- @$(call group_log,$(TEST_TIME_FILES),$@)
-
$(TEST_LOG_FILES):
- @$(MAKE) check -sC $(dir $@)
+ @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@)
+
+$(GROUP_TIME_FILE): $(TEST_TIME_FILES)
+ @$(call group_log,$^,$@)
$(TEST_TIME_FILES):
@$(MAKE) time -sC $(dir $@)
SHELL = /bin/sh
+######################################################################
+# マクロ
+######################################################################
+
+# 引数のファイルをチェックし、内容がない場合は削除
+# 用例: $(call rm_null,file)
+define rm_null
+ if test ! -s $1; then $(RM) $1; fi
+endef
+
+# 説明ファイルの内容を、引数のファイルに出力。
+# 用例: $(call desc_log,file_out)
+define desc_log
+ if test -s $(DESC_FILE); then $(CAT) $(DESC_FILE) >>$1; fi
+endef
+
+# テスト実行の経過時間を、ファイルに出力して表示。
+# 引数は、テスト名、コマンドファイル、出力ファイル
+# 用例: $(call time_cmd,name,file_cmd,file_out)
+define time_cmd
+ $(call chk_file_notext,$2)
+ $(CHMOD) u+x $2
+ $(TIME) -f"$1: %E" -o $3 ./$2 >$(DEV_NULL) 2>&1
+endef
+
+# テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
+# ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存。
+# エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
+# 用例: $(call exec_cmd,file_cmd,file_out,file_err)
+define exec_cmd
+ $(call chk_file_notext,$1)
+ $(CAT) $1 >$2
+ $(CHMOD) u+x $1
+ ./$1 >>$2 2>$3
+ if test -s $3; then $(CAT) $3 >>$2; fi
+ $(call rm_null,$3)
+endef
+
+# 2つのファイルを比較し、差分ファイルを作成。
+# 引数は、2ファイルのリスト、差分ファイル
+# 用例: $(call diff_files,files,file_out)
+define diff_files
+ $(DIFF) $1 >$2 2>&1
+ $(call rm_null,$2)
+endef
+
+# 差分ファイルの内容をログファイルに出力。
+# 引数は、テスト名、差分ファイル、ログファイル
+# 用例: $(call test_log,name,file_diff,file_log)
+define test_log
+ if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3
+endef
+
# テスト名。カレントディレクトリー名から取得
TEST = $(notdir $(shell pwd))
+######################################################################
+# ターゲット
+######################################################################
+
.PHONY: check set reset time cleantime clean cleanall
check: clean $(LOG_FILE)