Autotest.mk自身のユニットテストの項目追加
authorj8takagi <j8takagi@nifty.com>
Sun, 28 Nov 2010 17:02:02 +0000 (02:02 +0900)
committerj8takagi <j8takagi@nifty.com>
Sun, 28 Nov 2010 17:03:50 +0000 (02:03 +0900)
56 files changed:
selftest/unittest/Define.mk
selftest/unittest/Define_group.mk [new file with mode: 0644]
selftest/unittest/Define_test.mk [new file with mode: 0644]
selftest/unittest/Makefile
selftest/unittest/Test.mk
selftest/unittest/UNITTEST.log [deleted file]
selftest/unittest/chk_file_ext/0.txt [new file with mode: 0644]
selftest/unittest/chk_file_ext/Makefile [new file with mode: 0644]
selftest/unittest/chk_file_ext/a/a.txt [new file with mode: 0644]
selftest/unittest/chk_file_ext/cmd [new file with mode: 0755]
selftest/unittest/chk_file_ext/desc.txt [new file with mode: 0644]
selftest/unittest/chk_file_notext/0.txt [new file with mode: 0644]
selftest/unittest/chk_file_notext/Makefile [new file with mode: 0644]
selftest/unittest/chk_file_notext/a/a.txt [new file with mode: 0644]
selftest/unittest/chk_file_notext/cmd [new file with mode: 0755]
selftest/unittest/chk_file_notext/desc.txt [new file with mode: 0644]
selftest/unittest/chk_var_null/0.txt [new file with mode: 0644]
selftest/unittest/chk_var_null/Makefile [new file with mode: 0644]
selftest/unittest/chk_var_null/cmd [new file with mode: 0755]
selftest/unittest/chk_var_null/desc.txt [new file with mode: 0644]
selftest/unittest/create_dir/.gitignore [new file with mode: 0644]
selftest/unittest/create_dir/0.txt [new file with mode: 0644]
selftest/unittest/create_dir/Makefile [new file with mode: 0644]
selftest/unittest/create_dir/cmd [moved from selftest/unittest/create_testdir/cmd with 100% similarity]
selftest/unittest/create_dir/desc.txt [new file with mode: 0644]
selftest/unittest/create_dir/report_detail.txt [new file with mode: 0644]
selftest/unittest/create_makefile/0.txt [moved from selftest/unittest/create_testmkfile/0.txt with 59% similarity]
selftest/unittest/create_makefile/Makefile [new file with mode: 0644]
selftest/unittest/create_makefile/cmd [moved from selftest/unittest/create_testmkfile/cmd with 100% similarity]
selftest/unittest/create_makefile/desc.txt [moved from selftest/unittest/create_testmkfile/desc.txt with 54% similarity]
selftest/unittest/create_testdir/0.txt [deleted file]
selftest/unittest/create_testdir/Makefile [deleted file]
selftest/unittest/create_testmkfile/0.mk [deleted file]
selftest/unittest/create_testmkfile/Makefile [deleted file]
selftest/unittest/create_testmkfile/testmkfile.mk [deleted file]
selftest/unittest/desc_log/0.txt
selftest/unittest/desc_log/Makefile
selftest/unittest/exec_cmd/0.txt
selftest/unittest/exec_cmd/00.txt
selftest/unittest/exec_cmd/Makefile
selftest/unittest/exec_cmd/desc.txt
selftest/unittest/report_file/0.txt [new file with mode: 0644]
selftest/unittest/report_file/Makefile [new file with mode: 0644]
selftest/unittest/report_file/cmd [new file with mode: 0755]
selftest/unittest/report_file/desc.txt [new file with mode: 0644]
selftest/unittest/report_files/0.txt [new file with mode: 0644]
selftest/unittest/report_files/Makefile [new file with mode: 0644]
selftest/unittest/report_files/cmd [new file with mode: 0755]
selftest/unittest/report_files/desc.txt [new file with mode: 0644]
selftest/unittest/test_res_files/0.txt [new file with mode: 0644]
selftest/unittest/test_res_files/Makefile [new file with mode: 0644]
selftest/unittest/test_res_files/cmd [new file with mode: 0755]
selftest/unittest/test_res_files/desc.txt [new file with mode: 0644]
selftest/unittest/time_cmd/0.txt
selftest/unittest/time_cmd/Makefile
selftest/unittest/time_cmd/desc.txt [new file with mode: 0644]

index 97be24c..18813ff 100644 (file)
@@ -1,51 +1,17 @@
 # autotest.mk > test_template > Define.mk
 # 自動テスト用の変数、マクロ定義
 
-SHELL=/bin/sh
-
-######################################################################
-# テストグループのディレクトリー
-######################################################################
-
-# テストグループとテストの両方で使う変数を定義したファイル
-DEF_FILE := Define.mk
-
-# テストのMakefileにインクルードするファイル
-TEST_MAKEFILE := Test.mk
-
-######################################################################
-# テストのディレクトリー
-######################################################################
-
-# Makefile
-MAKEFILE ?= Makefile
+ifndef DEFINE_INCLUDED
+DEFINE_INCLUDED = 1
 
 # 現在の日時
 DATE = $(shell date +"%F %T")
 
-# テストコマンドファイル
-CMD_FILE ?= cmd
-
-# テスト説明ファイル
-DESC_FILE ?= desc.txt
-
-# テスト想定結果ファイル
-TEST0_FILE ?= 0.txt
-
-# テスト結果ファイル
-TEST1_FILE ?= 1.txt
-
-# テストの、想定結果と結果の差分ファイル
-DIFF_FILE ?= diff.txt
-
-# テストエラーファイル
-ERR_FILE ?= err.txt
-
-# テストログファイル
-LOG_FILE ?= test.log
+# 現在のディレクトリー
+CURRDIR = $(shell pwd)
 
-# 実行時間ファイル
-TIME_FILE ?= time.log
+# Makefile
+MAKEFILE := Makefile
 
 ######################################################################
 # コマンド
@@ -69,8 +35,17 @@ DEV_NULL ?= /dev/null
 
 CHMOD ?= chmod
 
+GREP ?= grep
+
+LINECOUNT ?= wc -l
+
+FIND ?= find
+
+TR ?= tr
+
+EXPR ?= expr
 ######################################################################
-# ã\82¨ã\83©ã\83¼
+# ã\83\86ã\82¹ã\83\88ã\82°ã\83«ã\83¼ã\83\97ã\81¨ã\83\86ã\82¹ã\83\88ã\81§ã\81®å\85±é\80\9aã\83\9eã\82¯ã\83­
 ######################################################################
 
 # chk_var_null: 引数がNULLの場合、エラー
@@ -82,111 +57,69 @@ 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
+    $(if $(wildcard $1),,$(error $1 not exists in $(CURRDIR)))
 endef
 
 ######################################################################
-# ã\83\9eã\82¯ã\83­
+# ã\83\86ã\82¹ã\83\88ã\82°ã\83«ã\83¼ã\83\97ã\81®ã\83\87ã\82£ã\83¬ã\82¯ã\83\88ã\83ªã\83¼
 ######################################################################
 
-# 指定したディレクトリーを作成
-# 用例: $(call create_dir,name)
-define create_dir
-    $(call chk_var_null,$1)
-    $(call chk_file_ext,$1)
-    $(MKDIR) $1
-endef
+# テストグループとテストの変数を定義したMakefile
+DEF_FILE := Define.mk
 
-# テストごとのMakefileを作成
-# 用例: $(call create_makefile,file)
-define create_makefile
-    $(RM) $1
-    $(foreach mkfile,$(DEF_FILE) $(TEST_MAKEFILE),$(ECHO) "include ../$(mkfile)" >>$1; )
-endef
+# テストグループの変数を定義したMakefile
+DEF_GROUP_FILE := Define_group.mk
 
-# リストで指定したディレクトリーでmakeを実行
-# 用例: $(call make_tests,list_dir,target)
-define make_tests
-    $(foreach dir,$1,$(call make_test_each,$(dir),$2))
-endef
+# テストの変数を定義したMakefile
+DEF_TEST_FILE := Define_test.mk
 
-# 指定したディレクトリーでMakeを実行
-# 用例: $(call make_test_each,tests,target)
-define make_test_each
-    $(MAKE) $2 -sC $1;
+# テストのターゲットを定義したMakefile
+TEST_MAKEFILE := Test.mk
 
-endef
+# すべてのMakefile群
+MAKEFILES := $(DEF_FILE) $(DEF_GROUP_FILE) $(DEF_TEST_FILE) $(TEST_MAKEFILE)
 
-# 引数のファイルをチェックし、内容がない場合は削除
-# 用例: $(call rm_null,file)
-define rm_null
-    if test ! -s $1; then $(RM) $1; fi
-endef
+# テストごとのMakefileでインクルードするMakefile群
+TEST_MAKEFILES := $(DEF_FILE) $(DEF_TEST_FILE) $(TEST_MAKEFILE)
 
-# 説明ファイルの内容を、引数のファイルに出力。
-# 用例: $(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
-    $(TIME) -f"$1: %E" -o $3 ./$2 >$(DEV_NULL) 2>&1
-endef
+# テストコマンドファイル
+CMD_FILE := cmd
 
-# テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
-# ファイルの内容と、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
+# テスト説明ファイル
+DESC_FILE := desc.txt
 
-# 2つのファイルを比較し、差分ファイルを作成。
-# 引数は、2ファイルのリスト、差分ファイル
-# 用例: $(call diff_files,files,file_out)
-define diff_files
-    $(DIFF) $1 >$2 2>&1
-    $(call rm_null,$2)
-endef
+# テスト想定結果ファイル
+TEST0_FILE := 0.txt
 
-# 差分ファイルの内容をログファイルに出力。
-# 引数は、テスト名、差分ファイル、ログファイル
-# 用例: $(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
+# テスト結果ファイル
+TEST1_FILE := 1.txt
 
-# テストごとのファイルをグループファイルに出力
-# 引数は、テストのリスト、グループファイル、テストファイル
-# 用例: $(call group_log,files_test_log,file_group_log)
-define group_log
-    $(foreach target,$1,$(call group_log_each,$(target),$2))
-endef
+# テストの、想定結果と結果の差分ファイル
+DIFF_FILE := diff.txt
 
-# テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル
-# 用例: $(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;
+# テストエラーファイル
+ERR_FILE := err.txt
 
-endef
+# テストログファイル
+LOG_FILE := test.log
 
-# テストの結果を、グループログファイルを元にレポート。
-# 引数は、グループログファイル
-# 用例: $(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
+# 実行時間ファイル
+TIME_FILE := time.log
+
+# テスト詳細レポートファイル
+DETAIL_FILE := detail.log
+
+# テストの結果として作成されるファイル群
+TEST_RES_FILES := $(TEST1_FILE) $(DIFF_FILE) $(ERR_FILE) $(LOG_FILE) $(DETAIL_FILE) $(TIME_FILE)
+
+endif
diff --git a/selftest/unittest/Define_group.mk b/selftest/unittest/Define_group.mk
new file mode 100644 (file)
index 0000000..f3cda2c
--- /dev/null
@@ -0,0 +1,95 @@
+######################################################################
+# テストグループのディレクトリー
+# ほかに、Define.mkでも一部定義
+######################################################################
+
+# グループディレクトリー
+GROUP_DIR := $(CURRDIR)
+
+# グループ名。ディレクトリ名から取得
+GROUP := $(notdir $(GROUP_DIR))
+
+# テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー
+TESTS = $(notdir $(shell $(FIND) -maxdepth 1 -name "[^A-Z.]*" -type d))
+
+# テストグループログファイル
+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_RES_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をインクルードするMakefileを作成
+# 用例: $(call create_makefile,file,list_include_file)
+define create_makefile
+    $(RM) $1
+    $(foreach infile,$2,$(ECHO) "include ../$(infile)" >>$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) | $(LINECOUNT))
+
+# 失敗したテストの数。テストグループログファイルから取得
+FAIL_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | $(LINECOUNT))
+
+# すべてのテストの数
+ALL_TEST = $(shell $(EXPR) $(SUCCESS_TEST) + $(FAIL_TEST))
+
+# テストごとの実行時間ファイル
+TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE))
+
+# テストの結果を、グループログファイルを元にレポート。
+# 引数は、グループ名、グループログファイル、グループレポートファイル
+# 用例: $(call group_report,name,file_log,file_report)
+define group_report
+    $(ECHO) "$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Detail 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
diff --git a/selftest/unittest/Define_test.mk b/selftest/unittest/Define_test.mk
new file mode 100644 (file)
index 0000000..78394cb
--- /dev/null
@@ -0,0 +1,80 @@
+######################################################################
+# マクロ
+######################################################################
+
+# 引数のファイルをチェックし、内容がない場合は削除
+# 用例: $(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
+
+# テスト実行コマンド。引数は、コマンドファイル、出力ファイル、エラーファイル
+# コマンドファイルを実行し、標準出力を出力ファイルに保存。
+# エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
+# 用例: $(call exec_cmd,file_cmd,file_out,file_err)
+define exec_cmd
+    $(call chk_file_notext,$1)
+    $(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
+    $(call desc_log,$3)
+    if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3
+    $(ECHO) "Detail in $(CURRDIR)/$(DETAIL_FILE)" >>$3
+endef
+
+# NODISPが設定されていない時は、ログファイルを表示
+# 引数は、ログファイル
+# 用例: $(call disp_test_log,file_log)
+define disp_test_log
+    $(if $(NODISP),,$(CAT) $1)
+endef
+
+# ファイル群から、ファイル名とファイルの内容を出力
+# 引数は、対象ファイル群、出力ファイル
+# 用例: $(call report_files,list_file_target,file_out)
+define report_files
+    $(call chk_file_ext,$2)
+    $(foreach tfile,$1,$(call report_file,$(tfile),$2))
+endef
+
+# ファイル名とファイルの内容を出力
+# 引数は、対象ファイル、出力ファイル
+# 用例: $(call report_file,file_target,file_out)
+define report_file
+    $(call chk_var_null,$1)
+    if test -s $1; then $(ECHO) "== $1 ==" >>$2; $(call echo_hr,$2); cat $1 >>$2; $(call echo_hr,$2); $(ECHO) >>$2; fi
+endef
+
+define echo_hr
+    $(ECHO) "----------------------------------------------------------------------" >>$1
+endef
index bdae65f..e22d03c 100644 (file)
 
 SHELL = /bin/sh
 
-######################################################################
-# テストグループの定義
-######################################################################
-
 include Define.mk
-
-# グループディレクトリー
-GROUP_DIR := $(shell pwd)
-
-# グループ名。ディレクトリ名から取得
-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
-
-# 成功したテストの数。テストグループログファイルから取得
-SUCCESS_TEST = $(shell grep "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | wc -l)
-
-# 失敗したテストの数。テストグループログファイルから取得
-FAIL_TEST = $(shell grep "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | wc -l)
-
-# すべてのテストの数
-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
-
-######################################################################
-# ターゲット
-######################################################################
+include Define_group.mk
 
 .PHONY: check checkall time create clean cleantime
 
@@ -66,11 +26,11 @@ time: cleantime $(GROUP_TIME_FILE)
 
 create:
        @$(call create_dir,$(TEST))
-       @$(call create_makefile,$(TEST)/$(MAKEFILE))
+       @$(call create_makefile,$(TEST)/$(MAKEFILE),$(TEST_MAKEFILES))
 
 clean:
        @$(call make_tests,$(TESTS),$@)
-       @$(RM) $(GROUP_REPORT_FILE) $(GROUP_LOG_FILE) $(GROUP_TIME_FILE)
+       @$(RM) $(GROUP_RES_FILES)
 
 cleantime:
        @$(call make_tests,$(TESTS),$@)
@@ -80,14 +40,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 $@) NODISP=1
+
+$(GROUP_TIME_FILE): $(TEST_TIME_FILES)
+       @$(call group_log,$^,$@)
 
 $(TEST_TIME_FILES):
        @$(MAKE) time -sC $(dir $@)
index 10fe274..edfa278 100644 (file)
@@ -1,7 +1,7 @@
 # autotest.mk > test_template > Test.mk
 # 自動テスト用のMakefile
 #
-# 要: Define.mk
+# 要: Define.mk Define_test.mk
 #
 # オペレーター
 # make         : CMDの標準出力をTEST1_FILEに保存したあと、TEST0_FILEとの差分を比較し、結果をLOG_FILEに出力
 SHELL = /bin/sh
 
 # テスト名。カレントディレクトリー名から取得
-TEST = $(notdir $(shell pwd))
+TEST = $(notdir $(CURRDIR))
 
 .PHONY: check set reset time cleantime clean cleanall
 
-check: clean $(LOG_FILE)
+check: clean $(DETAIL_FILE)
+       @$(call disp_test_log,$(LOG_FILE))
 
 checkall: check $(TIME_FILE)
        @$(CAT) $(TIME_FILE) >>$(LOG_FILE)
+       @$(call disp_test_log,$(LOG_FILE))
 
 set: $(TEST0_FILE)
        @$(CAT) $^
@@ -37,7 +39,7 @@ cleantime:
        @$(RM) $(TIME_FILE)
 
 clean:
-       @$(RM) $(TEST1_FILE) $(DIFF_FILE) $(LOG_FILE) $(ERR_FILE) $(TIME_FILE)
+       @$(RM) $(TEST_RES_FILES)
 
 cleanall: clean
        @$(RM) $(TEST0_FILE)
@@ -50,12 +52,14 @@ $(TEST0_FILE) $(TEST1_FILE): $(CMD_FILE)
        @-$(call exec_cmd,$^,$@,$(ERR_FILE))
 
 $(DIFF_FILE): $(TEST0_FILE) $(TEST1_FILE)
+       @$(call chk_file_notext,$(TEST0_FILE))
        @-$(call diff_files,$^,$@)
 
 $(LOG_FILE): $(DIFF_FILE)
-       @$(RM) $@
-       @$(call desc_log,$@)
        @$(call test_log,$(TEST),$^,$@)
 
+$(DETAIL_FILE): $(LOG_FILE)
+       @$(call report_files,$(LOG_FILE) $(CMD_FILE) $(TEST0_FILE) $(ERR_FILE) $(DIFF_FILE) $(TEST1_FILE),$@)
+
 $(TIME_FILE): $(CMD_FILE)
        @-$(call time_cmd,$(TEST),$^,$@)
diff --git a/selftest/unittest/UNITTEST.log b/selftest/unittest/UNITTEST.log
deleted file mode 100644 (file)
index 56b6e25..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
-ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存
-エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存
-exec_cmd: Test Success 2010-11-23 02:10:44
-
-create_testdir: Test Success 2010-11-23 02:10:45
-
-time_cmd: Test Success 2010-11-23 02:10:48
-
-説明ファイルの内容を、引数のファイルに出力
-desc_log: Test Success 2010-11-23 02:10:48
-
-TESTディレクトリーのMakefileを作成
-create_testmkfile: Test Success 2010-11-23 02:10:48
-
diff --git a/selftest/unittest/chk_file_ext/0.txt b/selftest/unittest/chk_file_ext/0.txt
new file mode 100644 (file)
index 0000000..bee2e5d
--- /dev/null
@@ -0,0 +1,5 @@
+b: not exist
+b/b.txt: not exist
+Makefile:14: *** a exists in /home/kazubito/2010_11/autotest.mk/selftest/unittest/chk_file_ext.  中止.
+Makefile:18: *** a/a.txt exists in /home/kazubito/2010_11/autotest.mk/selftest/unittest/chk_file_ext.  中止.
+
diff --git a/selftest/unittest/chk_file_ext/Makefile b/selftest/unittest/chk_file_ext/Makefile
new file mode 100644 (file)
index 0000000..bf2e4c6
--- /dev/null
@@ -0,0 +1,20 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err1 utest_err2
+
+utest:
+       @$(call chk_file_ext,b)
+       @$(call chk_file_ext,b/b.txt)
+       @echo "b: not exist"
+       @echo "b/b.txt: not exist"
+
+utest_err1:
+       @$(call chk_file_ext,a)
+       @echo "a: not exist"
+
+utest_err2:
+       @$(call chk_file_ext,a/a.txt)
+       @echo "a/a.txt: not exist"
+
diff --git a/selftest/unittest/chk_file_ext/a/a.txt b/selftest/unittest/chk_file_ext/a/a.txt
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/selftest/unittest/chk_file_ext/cmd b/selftest/unittest/chk_file_ext/cmd
new file mode 100755 (executable)
index 0000000..87d6e26
--- /dev/null
@@ -0,0 +1,4 @@
+make -s utest 2>&1
+make -s utest_err1 2>&1
+make -s utest_err2 2>&1
+echo
diff --git a/selftest/unittest/chk_file_ext/desc.txt b/selftest/unittest/chk_file_ext/desc.txt
new file mode 100644 (file)
index 0000000..ff585d8
--- /dev/null
@@ -0,0 +1,2 @@
+マクロ chk_file_ext のテスト
+指定されたファイルが実在する場合、エラー
diff --git a/selftest/unittest/chk_file_notext/0.txt b/selftest/unittest/chk_file_notext/0.txt
new file mode 100644 (file)
index 0000000..ed52560
--- /dev/null
@@ -0,0 +1,5 @@
+a: exist
+a/a.txt: exist
+Makefile:14: *** b not exists in /home/kazubito/2010_11/autotest.mk/selftest/unittest/chk_file_notext.  中止.
+Makefile:18: *** b/b.txt not exists in /home/kazubito/2010_11/autotest.mk/selftest/unittest/chk_file_notext.  中止.
+
diff --git a/selftest/unittest/chk_file_notext/Makefile b/selftest/unittest/chk_file_notext/Makefile
new file mode 100644 (file)
index 0000000..0def35c
--- /dev/null
@@ -0,0 +1,19 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err1 utest_err2
+
+utest:
+       @$(call chk_file_notext,a)
+       @$(call chk_file_notext,a/a.txt)
+       @echo "a: exist"
+       @echo "a/a.txt: exist"
+
+utest_err1:
+       @$(call chk_file_notext,b)
+       @echo "b: not exist"
+
+utest_err2:
+       @$(call chk_file_notext,b/b.txt)
+       @echo "b/b.txt: not exist"
diff --git a/selftest/unittest/chk_file_notext/a/a.txt b/selftest/unittest/chk_file_notext/a/a.txt
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/selftest/unittest/chk_file_notext/cmd b/selftest/unittest/chk_file_notext/cmd
new file mode 100755 (executable)
index 0000000..87d6e26
--- /dev/null
@@ -0,0 +1,4 @@
+make -s utest 2>&1
+make -s utest_err1 2>&1
+make -s utest_err2 2>&1
+echo
diff --git a/selftest/unittest/chk_file_notext/desc.txt b/selftest/unittest/chk_file_notext/desc.txt
new file mode 100644 (file)
index 0000000..6a3833f
--- /dev/null
@@ -0,0 +1,2 @@
+マクロ chk_file_notext のテスト
+指定されたファイルが実在しない場合、エラー
diff --git a/selftest/unittest/chk_var_null/0.txt b/selftest/unittest/chk_var_null/0.txt
new file mode 100644 (file)
index 0000000..389f8d0
--- /dev/null
@@ -0,0 +1,5 @@
+VAR_0: 0
+VAR_1: 1
+VAR_NULL: 
+Makefile:18: *** NULL argument.  中止.
+
diff --git a/selftest/unittest/chk_var_null/Makefile b/selftest/unittest/chk_var_null/Makefile
new file mode 100644 (file)
index 0000000..793d9cc
--- /dev/null
@@ -0,0 +1,21 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err
+
+VAR_0 = 0
+VAR_1 = 1
+
+utest:
+       @$(call chk_var_null,$(VAR_0))
+       @$(call chk_var_null,$(VAR_1))
+       @echo "VAR_0: $(VAR_0)"
+       @echo "VAR_1: $(VAR_1)"
+       @echo "VAR_NULL: $(VAR_NULL)"
+
+utest_err:
+       @$(call chk_var_null,$(VAR_NULL))
+       @echo "VAR_0: $(VAR_0)"
+       @echo "VAR_1: $(VAR_1)"
+       @echo "VAR_NULL: $(VAR_NULL)"
diff --git a/selftest/unittest/chk_var_null/cmd b/selftest/unittest/chk_var_null/cmd
new file mode 100755 (executable)
index 0000000..3a7890c
--- /dev/null
@@ -0,0 +1,3 @@
+make -s utest 2>&1
+make -s utest_err 2>&1
+echo
diff --git a/selftest/unittest/chk_var_null/desc.txt b/selftest/unittest/chk_var_null/desc.txt
new file mode 100644 (file)
index 0000000..09ecbdf
--- /dev/null
@@ -0,0 +1,2 @@
+マクロ chk_var_null のテスト
+引数がNULLの場合、エラー
diff --git a/selftest/unittest/create_dir/.gitignore b/selftest/unittest/create_dir/.gitignore
new file mode 100644 (file)
index 0000000..a9e6d35
--- /dev/null
@@ -0,0 +1 @@
+atest
diff --git a/selftest/unittest/create_dir/0.txt b/selftest/unittest/create_dir/0.txt
new file mode 100644 (file)
index 0000000..e477aef
--- /dev/null
@@ -0,0 +1,4 @@
+atest
+Makefile:15: *** NULL argument.  中止.
+Makefile:12: *** atest exists in /home/kazubito/2010_11/autotest.mk/selftest/unittest/create_dir.  中止.
+
diff --git a/selftest/unittest/create_dir/Makefile b/selftest/unittest/create_dir/Makefile
new file mode 100644 (file)
index 0000000..b75fceb
--- /dev/null
@@ -0,0 +1,18 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+include ../Define_group.mk
+
+.PHONY: utest utest_err clean_utest
+
+override RM := rm -rf
+override TEST_RES_FILES := $(TEST_RES_FILES) atest
+
+utest:
+       @$(call create_dir,atest)
+
+utest_err:
+       @$(call create_dir)
+
+clean_utest:
+       @rm -rf atest
diff --git a/selftest/unittest/create_dir/desc.txt b/selftest/unittest/create_dir/desc.txt
new file mode 100644 (file)
index 0000000..47a3679
--- /dev/null
@@ -0,0 +1,4 @@
+マクロcreate_dirのテスト
+引数として指定したディレクトリーを作成
+引数が指定されない場合は、エラー終了
+ディレクトリーが既存の場合は、エラー終了
diff --git a/selftest/unittest/create_dir/report_detail.txt b/selftest/unittest/create_dir/report_detail.txt
new file mode 100644 (file)
index 0000000..a6803aa
--- /dev/null
@@ -0,0 +1,13 @@
+引数として指定したディレクトリーを作成
+引数が指定されない場合は、エラー終了
+ディレクトリーが既存の場合は、エラー終了
+create_dir: Test Success 2010-11-28 19:06:19
+make -s clean_utest
+make -s utest 2>&1 && ls | grep atest
+make -s utest_err 2>&1 && ls | grep atest
+make -s utest 2>&1 && ls | grep atest
+echo
+atest
+Makefile:15: *** NULL argument.  中止.
+Makefile:12: *** atest exists in /home/kazubito/2010_11/autotest.mk/selftest/unittest/create_dir.  中止.
+
similarity index 59%
rename from selftest/unittest/create_testmkfile/0.txt
rename to selftest/unittest/create_makefile/0.txt
index 52c493f..39531db 100644 (file)
@@ -1,3 +1,4 @@
-make -s utest && cat 0.mk
+
 include ../Define.mk
+include ../Define_test.mk
 include ../Test.mk
diff --git a/selftest/unittest/create_makefile/Makefile b/selftest/unittest/create_makefile/Makefile
new file mode 100644 (file)
index 0000000..5a21ced
--- /dev/null
@@ -0,0 +1,11 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+include ../Define_group.mk
+
+override TEST_RES_FILES := $(TEST_RES_FILES) 0.mk
+
+utest:
+       echo $(TEST_INCLUDE_FILES)
+       $(call create_makefile,0.mk,$(TEST_MAKEFILES))
similarity index 54%
rename from selftest/unittest/create_testmkfile/desc.txt
rename to selftest/unittest/create_makefile/desc.txt
index a9ada04..7dd1e39 100644 (file)
@@ -1 +1,2 @@
+マクロ create_makefile のテスト
 TESTディレクトリーのMakefileを作成
diff --git a/selftest/unittest/create_testdir/0.txt b/selftest/unittest/create_testdir/0.txt
deleted file mode 100644 (file)
index 531b441..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-make -s clean_utest
-make -s utest 2>&1 && ls | grep atest
-make -s utest_err 2>&1 && ls | grep atest
-make -s utest 2>&1 && ls | grep atest
-echo
-atest
-Makefile:8: *** NULL argument.  Stop.
-Makefile:5: *** atest exists.  Stop.
-
diff --git a/selftest/unittest/create_testdir/Makefile b/selftest/unittest/create_testdir/Makefile
deleted file mode 100644 (file)
index 99b96b0..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
-include ../Define.mk
-include ../Test.mk
-
-utest:
-       @$(call create_testdir,atest)
-
-utest_err:
-       @$(call create_testdir)
-
-clean_utest:
-       @rm -rf atest
diff --git a/selftest/unittest/create_testmkfile/0.mk b/selftest/unittest/create_testmkfile/0.mk
deleted file mode 100644 (file)
index b6dac59..0000000
+++ /dev/null
@@ -1,2 +0,0 @@
-include ../Define.mk
-include ../Test.mk
diff --git a/selftest/unittest/create_testmkfile/Makefile b/selftest/unittest/create_testmkfile/Makefile
deleted file mode 100644 (file)
index c305ccd..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-include ../Define.mk
-include ../Test.mk
-
-utest:
-       $(call create_testmkfile,0.mk)
diff --git a/selftest/unittest/create_testmkfile/testmkfile.mk b/selftest/unittest/create_testmkfile/testmkfile.mk
deleted file mode 100644 (file)
index b6dac59..0000000
+++ /dev/null
@@ -1,2 +0,0 @@
-include ../Define.mk
-include ../Test.mk
index b49f821..2669eb2 100644 (file)
@@ -1,2 +1 @@
-make -s utest && cat 0.log
 説明ファイルの内容を、引数のファイルに出力
index d19867d..7a135fa 100644 (file)
@@ -1,4 +1,5 @@
 include ../Define.mk
+include ../Define_test.mk
 include ../Test.mk
 
 utest:
index 02c12fb..7ed6ff8 100644 (file)
@@ -1,3 +1 @@
-make -s utest && cat 00.txt
-expr 2 + 3
 5
index b293b5f..9f5d044 100644 (file)
@@ -1,6 +1,11 @@
 include ../Define.mk
+include ../Define_test.mk
 include ../Test.mk
 
-utest:
-       $(RM) 0.log
+.PHONY: utest clean_utest
+
+utest: clean_utest
        $(call exec_cmd,cmd0,00.txt,err.txt)
+
+clean_utest:
+       $(RM) 00.txt err.txt
index cb71972..c9127b8 100644 (file)
@@ -1,2 +1,3 @@
-ファイルの内容と、CMD_FILE実行の標準出力を、出力ファイルに保存
-エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存
+マクロ exec_cmd のテスト
+コマンドファイルを実行し、標準出力を出力ファイルに保存。
+エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。
diff --git a/selftest/unittest/report_file/0.txt b/selftest/unittest/report_file/0.txt
new file mode 100644 (file)
index 0000000..2188dc6
--- /dev/null
@@ -0,0 +1,25 @@
+== Makefile ==
+----------------------------------------------------------------------
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err1 utest_err2 clean_utest
+
+override TEST_RES_FILES := $(TEST_RES_FILES) atest
+
+utest: clean_utest
+       $(call report_file,Makefile,detail.log)
+
+utest_err1: clean_utest
+       $(call report_file,,detail.log)
+
+utest_err2: clean_utest
+       $(call report_file,NOEXT,detail.log)
+
+clean_utest:
+       $(RM) detail.log
+----------------------------------------------------------------------
+
+Makefile:13: *** NULL argument.  中止.
+cat: detail.log: No such file or directory
diff --git a/selftest/unittest/report_file/Makefile b/selftest/unittest/report_file/Makefile
new file mode 100644 (file)
index 0000000..c8fd0be
--- /dev/null
@@ -0,0 +1,19 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err1 utest_err2 clean_utest
+
+override TEST_RES_FILES := $(TEST_RES_FILES) atest
+
+utest: clean_utest
+       $(call report_file,Makefile,detail.log)
+
+utest_err1: clean_utest
+       $(call report_file,,detail.log)
+
+utest_err2: clean_utest
+       $(call report_file,NOEXT,detail.log)
+
+clean_utest:
+       $(RM) detail.log
diff --git a/selftest/unittest/report_file/cmd b/selftest/unittest/report_file/cmd
new file mode 100755 (executable)
index 0000000..1cc2916
--- /dev/null
@@ -0,0 +1,4 @@
+make -s utest && cat detail.log
+make -s utest_err1 && cat detail.log
+make -s utest_err2 && cat detail.log
+
diff --git a/selftest/unittest/report_file/desc.txt b/selftest/unittest/report_file/desc.txt
new file mode 100644 (file)
index 0000000..dc3021d
--- /dev/null
@@ -0,0 +1,2 @@
+マクロ report_file のテスト
+ファイル名とファイルの内容を出力
diff --git a/selftest/unittest/report_files/0.txt b/selftest/unittest/report_files/0.txt
new file mode 100644 (file)
index 0000000..f9f3adb
--- /dev/null
@@ -0,0 +1,24 @@
+== cmd ==
+----------------------------------------------------------------------
+make -s utest && cat detail.log
+
+----------------------------------------------------------------------
+
+== Makefile ==
+----------------------------------------------------------------------
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err1 utest_err2 clean_utest
+
+override TEST_RES_FILES := $(TEST_RES_FILES) atest
+TARGET_FILES := cmd Makefile
+
+utest: clean_utest
+       $(call report_files,$(TARGET_FILES),detail.log)
+
+clean_utest:
+       $(RM) detail.log
+----------------------------------------------------------------------
+
diff --git a/selftest/unittest/report_files/Makefile b/selftest/unittest/report_files/Makefile
new file mode 100644 (file)
index 0000000..26be367
--- /dev/null
@@ -0,0 +1,14 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest utest_err1 utest_err2 clean_utest
+
+override TEST_RES_FILES := $(TEST_RES_FILES) atest
+TARGET_FILES := cmd Makefile
+
+utest: clean_utest
+       $(call report_files,$(TARGET_FILES),detail.log)
+
+clean_utest:
+       $(RM) detail.log
diff --git a/selftest/unittest/report_files/cmd b/selftest/unittest/report_files/cmd
new file mode 100755 (executable)
index 0000000..a11c591
--- /dev/null
@@ -0,0 +1,2 @@
+make -s utest && cat detail.log
+
diff --git a/selftest/unittest/report_files/desc.txt b/selftest/unittest/report_files/desc.txt
new file mode 100644 (file)
index 0000000..16b9511
--- /dev/null
@@ -0,0 +1,2 @@
+マクロ report_files のテスト
+ファイル群から、ファイル名とファイルの内容を出力
diff --git a/selftest/unittest/test_res_files/0.txt b/selftest/unittest/test_res_files/0.txt
new file mode 100644 (file)
index 0000000..d3d4f8b
--- /dev/null
@@ -0,0 +1,2 @@
+1.txt diff.txt err.txt test.log detail.log time.log
+
diff --git a/selftest/unittest/test_res_files/Makefile b/selftest/unittest/test_res_files/Makefile
new file mode 100644 (file)
index 0000000..bc2192f
--- /dev/null
@@ -0,0 +1,8 @@
+include ../Define.mk
+include ../Define_test.mk
+include ../Test.mk
+
+.PHONY: utest
+
+utest:
+       @$(ECHO) $(TEST_RES_FILES)
diff --git a/selftest/unittest/test_res_files/cmd b/selftest/unittest/test_res_files/cmd
new file mode 100755 (executable)
index 0000000..2e64982
--- /dev/null
@@ -0,0 +1,2 @@
+make -s utest 2>&1
+echo
diff --git a/selftest/unittest/test_res_files/desc.txt b/selftest/unittest/test_res_files/desc.txt
new file mode 100644 (file)
index 0000000..0ad2b04
--- /dev/null
@@ -0,0 +1,2 @@
+変数 test_res_files のテスト
+テストの結果として作成されるファイル群
index 9a28196..33a0d78 100644 (file)
@@ -1,2 +1 @@
-make -s utest && cat 00.txt
 time_cmd: 0:03.00
index 4b7c247..f456e4e 100644 (file)
@@ -1,4 +1,5 @@
 include ../Define.mk
+include ../Define_test.mk
 include ../Test.mk
 
 utest:
diff --git a/selftest/unittest/time_cmd/desc.txt b/selftest/unittest/time_cmd/desc.txt
new file mode 100644 (file)
index 0000000..423d389
--- /dev/null
@@ -0,0 +1,4 @@
+マクロ time_cmd のテスト
+テスト実行の経過時間を、ファイルに出力して表示。
+多くの場合、0:03:00 (3秒)を出力。
+実際の実行時間により、結果が異なる場合がある。