X-Git-Url: http://pileus.org/git/?p=~andy%2Fgtk;a=blobdiff_plain;f=Makefile.decl;h=0f00030a6ec70fa977ef24962b0deafbc6f22a97;hp=4caa19b7725eabf5dcf5478a2bd2b9fb46118b35;hb=HEAD;hpb=9ba5da2f3644bdf5494a6b06dce7b6914e44b5af diff --git a/Makefile.decl b/Makefile.decl index 4caa19b77..0f00030a6 100644 --- a/Makefile.decl +++ b/Makefile.decl @@ -1,6 +1,7 @@ # GTK+ - The GIMP Toolkit -GTESTER = gtester # for non-GLIB packages +GTESTER = gtester -k # in $PATH for non-GLIB packages +GTESTER_REPORT = gtester-report # in $PATH for non-GLIB packages # initialize variables for unconditional += appending EXTRA_DIST = @@ -9,24 +10,43 @@ TEST_PROGS = ### testing rules # Xvfb based test rules -XVFB = Xvfb +XVFB = Xvfb -ac -noreset -screen 0 1024x768x16 +XIDS = 101 102 103 104 105 106 107 197 199 211 223 227 293 307 308 309 310 311 \ + 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 \ + 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 \ + 1008 1009 4703 4721 4723 4729 4733 4751 9973 9974 9975 9976 9977 9978 9979 \ + 9980 9981 9982 9983 9984 9985 9986 9987 9988 9989 9990 9991 9992 9993 9994 \ + 9995 9996 9997 9998 9999 + +if USE_X11 +SKIP_GDKTARGET = \ + false +else +SKIP_GDKTARGET = \ + echo "Gtk+Tests:INFO: Skipping GUI tests for non-X11 target." +endif + XVFB_START = \ ${XVFB} -help 2>/dev/null 1>&2 \ - && XID=`for id in \`seq 101 199\` ; do test -e /tmp/.X$$id-lock || { echo $$id; exit 0; }; done; exit 1` \ + && XID=`for id in $(XIDS) ; do test -e /tmp/.X$$id-lock || { echo $$id; exit 0; }; done; exit 1` \ && { ${XVFB} :$$XID -nolisten tcp -auth /dev/null >/dev/null 2>&1 & \ trap "kill -15 $$! " 0 HUP INT QUIT TRAP USR1 PIPE TERM ; } \ - || { echo Failed to start Xvfb environment for testing; exit 1; } \ - && set -e ; DISPLAY=:$$XID; export DISPLAY + || { echo "Gtk+Tests:ERROR: Failed to start Xvfb environment for X11 target tests."; exit 1; } \ + && DISPLAY=:$$XID && export DISPLAY # call as: $(XVFB_START) && someprogram # test: run all tests in cwd and subdirs -test: ${TEST_PROGS} - @$(XVFB_START) && { \ - test -z "${TEST_PROGS}" || ${GTESTER} --verbose ${TEST_PROGS} ; \ +test: test-cwd test-recurse +# test-cwd: run tests in cwd +test-cwd: ${TEST_PROGS} + @$(SKIP_GDKTARGET) || test -z "${TEST_PROGS}" || { \ + $(XVFB_START) && { set -e; $(TESTS_ENVIRONMENT) ${GTESTER} --verbose ${TEST_PROGS}; }; \ } +# test-recurse: run tests in subdirs +test-recurse: @ for subdir in $(SUBDIRS) ; do \ test "$$subdir" = "." -o "$$subdir" = "po" -o "$$subdir" = "po-properties" || \ - ( cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $@ ) || exit $? ; \ + ( cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) test ) || exit $? ; \ done # test-report: run tests in subdirs and generate report # perf-report: run tests in subdirs with -m perf and generate report @@ -41,13 +61,14 @@ test-report perf-report full-report: ${TEST_PROGS} test "$$subdir" = "." -o "$$subdir" = "po" -o "$$subdir" = "po-properties" || \ ( cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $@ ) || exit $? ; \ done ; \ - test -z "${TEST_PROGS}" || { \ + $(SKIP_GDKTARGET) || test -z "${TEST_PROGS}" || { \ case $@ in \ test-report) test_options="-k";; \ perf-report) test_options="-k -m=perf";; \ full-report) test_options="-k -m=perf -m=slow";; \ esac ; \ $(XVFB_START) && { \ + set -e; \ if test -z "$$GTESTER_LOGDIR" ; then \ ${GTESTER} --verbose $$test_options -o test-report.xml ${TEST_PROGS} ; \ elif test -n "${TEST_PROGS}" ; then \ @@ -64,7 +85,8 @@ test-report perf-report full-report: ${TEST_PROGS} echo >> $@.xml ; \ echo '' >> $@.xml ; \ rm -rf "$$GTESTER_LOGDIR"/ ; \ + ${GTESTER_REPORT} --version 2>/dev/null 1>&2 ; test "$$?" != 0 || ${GTESTER_REPORT} $@.xml >$@.html ; \ } -.PHONY: test test-report perf-report full-report -# run make test as part of make check -check-local: test +.PHONY: test test-cwd test-recurse test-report perf-report full-report +# run make test-cwd as part of make check +check-local: test-cwd