From: j8takagi Date: Sun, 28 Nov 2010 17:02:02 +0000 (+0900) Subject: Autotest.mk自身のユニットテストの項目追加 X-Git-Tag: 0.2p3~50 X-Git-Url: https://j8takagi.net/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=7945b3cf72579134bc4693c4f56ef4e9865e878e;p=autotest_mk.git Autotest.mk自身のユニットテストの項目追加 --- diff --git a/selftest/unittest/Define.mk b/selftest/unittest/Define.mk index 97be24c..18813ff 100644 --- a/selftest/unittest/Define.mk +++ b/selftest/unittest/Define.mk @@ -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 ###################################################################### -# エラー +# テストグループとテストでの共通マクロ ###################################################################### # 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 ###################################################################### -# マクロ +# テストグループのディレクトリー ###################################################################### -# 指定したディレクトリーを作成 -# 用例: $(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 index 0000000..f3cda2c --- /dev/null +++ b/selftest/unittest/Define_group.mk @@ -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 index 0000000..78394cb --- /dev/null +++ b/selftest/unittest/Define_test.mk @@ -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 diff --git a/selftest/unittest/Makefile b/selftest/unittest/Makefile index bdae65f..e22d03c 100644 --- a/selftest/unittest/Makefile +++ b/selftest/unittest/Makefile @@ -13,48 +13,8 @@ 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 $@) diff --git a/selftest/unittest/Test.mk b/selftest/unittest/Test.mk index 10fe274..edfa278 100644 --- a/selftest/unittest/Test.mk +++ b/selftest/unittest/Test.mk @@ -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に出力 @@ -16,14 +16,16 @@ 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 index 56b6e25..0000000 --- a/selftest/unittest/UNITTEST.log +++ /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 index 0000000..bee2e5d --- /dev/null +++ b/selftest/unittest/chk_file_ext/0.txt @@ -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 index 0000000..bf2e4c6 --- /dev/null +++ b/selftest/unittest/chk_file_ext/Makefile @@ -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 index 0000000..e69de29 diff --git a/selftest/unittest/chk_file_ext/cmd b/selftest/unittest/chk_file_ext/cmd new file mode 100755 index 0000000..87d6e26 --- /dev/null +++ b/selftest/unittest/chk_file_ext/cmd @@ -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 index 0000000..ff585d8 --- /dev/null +++ b/selftest/unittest/chk_file_ext/desc.txt @@ -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 index 0000000..ed52560 --- /dev/null +++ b/selftest/unittest/chk_file_notext/0.txt @@ -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 index 0000000..0def35c --- /dev/null +++ b/selftest/unittest/chk_file_notext/Makefile @@ -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 index 0000000..e69de29 diff --git a/selftest/unittest/chk_file_notext/cmd b/selftest/unittest/chk_file_notext/cmd new file mode 100755 index 0000000..87d6e26 --- /dev/null +++ b/selftest/unittest/chk_file_notext/cmd @@ -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 index 0000000..6a3833f --- /dev/null +++ b/selftest/unittest/chk_file_notext/desc.txt @@ -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 index 0000000..389f8d0 --- /dev/null +++ b/selftest/unittest/chk_var_null/0.txt @@ -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 index 0000000..793d9cc --- /dev/null +++ b/selftest/unittest/chk_var_null/Makefile @@ -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 index 0000000..3a7890c --- /dev/null +++ b/selftest/unittest/chk_var_null/cmd @@ -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 index 0000000..09ecbdf --- /dev/null +++ b/selftest/unittest/chk_var_null/desc.txt @@ -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 index 0000000..a9e6d35 --- /dev/null +++ b/selftest/unittest/create_dir/.gitignore @@ -0,0 +1 @@ +atest diff --git a/selftest/unittest/create_dir/0.txt b/selftest/unittest/create_dir/0.txt new file mode 100644 index 0000000..e477aef --- /dev/null +++ b/selftest/unittest/create_dir/0.txt @@ -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 index 0000000..b75fceb --- /dev/null +++ b/selftest/unittest/create_dir/Makefile @@ -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_testdir/cmd b/selftest/unittest/create_dir/cmd similarity index 100% rename from selftest/unittest/create_testdir/cmd rename to selftest/unittest/create_dir/cmd diff --git a/selftest/unittest/create_dir/desc.txt b/selftest/unittest/create_dir/desc.txt new file mode 100644 index 0000000..47a3679 --- /dev/null +++ b/selftest/unittest/create_dir/desc.txt @@ -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 index 0000000..a6803aa --- /dev/null +++ b/selftest/unittest/create_dir/report_detail.txt @@ -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. 中止. + diff --git a/selftest/unittest/create_testmkfile/0.txt b/selftest/unittest/create_makefile/0.txt similarity index 59% rename from selftest/unittest/create_testmkfile/0.txt rename to selftest/unittest/create_makefile/0.txt index 52c493f..39531db 100644 --- a/selftest/unittest/create_testmkfile/0.txt +++ b/selftest/unittest/create_makefile/0.txt @@ -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 index 0000000..5a21ced --- /dev/null +++ b/selftest/unittest/create_makefile/Makefile @@ -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)) diff --git a/selftest/unittest/create_testmkfile/cmd b/selftest/unittest/create_makefile/cmd similarity index 100% rename from selftest/unittest/create_testmkfile/cmd rename to selftest/unittest/create_makefile/cmd diff --git a/selftest/unittest/create_testmkfile/desc.txt b/selftest/unittest/create_makefile/desc.txt similarity index 54% rename from selftest/unittest/create_testmkfile/desc.txt rename to selftest/unittest/create_makefile/desc.txt index a9ada04..7dd1e39 100644 --- a/selftest/unittest/create_testmkfile/desc.txt +++ b/selftest/unittest/create_makefile/desc.txt @@ -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 index 531b441..0000000 --- a/selftest/unittest/create_testdir/0.txt +++ /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 index 99b96b0..0000000 --- a/selftest/unittest/create_testdir/Makefile +++ /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 index b6dac59..0000000 --- a/selftest/unittest/create_testmkfile/0.mk +++ /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 index c305ccd..0000000 --- a/selftest/unittest/create_testmkfile/Makefile +++ /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 index b6dac59..0000000 --- a/selftest/unittest/create_testmkfile/testmkfile.mk +++ /dev/null @@ -1,2 +0,0 @@ -include ../Define.mk -include ../Test.mk diff --git a/selftest/unittest/desc_log/0.txt b/selftest/unittest/desc_log/0.txt index b49f821..2669eb2 100644 --- a/selftest/unittest/desc_log/0.txt +++ b/selftest/unittest/desc_log/0.txt @@ -1,2 +1 @@ -make -s utest && cat 0.log 説明ファイルの内容を、引数のファイルに出力 diff --git a/selftest/unittest/desc_log/Makefile b/selftest/unittest/desc_log/Makefile index d19867d..7a135fa 100644 --- a/selftest/unittest/desc_log/Makefile +++ b/selftest/unittest/desc_log/Makefile @@ -1,4 +1,5 @@ include ../Define.mk +include ../Define_test.mk include ../Test.mk utest: diff --git a/selftest/unittest/exec_cmd/0.txt b/selftest/unittest/exec_cmd/0.txt index 02c12fb..7ed6ff8 100644 --- a/selftest/unittest/exec_cmd/0.txt +++ b/selftest/unittest/exec_cmd/0.txt @@ -1,3 +1 @@ -make -s utest && cat 00.txt -expr 2 + 3 5 diff --git a/selftest/unittest/exec_cmd/00.txt b/selftest/unittest/exec_cmd/00.txt index 2333bdb..7ed6ff8 100644 --- a/selftest/unittest/exec_cmd/00.txt +++ b/selftest/unittest/exec_cmd/00.txt @@ -1,2 +1 @@ -expr 2 + 3 5 diff --git a/selftest/unittest/exec_cmd/Makefile b/selftest/unittest/exec_cmd/Makefile index b293b5f..9f5d044 100644 --- a/selftest/unittest/exec_cmd/Makefile +++ b/selftest/unittest/exec_cmd/Makefile @@ -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 diff --git a/selftest/unittest/exec_cmd/desc.txt b/selftest/unittest/exec_cmd/desc.txt index cb71972..c9127b8 100644 --- a/selftest/unittest/exec_cmd/desc.txt +++ b/selftest/unittest/exec_cmd/desc.txt @@ -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 index 0000000..2188dc6 --- /dev/null +++ b/selftest/unittest/report_file/0.txt @@ -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 index 0000000..c8fd0be --- /dev/null +++ b/selftest/unittest/report_file/Makefile @@ -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 index 0000000..1cc2916 --- /dev/null +++ b/selftest/unittest/report_file/cmd @@ -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 index 0000000..dc3021d --- /dev/null +++ b/selftest/unittest/report_file/desc.txt @@ -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 index 0000000..f9f3adb --- /dev/null +++ b/selftest/unittest/report_files/0.txt @@ -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 index 0000000..26be367 --- /dev/null +++ b/selftest/unittest/report_files/Makefile @@ -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 index 0000000..a11c591 --- /dev/null +++ b/selftest/unittest/report_files/cmd @@ -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 index 0000000..16b9511 --- /dev/null +++ b/selftest/unittest/report_files/desc.txt @@ -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 index 0000000..d3d4f8b --- /dev/null +++ b/selftest/unittest/test_res_files/0.txt @@ -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 index 0000000..bc2192f --- /dev/null +++ b/selftest/unittest/test_res_files/Makefile @@ -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 index 0000000..2e64982 --- /dev/null +++ b/selftest/unittest/test_res_files/cmd @@ -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 index 0000000..0ad2b04 --- /dev/null +++ b/selftest/unittest/test_res_files/desc.txt @@ -0,0 +1,2 @@ +変数 test_res_files のテスト +テストの結果として作成されるファイル群 diff --git a/selftest/unittest/time_cmd/0.txt b/selftest/unittest/time_cmd/0.txt index 9a28196..33a0d78 100644 --- a/selftest/unittest/time_cmd/0.txt +++ b/selftest/unittest/time_cmd/0.txt @@ -1,2 +1 @@ -make -s utest && cat 00.txt time_cmd: 0:03.00 diff --git a/selftest/unittest/time_cmd/Makefile b/selftest/unittest/time_cmd/Makefile index 4b7c247..f456e4e 100644 --- a/selftest/unittest/time_cmd/Makefile +++ b/selftest/unittest/time_cmd/Makefile @@ -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 index 0000000..423d389 --- /dev/null +++ b/selftest/unittest/time_cmd/desc.txt @@ -0,0 +1,4 @@ +マクロ time_cmd のテスト +テスト実行の経過時間を、ファイルに出力して表示。 +多くの場合、0:03:00 (3秒)を出力。 +実際の実行時間により、結果が異なる場合がある。