<!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.0 Transitional//EN' 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd'> <html xmlns='http://www.w3.org/1999/xhtml'> <head> <title>test/system/casl2rev/Test.mk</title> <meta name='robots' content='noindex,nofollow' /> <meta name='generator' content='GLOBAL-6.6.5' /> <meta http-equiv='Content-Style-Type' content='text/css' /> <link rel='stylesheet' type='text/css' href='../style.css' /> </head> <body> <a id='TOP' name='TOP'></a><h2 class='header'><a href='../mains.html'>root</a>/<a href='../files/2933.html'>test</a>/<a href='../files/2935.html'>system</a>/<a href='../files/3128.html'>casl2rev</a>/Test.mk</h2> <em class='comment'>/* [<][>][^][v][top]<a href='#BOTTOM'>[bottom]</a><a href='../mains.html'>[index]</a><a href='../help.html'>[help]</a> */</em> <hr /> <pre> <a id='L1' name='L1'></a># autotest.mk > test_template > Test.mk <a id='L2' name='L2'></a># 自動テスト用のMakefile <a id='L3' name='L3'></a># <a id='L4' name='L4'></a># 要: Define.mk <a id='L5' name='L5'></a># <a id='L6' name='L6'></a># オペレーター <a id='L7' name='L7'></a># make : CMDの標準出力をTEST1_FILEに保存したあと、TEST0_FILEとの差分を比較し、結果をLOG_FILEに出力 <a id='L8' name='L8'></a># make check : ↓ <a id='L9' name='L9'></a># make set : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は実行しない <a id='L10' name='L10'></a># make reset : CMDの標準出力をTEST0_FILEに保存。TEST0_FILEが存在する場合は上書き <a id='L11' name='L11'></a># make time : CMDの実行にかかった時間をTIME_FILEに保存し、出力 <a id='L12' name='L12'></a># make time-clean: "make time" で作成されたファイルをクリア <a id='L13' name='L13'></a># make valgrind: valgrind CMDの標準出力をVARGRIND_FILEに保存 <a id='L14' name='L14'></a># make clean : "make" で作成されたファイルをクリア <a id='L15' name='L15'></a># make all-clean: "make" と "make set" で作成されたファイルをクリア <a id='L16' name='L16'></a> <a id='L17' name='L17'></a>###################################################################### <a id='L18' name='L18'></a># マクロ <a id='L19' name='L19'></a>###################################################################### <a id='L20' name='L20'></a># 指定されたファイルをチェックし、空の場合は削除 <a id='L21' name='L21'></a># 引数は、対象ファイル <a id='L22' name='L22'></a># 用例: $(call rm_null,file_target) <a id='L23' name='L23'></a>define rm_null <a id='L24' name='L24'></a> if test ! -s $1; then $(RM) $1; fi <a id='L25' name='L25'></a>endef <a id='L26' name='L26'></a> <a id='L27' name='L27'></a># 説明ファイルの内容を、指定されたファイルに出力 <a id='L28' name='L28'></a># 引数は、出力ファイル <a id='L29' name='L29'></a># 用例: $(call desc_log,file_out) <a id='L30' name='L30'></a>define desc_log <a id='L31' name='L31'></a> if test -s $(DESC_FILE); then $(CAT) $(DESC_FILE) >>$1; fi <a id='L32' name='L32'></a>endef <a id='L33' name='L33'></a> <a id='L34' name='L34'></a># テスト実行の経過時間を、指定されたファイルに出力して表示 <a id='L35' name='L35'></a># 引数は、テスト名、コマンドファイル、出力ファイル <a id='L36' name='L36'></a># 用例: $(call time_cmd,file_cmd,file_out) <a id='L37' name='L37'></a>define time_cmd <a id='L38' name='L38'></a> if test ! -x $1; then $(CHMOD) u+x $1; fi <a id='L39' name='L39'></a> ($(TIME) ./$1 1>$(DEV_NULL) 2>$(DEV_NULL)) 2>&1 | $(GREP) '^real' >$2 <a id='L40' name='L40'></a>endef <a id='L41' name='L41'></a> <a id='L42' name='L42'></a>VALGRIND_CMD = $(strip $(shell if test -s $(VALGRIND_CMD_FILE); then $(CAT) $(VALGRIND_CMD_FILE); elif test "`$(FILE) $(CMD_FILE)`" = "data"; then $(CAT) $(CMD_FILE); else $(PRINTF) "./$(CMD_FILE)"; fi)) <a id='L43' name='L43'></a> <a id='L44' name='L44'></a># valgrindによるメモリーチェック結果を、指定されたファイルに出力して表示 <a id='L45' name='L45'></a># 引数は、テスト名、コマンドファイル、出力ファイル <a id='L46' name='L46'></a># 用例: $(call valgrind_cmd,file_cmd,file_out) <a id='L47' name='L47'></a>define valgrind_cmd <a id='L48' name='L48'></a> -$(VALGRIND) $(VALGRINDFLAG) $(VALGRIND_CMD) 1>/dev/null 2>&1 <a id='L49' name='L49'></a>endef <a id='L50' name='L50'></a> <a id='L51' name='L51'></a># テスト実行コマンド <a id='L52' name='L52'></a># コマンドファイルを実行し、標準出力を指定されたファイルに保存。 <a id='L53' name='L53'></a># エラー発生時は、エラー出力を出力ファイルとエラーファイルに保存。 <a id='L54' name='L54'></a># 引数は、コマンドファイル、出力ファイル、エラーファイル <a id='L55' name='L55'></a># 用例: $(call exec_cmd,file_cmd,file_out,file_err) <a id='L56' name='L56'></a>define exec_cmd <a id='L57' name='L57'></a> if test ! -x $1; then $(CHMOD) u+x $1; fi <a id='L58' name='L58'></a> ./$1 >>$2 2>$3 <a id='L59' name='L59'></a> if test -s $3; then $(CAT) $3 >>$2; fi <a id='L60' name='L60'></a> $(MV) $2 $2.tmp && $(SED) -e "s%$(CURDIR)%\$$PWD%g" $2.tmp >$2 && $(RM) $2.tmp <a id='L61' name='L61'></a> $(call rm_null,$3) <a id='L62' name='L62'></a>endef <a id='L63' name='L63'></a> <a id='L64' name='L64'></a># 2つのファイルを比較し、差分ファイルを作成 <a id='L65' name='L65'></a># 引数は、2ファイルのリスト、差分ファイル <a id='L66' name='L66'></a># 用例: $(call diff_files,files,file_out) <a id='L67' name='L67'></a>define diff_files <a id='L68' name='L68'></a> $(DIFF) $1 >$2 2>&1 <a id='L69' name='L69'></a> $(call rm_null,$2) <a id='L70' name='L70'></a>endef <a id='L71' name='L71'></a> <a id='L72' name='L72'></a># 差分ファイルの内容をログファイルに出力 <a id='L73' name='L73'></a># 引数は、テスト名、差分ファイル、ログファイル <a id='L74' name='L74'></a># 用例: $(call test_log,name,file_diff,file_log) <a id='L75' name='L75'></a>define test_log <a id='L76' name='L76'></a> $(call desc_log,$3) <a id='L77' name='L77'></a> if test ! -s $2; then RES=Success; else RES=Failure; fi; $(ECHO) "$1: Test $$RES $(DATE)" >>$3 <a id='L78' name='L78'></a> $(ECHO) "Details in $(CURDIR)/$(DETAIL_FILE)" >>$3 <a id='L79' name='L79'></a>endef <a id='L80' name='L80'></a> <a id='L81' name='L81'></a># NODISPが設定されていない時は、ログファイルを表示 <a id='L82' name='L82'></a># 引数は、ログファイル <a id='L83' name='L83'></a># 用例: $(call disp_test_log,file_log) <a id='L84' name='L84'></a>define disp_test_log <a id='L85' name='L85'></a> $(if $(NODISP),,$(CAT) $1) <a id='L86' name='L86'></a>endef <a id='L87' name='L87'></a> <a id='L88' name='L88'></a># ファイル群から、ファイル名とファイルの内容を指定されたファイルに出力 <a id='L89' name='L89'></a># 引数は、対象ファイル群、出力ファイル <a id='L90' name='L90'></a># 用例: $(call report_files,list_file_target,file_out) <a id='L91' name='L91'></a>define report_files <a id='L92' name='L92'></a> $(foreach tfile,$1,$(call report_file,$(tfile),$2)) <a id='L93' name='L93'></a>endef <a id='L94' name='L94'></a> <a id='L95' name='L95'></a># ファイル名とファイルの内容を指定されたファイルに出力 <a id='L96' name='L96'></a># 引数は、対象ファイル、出力ファイル <a id='L97' name='L97'></a># 用例: $(call report_file,file_target,file_out) <a id='L98' name='L98'></a>define report_file <a id='L99' name='L99'></a> $(call chk_var_null,$1) <a id='L100' name='L100'></a> if test -s $1; then $(ECHO) "== $1 ==" >>$2; $(call echo_hr,$2); cat $1 >>$2; $(call echo_hr,$2); $(ECHO) >>$2; fi <a id='L101' name='L101'></a>endef <a id='L102' name='L102'></a> <a id='L103' name='L103'></a>define echo_hr <a id='L104' name='L104'></a> $(ECHO) "----------------------------------------------------------------------" >>$1 <a id='L105' name='L105'></a>endef <a id='L106' name='L106'></a> <a id='L107' name='L107'></a># テスト名。カレントディレクトリー名から取得 <a id='L108' name='L108'></a>TEST = $(notdir $(CURDIR)) <a id='L109' name='L109'></a> <a id='L110' name='L110'></a># コマンドファイルのソース <a id='L111' name='L111'></a>CMDSRC_FILE ?= $(CMD_FILE) <a id='L112' name='L112'></a> <a id='L113' name='L113'></a>.PHONY: check set reset clean all-clean time time-clean valgrind valgrind-clean <a id='L114' name='L114'></a> <a id='L115' name='L115'></a>check: clean $(DETAIL_FILE) <a id='L116' name='L116'></a> @$(call disp_test_log,$(LOG_FILE)) <a id='L117' name='L117'></a> <a id='L118' name='L118'></a>checkall: clean $(DETAIL_FILE) $(TIME_FILE) <a id='L119' name='L119'></a> @$(CAT) $(TIME_FILE) >>$(LOG_FILE) <a id='L120' name='L120'></a> @$(call disp_test_log,$(LOG_FILE)) <a id='L121' name='L121'></a> <a id='L122' name='L122'></a>set: $(CMD_FILE) <a id='L123' name='L123'></a> @$(call chk_file_ext,$(TEST0_FILE)) <a id='L124' name='L124'></a> @-$(call exec_cmd,$(CMD_FILE),$(TEST0_FILE),$(ERR_FILE)) <a id='L125' name='L125'></a> @$(CAT) $(TEST0_FILE) <a id='L126' name='L126'></a> <a id='L127' name='L127'></a>reset: all-clean $(CMD_FILE) <a id='L128' name='L128'></a> @-$(call exec_cmd,$(CMD_FILE),$(TEST0_FILE),$(ERR_FILE)) <a id='L129' name='L129'></a> @$(CAT) $(TEST0_FILE) <a id='L130' name='L130'></a> <a id='L131' name='L131'></a>clean: <a id='L132' name='L132'></a> @$(RM) $(TEST_RES_FILES) $(TIME_FILE) $(VALGRIND_LOGFILE) $(VALGRIND_CMDLOGFILE) core <a id='L133' name='L133'></a> <a id='L134' name='L134'></a>all-clean: clean <a id='L135' name='L135'></a> @$(RM) $(TEST0_FILE) <a id='L136' name='L136'></a> <a id='L137' name='L137'></a>time: time-clean $(TIME_FILE) <a id='L138' name='L138'></a> @$(CAT) $(TIME_FILE) <a id='L139' name='L139'></a> <a id='L140' name='L140'></a>time-clean: <a id='L141' name='L141'></a> @$(RM) $(TIME_FILE) <a id='L142' name='L142'></a> <a id='L143' name='L143'></a>valgrind: valgrind-clean $(VALGRIND_LOGFILE) $(VALGRIND_CMDLOGFILE) <a id='L144' name='L144'></a> if test -s $(VALGRIND_LOGFILE); then $(ECHO) $(CURDIR) && $(CAT) $(VALGRIND_LOGFILE); else $(RM) $(VALGRIND_LOGFILE); fi <a id='L145' name='L145'></a> <a id='L146' name='L146'></a>$(VALGRIND_CMDLOGFILE): $(VALGRIND_LOGFILE) <a id='L147' name='L147'></a> @$(PRINTF) "$(VALGRIND) $(VALGRINDFLAG) $(VALGRIND_CMD)\n" | $(CAT) - $(VALGRIND_LOGFILE) >$(VALGRIND_CMDLOGFILE) <a id='L148' name='L148'></a> <a id='L149' name='L149'></a>valgrind-clean: <a id='L150' name='L150'></a> @$(RM) $(VALGRIND_LOGFILE) <a id='L151' name='L151'></a> <a id='L152' name='L152'></a>$(TEST1_FILE): $(CMD_FILE) <a id='L153' name='L153'></a> @-$(call exec_cmd,$^,$@,$(ERR_FILE)) <a id='L154' name='L154'></a> <a id='L155' name='L155'></a>$(DIFF_FILE): $(TEST0_FILE) $(TEST1_FILE) <a id='L156' name='L156'></a> @-$(call diff_files,$^,$@) <a id='L157' name='L157'></a> <a id='L158' name='L158'></a>$(LOG_FILE): $(DIFF_FILE) <a id='L159' name='L159'></a> @$(call test_log,$(TEST),$^,$@) <a id='L160' name='L160'></a> <a id='L161' name='L161'></a>$(DETAIL_FILE): $(LOG_FILE) <a id='L162' name='L162'></a> @$(call report_files,$(LOG_FILE) $(CMDSRC_FILE) $(TEST0_FILE) $(ERR_FILE) $(DIFF_FILE) $(TEST1_FILE),$@) <a id='L163' name='L163'></a> <a id='L164' name='L164'></a>$(TIME_FILE): $(CMD_FILE) <a id='L165' name='L165'></a> @$(call time_cmd,$^,$@) <a id='L166' name='L166'></a> <a id='L167' name='L167'></a>$(VALGRIND_LOGFILE): $(CMD_FILE) <a id='L168' name='L168'></a> $(call valgrind_cmd,$^,$@) </pre> <hr /> <a id='BOTTOM' name='BOTTOM'></a> <em class='comment'>/* [<][>][^][v]<a href='#TOP'>[top]</a>[bottom]<a href='../mains.html'>[index]</a><a href='../help.html'>[help]</a> */</em> </body> </html>