root/doc_inner/gnu_global/S/1056.html

/* [<][>][^][v][top][bottom][index][help] */
<!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/comet2monitor/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/3295.html'>comet2monitor</a>/Makefile</h2>
<em class='comment'>/* [&lt;][&gt;][^][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 &gt; template &gt; 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) &gt;&gt;$2;
<a id='L66' name='L66'></a>    if $(TEST) -s $1; then $(CAT) $1 &gt;&gt;$2; else $(ECHO) $(dir $1)": no log" &gt;&gt;$2; fi
<a id='L67' name='L67'></a>    $(ECHO) &gt;&gt;$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' &gt;$3
<a id='L90' name='L90'></a>    if $(TEST) $(FAIL_TEST) -eq 0; then $(ECHO) "$1: All tests are succeded." &gt;&gt;$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'>/* [&lt;][&gt;][^][v]<a href='#TOP'>[top]</a>[bottom]<a href='../mains.html'>[index]</a><a href='../help.html'>[help]</a> */</em>
</body>
</html>

/* [<][>][^][v][top][bottom][index][help] */