123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573 |
- ## automake - create Makefile.in from Makefile.am
- ## Copyright (C) 2001-2017 Free Software Foundation, Inc.
- ## This program is free software; you can redistribute it and/or modify
- ## it under the terms of the GNU General Public License as published by
- ## the Free Software Foundation; either version 2, or (at your option)
- ## any later version.
- ## This program is distributed in the hope that it will be useful,
- ## but WITHOUT ANY WARRANTY; without even the implied warranty of
- ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- ## GNU General Public License for more details.
- ## You should have received a copy of the GNU General Public License
- ## along with this program. If not, see <http://www.gnu.org/licenses/>.
- am__tty_colors_dummy = \
- mgn= red= grn= lgn= blu= brg= std=; \
- am__color_tests=no
- am__tty_colors = { \
- $(am__tty_colors_dummy); \
- if test "X$(AM_COLOR_TESTS)" = Xno; then \
- am__color_tests=no; \
- elif test "X$(AM_COLOR_TESTS)" = Xalways; then \
- am__color_tests=yes; \
- ## If stdout is a non-dumb tty, use colors. If test -t is not supported,
- ## then this check fails; a conservative approach. Of course do not
- ## redirect stdout here, just stderr.
- elif test "X$$TERM" != Xdumb && { test -t 1; } 2>/dev/null; then \
- am__color_tests=yes; \
- fi; \
- if test $$am__color_tests = yes; then \
- red='[0;31m'; \
- grn='[0;32m'; \
- lgn='[1;32m'; \
- blu='[1;34m'; \
- mgn='[0;35m'; \
- brg='[1m'; \
- std='[m'; \
- fi; \
- }
- .PHONY: check-TESTS
- if !%?SERIAL_TESTS%
- include inst-vars.am
- ## New parallel test driver.
- ##
- ## The first version of the code here was adapted from check.mk, which was
- ## originally written at EPITA/LRDE, further developed at Gostai, then made
- ## its way from GNU coreutils to end up, largely rewritten, in Automake.
- ## The current version is an heavy rewrite of that, to allow for support
- ## of more test metadata, and the use of custom test drivers and protocols
- ## (among them, TAP).
- am__recheck_rx = ^[ ]*:recheck:[ ]*
- am__global_test_result_rx = ^[ ]*:global-test-result:[ ]*
- am__copy_in_global_log_rx = ^[ ]*:copy-in-global-log:[ ]*
- # A command that, given a newline-separated list of test names on the
- # standard input, print the name of the tests that are to be re-run
- # upon "make recheck".
- am__list_recheck_tests = $(AWK) '{ \
- ## By default, we assume the test is to be re-run.
- recheck = 1; \
- while ((rc = (getline line < ($$0 ".trs"))) != 0) \
- { \
- if (rc < 0) \
- { \
- ## If we've encountered an I/O error here, there are three possibilities:
- ##
- ## [1] The '.log' file exists, but the '.trs' does not; in this case,
- ## we "gracefully" recover by assuming the corresponding test is
- ## to be re-run (which will re-create the missing '.trs' file).
- ##
- ## [2] Both the '.log' and '.trs' files are missing; this means that
- ## the corresponding test has not been run, and is thus *not* to
- ## be re-run.
- ##
- ## [3] We have encountered some corner-case problem (e.g., a '.log' or
- ## '.trs' files somehow made unreadable, or issues with a bad NFS
- ## connection, or whatever); we don't handle such corner cases.
- ##
- if ((getline line2 < ($$0 ".log")) < 0) \
- recheck = 0; \
- break; \
- } \
- else if (line ~ /$(am__recheck_rx)[nN][Oo]/) \
- ## A directive explicitly specifying the test is *not* to be re-run.
- { \
- recheck = 0; \
- break; \
- } \
- else if (line ~ /$(am__recheck_rx)[yY][eE][sS]/) \
- { \
- ## A directive explicitly specifying the test *is* to be re-run.
- break; \
- } \
- ## else continue with the next iteration.
- }; \
- if (recheck) \
- print $$0; \
- ## Don't leak open file descriptors, as this could cause serious
- ## problems when there are many tests (yes, even on Linux).
- close ($$0 ".trs"); \
- close ($$0 ".log"); \
- }'
- # A command that, given a newline-separated list of test names on the
- # standard input, create the global log from their .trs and .log files.
- am__create_global_log = $(AWK) ' \
- function fatal(msg) \
- { \
- print "fatal: making $@: " msg | "cat >&2"; \
- exit 1; \
- } \
- function rst_section(header) \
- { \
- print header; \
- len = length(header); \
- for (i = 1; i <= len; i = i + 1) \
- printf "="; \
- printf "\n\n"; \
- } \
- { \
- ## By default, we assume the test log is to be copied in the global log,
- ## and that its result is simply "RUN" (i.e., we still don't know what
- ## it outcome was, but we know that at least it has run).
- copy_in_global_log = 1; \
- global_test_result = "RUN"; \
- while ((rc = (getline line < ($$0 ".trs"))) != 0) \
- { \
- if (rc < 0) \
- fatal("failed to read from " $$0 ".trs"); \
- if (line ~ /$(am__global_test_result_rx)/) \
- { \
- sub("$(am__global_test_result_rx)", "", line); \
- sub("[ ]*$$", "", line); \
- global_test_result = line; \
- } \
- else if (line ~ /$(am__copy_in_global_log_rx)[nN][oO]/) \
- copy_in_global_log = 0; \
- }; \
- if (copy_in_global_log) \
- { \
- rst_section(global_test_result ": " $$0); \
- while ((rc = (getline line < ($$0 ".log"))) != 0) \
- { \
- if (rc < 0) \
- fatal("failed to read from " $$0 ".log"); \
- print line; \
- }; \
- printf "\n"; \
- }; \
- ## Don't leak open file descriptors, as this could cause serious
- ## problems when there are many tests (yes, even on Linux).
- close ($$0 ".trs"); \
- close ($$0 ".log"); \
- }'
- # Restructured Text title.
- am__rst_title = { sed 's/.*/ & /;h;s/./=/g;p;x;s/ *$$//;p;g' && echo; }
- # Solaris 10 'make', and several other traditional 'make' implementations,
- # pass "-e" to $(SHELL), and POSIX 2008 even requires this. Work around it
- # by disabling -e (using the XSI extension "set +e") if it's set.
- am__sh_e_setup = case $$- in *e*) set +e;; esac
- # Default flags passed to test drivers.
- am__common_driver_flags = \
- --color-tests "$$am__color_tests" \
- --enable-hard-errors "$$am__enable_hard_errors" \
- --expect-failure "$$am__expect_failure"
- # To be inserted before the command running the test. Creates the
- # directory for the log if needed. Stores in $dir the directory
- # containing $f, in $tst the test, in $log the log. Executes the
- # developer- defined test setup AM_TESTS_ENVIRONMENT (if any), and
- # passes TESTS_ENVIRONMENT. Set up options for the wrapper that
- # will run the test scripts (or their associated LOG_COMPILER, if
- # thy have one).
- am__check_pre = \
- $(am__sh_e_setup); \
- $(am__vpath_adj_setup) $(am__vpath_adj) \
- $(am__tty_colors); \
- srcdir=$(srcdir); export srcdir; \
- case "$@" in \
- */*) am__odir=`echo "./$@" | sed 's|/[^/]*$$||'`;; \
- *) am__odir=.;; \
- esac; \
- test "x$$am__odir" = x"." || test -d "$$am__odir" \
- || $(MKDIR_P) "$$am__odir" || exit $$?; \
- if test -f "./$$f"; then dir=./; \
- elif test -f "$$f"; then dir=; \
- else dir="$(srcdir)/"; fi; \
- tst=$$dir$$f; log='$@'; \
- if test -n '$(DISABLE_HARD_ERRORS)'; then \
- am__enable_hard_errors=no; \
- else \
- am__enable_hard_errors=yes; \
- fi; \
- ## The use of $dir below is required to account for VPATH
- ## rewriting done by Sun make.
- case " $(XFAIL_TESTS) " in \
- *[\ \ ]$$f[\ \ ]* | *[\ \ ]$$dir$$f[\ \ ]*) \
- am__expect_failure=yes;; \
- *) \
- am__expect_failure=no;; \
- esac; \
- $(AM_TESTS_ENVIRONMENT) $(TESTS_ENVIRONMENT)
- # A shell command to get the names of the tests scripts with any registered
- # extension removed (i.e., equivalently, the names of the test logs, with
- # the '.log' extension removed). The result is saved in the shell variable
- # '$bases'. This honors runtime overriding of TESTS and TEST_LOGS. Sadly,
- # we cannot use something simpler, involving e.g., "$(TEST_LOGS:.log=)",
- # since that might cause problem with VPATH rewrites for suffix-less tests.
- # See also 'test-harness-vpath-rewrite.sh' and 'test-trs-basic.sh'.
- am__set_TESTS_bases = \
- bases='$(TEST_LOGS)'; \
- bases=`for i in $$bases; do echo $$i; done | sed 's/\.log$$//'`; \
- ## Trim away any extra whitespace. This has already proved useful
- ## in avoiding weird bug on lesser make implementations. It also
- ## works around the GNU make 3.80 bug where trailing whitespace in
- ## "TESTS = foo.test $(empty)" causes $(TESTS_LOGS) to erroneously
- ## expand to "foo.log .log".
- bases=`echo $$bases`
- # Recover from deleted '.trs' file; this should ensure that
- # "rm -f foo.log; make foo.trs" re-run 'foo.test', and re-create
- # both 'foo.log' and 'foo.trs'. Break the recipe in two subshells
- # to avoid problems with "make -n".
- .log.trs:
- rm -f $< $@
- $(MAKE) $(AM_MAKEFLAGS) $<
- # Leading 'am--fnord' is there to ensure the list of targets does not
- # expand to empty, as could happen e.g. with make check TESTS=''.
- am--fnord $(TEST_LOGS) $(TEST_LOGS:.log=.trs): $(am__force_recheck)
- am--force-recheck:
- @:
- $(TEST_SUITE_LOG): $(TEST_LOGS)
- @$(am__set_TESTS_bases); \
- ## Helper shell function, tells whether a path refers to an existing,
- ## regular, readable file.
- am__f_ok () { test -f "$$1" && test -r "$$1"; }; \
- ## We need to ensures that all the required '.trs' and '.log' files will
- ## be present and readable. The direct dependencies of $(TEST_SUITE_LOG)
- ## only ensure that all the '.log' files exists; they don't ensure that
- ## the '.log' files are readable, and worse, they don't ensure that the
- ## '.trs' files even exist.
- redo_bases=`for i in $$bases; do \
- am__f_ok $$i.trs && am__f_ok $$i.log || echo $$i; \
- done`; \
- if test -n "$$redo_bases"; then \
- ## Uh-oh, either some '.log' files were unreadable, or some '.trs' files
- ## were missing (or unreadable). We need to re-run the corresponding
- ## tests in order to re-create them.
- redo_logs=`for i in $$redo_bases; do echo $$i.log; done`; \
- redo_results=`for i in $$redo_bases; do echo $$i.trs; done`; \
- if $(am__make_dryrun); then :; else \
- ## Break "rm -f" into two calls to minimize the possibility of exceeding
- ## command line length limits.
- rm -f $$redo_logs && rm -f $$redo_results || exit 1; \
- fi; \
- fi; \
- ## Use a trick to to ensure that we don't go into an infinite recursion
- ## in case a test log in $(TEST_LOGS) is the same as $(TEST_SUITE_LOG).
- ## Yes, this has already happened in practice. Sigh!
- if test -n "$$am__remaking_logs"; then \
- echo "fatal: making $(TEST_SUITE_LOG): possible infinite" \
- "recursion detected" >&2; \
- ## Invoking this unconditionally could cause a useless "make all" to
- ## be invoked when '$redo_logs' expands to empty (automake bug#16302).
- elif test -n "$$redo_logs"; then \
- am__remaking_logs=yes $(MAKE) $(AM_MAKEFLAGS) $$redo_logs; \
- fi; \
- if $(am__make_dryrun); then :; else \
- ## Sanity check: each unreadable or non-existent test result file should
- ## has been properly remade at this point, as should the corresponding log
- ## file.
- st=0; \
- errmsg="fatal: making $(TEST_SUITE_LOG): failed to create"; \
- for i in $$redo_bases; do \
- test -f $$i.trs && test -r $$i.trs \
- || { echo "$$errmsg $$i.trs" >&2; st=1; }; \
- test -f $$i.log && test -r $$i.log \
- || { echo "$$errmsg $$i.log" >&2; st=1; }; \
- done; \
- test $$st -eq 0 || exit 1; \
- fi
- ## We need a new subshell to work portably with "make -n", since the
- ## previous part of the recipe contained a $(MAKE) invocation.
- @$(am__sh_e_setup); $(am__tty_colors); $(am__set_TESTS_bases); \
- ws='[ ]'; \
- ## List of test result files.
- results=`for b in $$bases; do echo $$b.trs; done`; \
- test -n "$$results" || results=/dev/null; \
- ## Prepare data for the test suite summary. These do not take into account
- ## unreadable test results, but they'll be appropriately updated later if
- ## needed.
- all=` grep "^$$ws*:test-result:" $$results | wc -l`; \
- pass=` grep "^$$ws*:test-result:$$ws*PASS" $$results | wc -l`; \
- fail=` grep "^$$ws*:test-result:$$ws*FAIL" $$results | wc -l`; \
- skip=` grep "^$$ws*:test-result:$$ws*SKIP" $$results | wc -l`; \
- xfail=`grep "^$$ws*:test-result:$$ws*XFAIL" $$results | wc -l`; \
- xpass=`grep "^$$ws*:test-result:$$ws*XPASS" $$results | wc -l`; \
- error=`grep "^$$ws*:test-result:$$ws*ERROR" $$results | wc -l`; \
- ## Whether the testsuite was successful or not.
- if test `expr $$fail + $$xpass + $$error` -eq 0; then \
- success=true; \
- else \
- success=false; \
- fi; \
- ## Make $br a line of exactly 76 '=' characters, that will be used to
- ## enclose the testsuite summary report when displayed on the console.
- br='==================='; br=$$br$$br$$br$$br; \
- ## When writing the test summary to the console, we want to color a line
- ## reporting the count of some result *only* if at least one test
- ## experienced such a result. This function is handy in this regard.
- result_count () \
- { \
- if test x"$$1" = x"--maybe-color"; then \
- maybe_colorize=yes; \
- elif test x"$$1" = x"--no-color"; then \
- maybe_colorize=no; \
- else \
- echo "$@: invalid 'result_count' usage" >&2; exit 4; \
- fi; \
- shift; \
- desc=$$1 count=$$2; \
- if test $$maybe_colorize = yes && test $$count -gt 0; then \
- color_start=$$3 color_end=$$std; \
- else \
- color_start= color_end=; \
- fi; \
- echo "$${color_start}# $$desc $$count$${color_end}"; \
- }; \
- ## A shell function that creates the testsuite summary. We need it
- ## because we have to create *two* summaries, one for test-suite.log,
- ## and a possibly-colorized one for console output.
- create_testsuite_report () \
- { \
- result_count $$1 "TOTAL:" $$all "$$brg"; \
- result_count $$1 "PASS: " $$pass "$$grn"; \
- result_count $$1 "SKIP: " $$skip "$$blu"; \
- result_count $$1 "XFAIL:" $$xfail "$$lgn"; \
- result_count $$1 "FAIL: " $$fail "$$red"; \
- result_count $$1 "XPASS:" $$xpass "$$red"; \
- result_count $$1 "ERROR:" $$error "$$mgn"; \
- }; \
- ## Write "global" testsuite log.
- { \
- echo "$(PACKAGE_STRING): $(subdir)/$(TEST_SUITE_LOG)" | \
- $(am__rst_title); \
- create_testsuite_report --no-color; \
- echo; \
- echo ".. contents:: :depth: 2"; \
- echo; \
- for b in $$bases; do echo $$b; done \
- | $(am__create_global_log); \
- } >$(TEST_SUITE_LOG).tmp || exit 1; \
- mv $(TEST_SUITE_LOG).tmp $(TEST_SUITE_LOG); \
- ## Emit the test summary on the console.
- if $$success; then \
- col="$$grn"; \
- else \
- col="$$red"; \
- test x"$$VERBOSE" = x || cat $(TEST_SUITE_LOG); \
- fi; \
- ## Multi line coloring is problematic with "less -R", so we really need
- ## to color each line individually.
- echo "$${col}$$br$${std}"; \
- echo "$${col}Testsuite summary for $(PACKAGE_STRING)$${std}"; \
- echo "$${col}$$br$${std}"; \
- ## This is expected to go to the console, so it might have to be colorized.
- create_testsuite_report --maybe-color; \
- echo "$$col$$br$$std"; \
- if $$success; then :; else \
- echo "$${col}See $(subdir)/$(TEST_SUITE_LOG)$${std}"; \
- if test -n "$(PACKAGE_BUGREPORT)"; then \
- echo "$${col}Please report to $(PACKAGE_BUGREPORT)$${std}"; \
- fi; \
- echo "$$col$$br$$std"; \
- fi; \
- ## Be sure to exit with the proper exit status. The use of "exit 1" below
- ## is required to work around a FreeBSD make bug (present only when running
- ## in concurrent mode). See automake bug#9245:
- ## <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9245>
- ## and FreeBSD PR bin/159730:
- ## <http://www.freebsd.org/cgi/query-pr.cgi?pr=159730>.
- $$success || exit 1
- RECHECK_LOGS = $(TEST_LOGS)
- ## ------------------------------------------ ##
- ## Running all tests, or rechecking failures. ##
- ## ------------------------------------------ ##
- check-TESTS:
- @list='$(RECHECK_LOGS)'; test -z "$$list" || rm -f $$list
- @list='$(RECHECK_LOGS:.log=.trs)'; test -z "$$list" || rm -f $$list
- ## We always have to remove $(TEST_SUITE_LOG), to ensure its rule is run
- ## in any case even in lazy mode: otherwise, if no test needs rerunning,
- ## or a prior run plus reruns all happen within the same timestamp (can
- ## happen with a prior "make TESTS=<subset>"), then we get no log output.
- ## OTOH, this means that, in the rule for '$(TEST_SUITE_LOG)', we
- ## cannot use '$?' to compute the set of lazily rerun tests, lest
- ## we rely on .PHONY to work portably.
- @test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
- @set +e; $(am__set_TESTS_bases); \
- log_list=`for i in $$bases; do echo $$i.log; done`; \
- trs_list=`for i in $$bases; do echo $$i.trs; done`; \
- ## Remove newlines and normalize whitespace. Trailing (and possibly
- ## leading) whitespace is known to cause segmentation faults on
- ## Solaris 10 XPG4 make.
- log_list=`echo $$log_list`; trs_list=`echo $$trs_list`; \
- $(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) TEST_LOGS="$$log_list"; \
- ## Be sure to exit with the proper exit status (automake bug#9245). See
- ## comments in the recipe of $(TEST_SUITE_LOG) above for more information.
- exit $$?;
- ## Recheck must depend on $(check_SCRIPTS), $(check_PROGRAMS), etc.
- ## It must also depend on the 'all' target. See automake bug#11252.
- recheck: all %CHECK_DEPS%
- ## See comments above in the check-TESTS recipe for why remove
- ## $(TEST_SUITE_LOG) here.
- @test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG)
- @set +e; $(am__set_TESTS_bases); \
- ## We must only consider tests that had an unexpected outcome (FAIL
- ## or XPASS) in the earlier run.
- bases=`for i in $$bases; do echo $$i; done \
- | $(am__list_recheck_tests)` || exit 1; \
- log_list=`for i in $$bases; do echo $$i.log; done`; \
- ## Remove newlines and normalize whitespace. Trailing (and possibly
- ## leading) whitespace is known to cause segmentation faults on
- ## Solaris 10 XPG4 make.
- log_list=`echo $$log_list`; \
- ## Move the '.log' and '.trs' files associated with the tests to be
- ## re-run out of the way, so that those tests will be re-run by the
- ## "make test-suite.log" recursive invocation below.
- ## Two tricky requirements:
- ## - we must avoid extra files removal when running under "make -n";
- ## - in case the test is a compiled program whose compilation fails,
- ## we must ensure that any '.log' and '.trs' file referring to such
- ## test are preserved, so that future "make recheck" invocations
- ## will still try to re-compile and re-run it (automake bug#11791).
- ## The tricky recursive make invocation below should cater to such
- ## requirements.
- $(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) \
- am__force_recheck=am--force-recheck \
- TEST_LOGS="$$log_list"; \
- ## Be sure to exit with the proper exit status (automake bug#9245). See
- ## comments in the recipe of $(TEST_SUITE_LOG) above for more information.
- exit $$?
- AM_RECURSIVE_TARGETS += check recheck
- .PHONY: recheck
- else %?SERIAL_TESTS%
- ## Obsolescent serial testsuite driver.
- check-TESTS: $(TESTS)
- @failed=0; all=0; xfail=0; xpass=0; skip=0; \
- srcdir=$(srcdir); export srcdir; \
- ## Make sure Solaris VPATH-expands all members of this list, even
- ## the first and the last one; thus the spaces around $(TESTS)
- list=' $(TESTS) '; \
- $(am__tty_colors); \
- if test -n "$$list"; then \
- for tst in $$list; do \
- if test -f ./$$tst; then dir=./; \
- ## Note: Solaris 2.7 seems to expand TESTS using VPATH. That's
- ## why we also try 'dir='.
- elif test -f $$tst; then dir=; \
- else dir="$(srcdir)/"; fi; \
- if $(TESTS_ENVIRONMENT) $${dir}$$tst $(AM_TESTS_FD_REDIRECT); then \
- ## Success
- all=`expr $$all + 1`; \
- case " $(XFAIL_TESTS) " in \
- *[\ \ ]$$tst[\ \ ]*) \
- xpass=`expr $$xpass + 1`; \
- failed=`expr $$failed + 1`; \
- col=$$red; res=XPASS; \
- ;; \
- *) \
- col=$$grn; res=PASS; \
- ;; \
- esac; \
- elif test $$? -ne 77; then \
- ## Failure
- all=`expr $$all + 1`; \
- case " $(XFAIL_TESTS) " in \
- *[\ \ ]$$tst[\ \ ]*) \
- xfail=`expr $$xfail + 1`; \
- col=$$lgn; res=XFAIL; \
- ;; \
- *) \
- failed=`expr $$failed + 1`; \
- col=$$red; res=FAIL; \
- ;; \
- esac; \
- else \
- ## Skipped
- skip=`expr $$skip + 1`; \
- col=$$blu; res=SKIP; \
- fi; \
- echo "$${col}$$res$${std}: $$tst"; \
- done; \
- ## Prepare the banner
- if test "$$all" -eq 1; then \
- tests="test"; \
- All=""; \
- else \
- tests="tests"; \
- All="All "; \
- fi; \
- if test "$$failed" -eq 0; then \
- if test "$$xfail" -eq 0; then \
- banner="$$All$$all $$tests passed"; \
- else \
- if test "$$xfail" -eq 1; then failures=failure; else failures=failures; fi; \
- banner="$$All$$all $$tests behaved as expected ($$xfail expected $$failures)"; \
- fi; \
- else \
- if test "$$xpass" -eq 0; then \
- banner="$$failed of $$all $$tests failed"; \
- else \
- if test "$$xpass" -eq 1; then passes=pass; else passes=passes; fi; \
- banner="$$failed of $$all $$tests did not behave as expected ($$xpass unexpected $$passes)"; \
- fi; \
- fi; \
- ## DASHES should contain the largest line of the banner.
- dashes="$$banner"; \
- skipped=""; \
- if test "$$skip" -ne 0; then \
- if test "$$skip" -eq 1; then \
- skipped="($$skip test was not run)"; \
- else \
- skipped="($$skip tests were not run)"; \
- fi; \
- test `echo "$$skipped" | wc -c` -le `echo "$$banner" | wc -c` || \
- dashes="$$skipped"; \
- fi; \
- report=""; \
- if test "$$failed" -ne 0 && test -n "$(PACKAGE_BUGREPORT)"; then \
- report="Please report to $(PACKAGE_BUGREPORT)"; \
- test `echo "$$report" | wc -c` -le `echo "$$banner" | wc -c` || \
- dashes="$$report"; \
- fi; \
- dashes=`echo "$$dashes" | sed s/./=/g`; \
- if test "$$failed" -eq 0; then \
- col="$$grn"; \
- else \
- col="$$red"; \
- fi; \
- ## Multi line coloring is problematic with "less -R", so we really need
- ## to color each line individually.
- echo "$${col}$$dashes$${std}"; \
- echo "$${col}$$banner$${std}"; \
- test -z "$$skipped" || echo "$${col}$$skipped$${std}"; \
- test -z "$$report" || echo "$${col}$$report$${std}"; \
- echo "$${col}$$dashes$${std}"; \
- test "$$failed" -eq 0; \
- else :; fi
- endif %?SERIAL_TESTS%
|