<!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/casl2_opt/Makefile</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/3112.html'>casl2_opt</a>/Makefile</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 > template > Group.mk <a id='L2' name='L2'></a># テストグループのMakefile <a id='L3' name='L3'></a># <a id='L4' name='L4'></a># オペレーター <a id='L5' name='L5'></a># make : すべてのテストを実行し、結果をログファイルに出力 <a id='L6' name='L6'></a># make check : ↓ <a id='L7' name='L7'></a># make checkall : すべてのテストを実行し、結果と実行時間をログファイルに出力 <a id='L8' name='L8'></a># make time : すべてのテストを実行し、実行時間をログファイルに出力 <a id='L9' name='L9'></a># make create : TESTNAMEで指定されたテストを新規に作成 <a id='L10' name='L10'></a># make clean : すべてのテストで、"make" で生成されたファイルをクリア <a id='L11' name='L11'></a># make time-clean: すべてのテストで、実行時間のログファイルをクリア <a id='L12' name='L12'></a># make valgrind: すべてのテストで、valgrindによるメモリリークチェックを実行する <a id='L13' name='L13'></a># make valgrind-clean: すべてのテストで、valgrindのログファイルをクリア <a id='L14' name='L14'></a> <a id='L15' name='L15'></a>include Define.mk <a id='L16' name='L16'></a> <a id='L17' name='L17'></a>verbose ?= 1 <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> <a id='L23' name='L23'></a># グループディレクトリー <a id='L24' name='L24'></a>GROUP_DIR := $(CURDIR) <a id='L25' name='L25'></a> <a id='L26' name='L26'></a># グループ名。ディレクトリ名から取得 <a id='L27' name='L27'></a>GROUP := $(notdir $(GROUP_DIR)) <a id='L28' name='L28'></a> <a id='L29' name='L29'></a># テスト名。カレントディレクトリー内の、名前が大文字または.以外で始まるディレクトリー <a id='L30' name='L30'></a>TESTS := $(notdir $(shell $(FIND) . -maxdepth 1 -name "[^A-Z.]*" -type d)) <a id='L31' name='L31'></a> <a id='L32' name='L32'></a># テストグループログファイル <a id='L33' name='L33'></a>GROUP_LOG_FILE := $(shell $(ECHO) $(GROUP) | $(TR) '[a-z]' '[A-Z]').log <a id='L34' name='L34'></a> <a id='L35' name='L35'></a># テストグループレポートファイル <a id='L36' name='L36'></a>GROUP_REPORT_FILE := Summary.log <a id='L37' name='L37'></a> <a id='L38' name='L38'></a># テストグループ実行時間ファイル <a id='L39' name='L39'></a>GROUP_TIME_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_time.log <a id='L40' name='L40'></a> <a id='L41' name='L41'></a># テストグループvalgrindファイル <a id='L42' name='L42'></a>GROUP_VALGRIND_FILE := $(shell echo $(GROUP) | $(TR) '[a-z]' '[A-Z]')_valgrind.log <a id='L43' name='L43'></a> <a id='L44' name='L44'></a># グループで、テスト結果として作成されるファイル群 <a id='L45' name='L45'></a>GROUP_RES_FILES := $(GROUP_LOG_FILE) $(GROUP_REPORT_FILE) $(GROUP_TIME_FILE) $(GROUP_VALGRIND_FILE) <a id='L46' name='L46'></a> <a id='L47' name='L47'></a># テストごとのログファイル <a id='L48' name='L48'></a>TEST_LOG_FILES := $(foreach test,$(TESTS),$(test)/$(LOG_FILE)) <a id='L49' name='L49'></a> <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># 引数は、テストのリスト、グループファイル、テストファイル <a id='L56' name='L56'></a># 用例: $(call group_log,files_test_log,file_group_log) <a id='L57' name='L57'></a>define group_log <a id='L58' name='L58'></a> $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $(words $1) tests') <a id='L59' name='L59'></a> $(foreach target,$1,$(call group_log_each,$(target),$2)) <a id='L60' name='L60'></a>endef <a id='L61' name='L61'></a> <a id='L62' name='L62'></a># テストのログファイルをグループログファイルに出力。引数は、テスト、グループログファイル <a id='L63' name='L63'></a># 用例: $(call group_log_each,file_test_log,file_group_log) <a id='L64' name='L64'></a>define group_log_each <a id='L65' name='L65'></a> $(ECHO) $(dir $1) >>$2; <a id='L66' name='L66'></a> if $(TEST) -s $1; then $(CAT) $1 >>$2; else $(ECHO) $(dir $1)": no log" >>$2; fi <a id='L67' name='L67'></a> $(ECHO) >>$2; <a id='L68' name='L68'></a>endef <a id='L69' name='L69'></a> <a id='L70' name='L70'></a># 成功したテストの数。テストグループログファイルから取得 <a id='L71' name='L71'></a>SUCCESS_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Success" $(GROUP_LOG_FILE) | $(LINECOUNT)) <a id='L72' name='L72'></a> <a id='L73' name='L73'></a># 失敗したテストの数。テストグループログファイルから取得 <a id='L74' name='L74'></a>FAIL_TEST = $(shell $(GREP) "^[^A-Z.].*: Test Failure" $(GROUP_LOG_FILE) | $(LINECOUNT)) <a id='L75' name='L75'></a> <a id='L76' name='L76'></a># すべてのテストの数 <a id='L77' name='L77'></a>ALL_TEST = $(shell $(EXPR) $(SUCCESS_TEST) + $(FAIL_TEST)) <a id='L78' name='L78'></a> <a id='L79' name='L79'></a># テストごとの実行時間ファイル <a id='L80' name='L80'></a>TEST_TIME_FILES := $(foreach test,$(TESTS),$(test)/$(TIME_FILE)) <a id='L81' name='L81'></a> <a id='L82' name='L82'></a># テストごとのvalgrindファイル <a id='L83' name='L83'></a>TEST_VALGRIND_FILES := $(foreach test,$(TESTS),$(test)/$(VALGRIND_FILE)) <a id='L84' name='L84'></a> <a id='L85' name='L85'></a># テストの結果を、グループログファイルを元にレポート。 <a id='L86' name='L86'></a># 引数は、グループ名、グループログファイル、グループレポートファイル <a id='L87' name='L87'></a># 用例: $(call group_report,name,file_log,file_report) <a id='L88' name='L88'></a>define group_report <a id='L89' name='L89'></a> $(ECHO) '$1: $(SUCCESS_TEST) / $(ALL_TEST) tests passed. Details in $(GROUP_DIR)/$2' >$3 <a id='L90' name='L90'></a> if $(TEST) $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." >>$3; fi <a id='L91' name='L91'></a>endef <a id='L92' name='L92'></a> <a id='L93' name='L93'></a># リストで指定したディレクトリーでmakeを実行 <a id='L94' name='L94'></a># 用例: $(call make_targets,list_dir,target) <a id='L95' name='L95'></a>define make_targets <a id='L96' name='L96'></a> $(if $(filter 1,$(verbose)),$(ECHO) '$(CURDIR) - $2';) <a id='L97' name='L97'></a> $(foreach dir,$1,$(call make_target_each,$(dir),$2)) <a id='L98' name='L98'></a>endef <a id='L99' name='L99'></a> <a id='L100' name='L100'></a># 指定したディレクトリーでmakeを実行 <a id='L101' name='L101'></a># 用例: $(call make_target_each,tests,target) <a id='L102' name='L102'></a>define make_target_each <a id='L103' name='L103'></a> $(MAKE) $2 -sC $1; <a id='L104' name='L104'></a>endef <a id='L105' name='L105'></a> <a id='L106' name='L106'></a>.PHONY: check checkall time valgrind create clean time-clean valgrind-clean <a id='L107' name='L107'></a> <a id='L108' name='L108'></a>check checkall: clean $(GROUP_REPORT_FILE) <a id='L109' name='L109'></a> @$(CAT) $(GROUP_REPORT_FILE) <a id='L110' name='L110'></a> @(if $(TEST) $(FAIL_TEST) -gt 0; then $(GREP) 'Failure' $(GROUP_LOG_FILE); fi) <a id='L111' name='L111'></a> @exit $(FAIL_TEST) <a id='L112' name='L112'></a> <a id='L113' name='L113'></a>time: time-clean $(GROUP_TIME_FILE) <a id='L114' name='L114'></a> @$(CAT) $(GROUP_TIME_FILE) <a id='L115' name='L115'></a> <a id='L116' name='L116'></a>create: <a id='L117' name='L117'></a> @$(call create_dir,$(TEST)) <a id='L118' name='L118'></a> @$(call create_makefile,$(TEST)/$(MAKEFILE),$(MAKEFILES)) <a id='L119' name='L119'></a> <a id='L120' name='L120'></a>clean: <a id='L121' name='L121'></a> @$(call make_targets,$(TESTS),$@) <a id='L122' name='L122'></a> @$(RM) $(GROUP_RES_FILES); <a id='L123' name='L123'></a> <a id='L124' name='L124'></a>time-clean: <a id='L125' name='L125'></a> @$(call make_targets,$(TESTS),$@) <a id='L126' name='L126'></a> @$(RM) $(GROUP_TIME_FILE); <a id='L127' name='L127'></a> <a id='L128' name='L128'></a>valgrind: <a id='L129' name='L129'></a> @$(call make_targets,$(TESTS),$@) <a id='L130' name='L130'></a> @$(RM) $(GROUP_RES_FILES); <a id='L131' name='L131'></a> <a id='L132' name='L132'></a>valgrind-clean: <a id='L133' name='L133'></a> @$(call make_targets,$(TESTS),$@) <a id='L134' name='L134'></a> @$(RM) $(GROUP_VALGRIND_FILE); <a id='L135' name='L135'></a> <a id='L136' name='L136'></a>$(GROUP_REPORT_FILE): $(GROUP_LOG_FILE) <a id='L137' name='L137'></a> @$(call group_report,$(GROUP),$^,$@) <a id='L138' name='L138'></a> <a id='L139' name='L139'></a>$(GROUP_LOG_FILE): $(TEST_LOG_FILES) <a id='L140' name='L140'></a> @$(call group_log,$^,$@) <a id='L141' name='L141'></a> <a id='L142' name='L142'></a>$(TEST_LOG_FILES): <a id='L143' name='L143'></a> @$(MAKE) $(MAKECMDGOALS) -sC $(dir $@) NODISP=1 <a id='L144' name='L144'></a> <a id='L145' name='L145'></a>$(GROUP_TIME_FILE): $(TEST_TIME_FILES) <a id='L146' name='L146'></a> @$(call group_log,$^,$@) <a id='L147' name='L147'></a> <a id='L148' name='L148'></a>$(TEST_TIME_FILES): <a id='L149' name='L149'></a> @$(MAKE) time -sC $(dir $@) <a id='L150' name='L150'></a> <a id='L151' name='L151'></a>$(GROUP_VALGRIND_FILE): $(TEST_VALGRIND_FILES) <a id='L152' name='L152'></a> @$(call group_log,$^,$@) <a id='L153' name='L153'></a> <a id='L154' name='L154'></a>$(TEST_VALGRIND_FILES): <a id='L155' name='L155'></a> @$(MAKE) time -sC $(dir $@) </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>