From: j8takagi Date: Fri, 26 Nov 2010 16:05:36 +0000 (+0900) Subject: テストの動作を一通り確認 X-Git-Tag: 0.2p3~52 X-Git-Url: https://j8takagi.net/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=1450bd0328b48ca8c3741c2462c29c07618b61b0;p=autotest_mk.git テストの動作を一通り確認 --- diff --git a/sample/hoc1/test/Define.mk b/sample/hoc1/test/Define.mk index 97be24c..44c12c9 100644 --- a/sample/hoc1/test/Define.mk +++ b/sample/hoc1/test/Define.mk @@ -1,7 +1,8 @@ # autotest.mk > test_template > Define.mk # 自動テスト用の変数、マクロ定義 -SHELL=/bin/sh +ifndef DEFINE_INCLUDED +DEFINE_INCLUDED = 1 ###################################################################### # テストグループのディレクトリー @@ -18,34 +19,34 @@ TEST_MAKEFILE := Test.mk ###################################################################### # 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") ###################################################################### # コマンド @@ -70,7 +71,7 @@ DEV_NULL ?= /dev/null CHMOD ?= chmod ###################################################################### -# エラー +# マクロ ###################################################################### # chk_var_null: 引数がNULLの場合、エラー @@ -82,111 +83,13 @@ endef # 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 diff --git a/sample/hoc1/test/Makefile b/sample/hoc1/test/Makefile index bdae65f..2214574 100644 --- a/sample/hoc1/test/Makefile +++ b/sample/hoc1/test/Makefile @@ -28,15 +28,51 @@ GROUP := $(notdir $(GROUP_DIR)) # テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー 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) @@ -49,8 +85,26 @@ ALL_TEST = $(shell expr $(SUCCESS_TEST) + $(FAIL_TEST)) # テストごとの実行時間ファイル 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 ###################################################################### # ターゲット @@ -70,7 +124,7 @@ create: clean: @$(call make_tests,$(TESTS),$@) - @$(RM) $(GROUP_REPORT_FILE) $(GROUP_LOG_FILE) $(GROUP_TIME_FILE) + @$(RM) $(GROUP_TEMP_FILES) cleantime: @$(call make_tests,$(TESTS),$@) @@ -80,14 +134,13 @@ $(GROUP_REPORT_FILE): $(GROUP_LOG_FILE) @$(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 $@) diff --git a/sample/hoc1/test/Test.mk b/sample/hoc1/test/Test.mk index 10fe274..600e777 100644 --- a/sample/hoc1/test/Test.mk +++ b/sample/hoc1/test/Test.mk @@ -15,9 +15,66 @@ 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) diff --git a/template/Define.mk b/template/Define.mk index 97be24c..44c12c9 100644 --- a/template/Define.mk +++ b/template/Define.mk @@ -1,7 +1,8 @@ # autotest.mk > test_template > Define.mk # 自動テスト用の変数、マクロ定義 -SHELL=/bin/sh +ifndef DEFINE_INCLUDED +DEFINE_INCLUDED = 1 ###################################################################### # テストグループのディレクトリー @@ -18,34 +19,34 @@ TEST_MAKEFILE := Test.mk ###################################################################### # 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") ###################################################################### # コマンド @@ -70,7 +71,7 @@ DEV_NULL ?= /dev/null CHMOD ?= chmod ###################################################################### -# エラー +# マクロ ###################################################################### # chk_var_null: 引数がNULLの場合、エラー @@ -82,111 +83,13 @@ endef # 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 diff --git a/template/Group.mk b/template/Group.mk index bdae65f..2214574 100644 --- a/template/Group.mk +++ b/template/Group.mk @@ -28,15 +28,51 @@ GROUP := $(notdir $(GROUP_DIR)) # テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー 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) @@ -49,8 +85,26 @@ ALL_TEST = $(shell expr $(SUCCESS_TEST) + $(FAIL_TEST)) # テストごとの実行時間ファイル 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 ###################################################################### # ターゲット @@ -70,7 +124,7 @@ create: clean: @$(call make_tests,$(TESTS),$@) - @$(RM) $(GROUP_REPORT_FILE) $(GROUP_LOG_FILE) $(GROUP_TIME_FILE) + @$(RM) $(GROUP_TEMP_FILES) cleantime: @$(call make_tests,$(TESTS),$@) @@ -80,14 +134,13 @@ $(GROUP_REPORT_FILE): $(GROUP_LOG_FILE) @$(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 $@) diff --git a/template/Test.mk b/template/Test.mk index 10fe274..600e777 100644 --- a/template/Test.mk +++ b/template/Test.mk @@ -15,9 +15,66 @@ 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)