diff options
author | Vadim Rutkovsky <vrutkovs@redhat.com> | 2013-03-13 16:32:20 +0100 |
---|---|---|
committer | Vadim Rutkovsky <vrutkovs@redhat.com> | 2013-03-19 10:18:16 +0100 |
commit | 421468ea04802108708062c9ae7ebdbc14a95a7c (patch) | |
tree | f5357bdbf6f548ffd269e6237c695e097de25b70 | |
parent | 8022c0c6a23092c6ef80fde7c76a57aa98cf6ae8 (diff) | |
download | evolution-data-server-wip/gtester.tar.gz |
Bug 695688 - run tests using gtester and produce html reportwip/gtester
-rw-r--r-- | Makefile.am | 5 | ||||
-rw-r--r-- | tests/Makefile.am | 1 | ||||
-rw-r--r-- | tests/Makefile.gtester | 63 | ||||
-rw-r--r-- | tests/libebook/Makefile.am | 1 | ||||
-rw-r--r-- | tests/libebook/client/Makefile.am | 1 | ||||
-rw-r--r-- | tests/libebook/vcard/Makefile.am | 1 | ||||
-rw-r--r-- | tests/libecal/Makefile.am | 1 | ||||
-rw-r--r-- | tests/libecal/client/Makefile.am | 1 | ||||
-rw-r--r-- | tests/libedata-cal/Makefile.am | 1 | ||||
-rw-r--r-- | tests/libedataserver/Makefile.am | 1 | ||||
-rw-r--r-- | tests/test-server-utils/Makefile.am | 1 | ||||
-rw-r--r-- | tests/test-server-utils/services/Makefile.am | 1 |
12 files changed, 78 insertions, 0 deletions
diff --git a/Makefile.am b/Makefile.am index f584b73f8..e9e3c95fb 100644 --- a/Makefile.am +++ b/Makefile.am @@ -102,3 +102,8 @@ MAINTAINERCLEANFILES = \ $(srcdir)/po/remove-potcdate.sin -include $(top_srcdir)/git.mk + +test-report perf-report full-report: + @cd tests && $(MAKE) $(AM_MAKEFLAGS) $@ + +.PHONY:test-report perf-report full-report diff --git a/tests/Makefile.am b/tests/Makefile.am index bdad80535..9cb5e5c04 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -3,3 +3,4 @@ SUBDIRS = test-server-utils libedataserver libebook-contacts libebook libecal li @GNOME_CODE_COVERAGE_RULES@ -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/Makefile.gtester b/tests/Makefile.gtester new file mode 100644 index 000000000..37868c631 --- /dev/null +++ b/tests/Makefile.gtester @@ -0,0 +1,63 @@ +### testing rules + +# test: run all tests in cwd and subdirs +test: test-nonrecursive + @ for subdir in $(SUBDIRS) . ; do \ + test "$$subdir" = "." -o "$$subdir" = "po" -o "$$subdir" = "docs" || \ + ( cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $@ ) || exit $? ; \ + done + +# test-nonrecursive: run tests only in cwd +test-nonrecursive: ${TESTS} + @test -z "${TESTS}" || G_DEBUG=gc-friendly MALLOC_CHECK_=2 MALLOC_PERTURB_=$$(($${RANDOM:-256} % 256)) gtester ${TESTS} + +# test-report: run tests in subdirs and generate report +# perf-report: run tests in subdirs with -m perf and generate report +# full-report: like test-report: with -m perf and -m slow +test-report perf-report full-report: ${TESTS} + @test -z "${TESTS}" || { \ + case $@ in \ + test-report) test_options="-k";; \ + perf-report) test_options="-k -m=perf";; \ + full-report) test_options="-k -m=perf -m=slow";; \ + esac ; \ + if test -z "$$GTESTER_LOGDIR" ; then \ + gtester $$test_options -o test-report.xml ${TESTS} || true ; \ + elif test -n "${TESTS}" ; then \ + gtester $$test_options -o `mktemp "$$GTESTER_LOGDIR/log-XXXXXX"` ${TESTS} || true ; \ + fi ; \ + } + @ ignore_logdir=true ; \ + if test -z "$$GTESTER_LOGDIR" ; then \ + GTESTER_LOGDIR=`mktemp -d "\`pwd\`/.testlogs-XXXXXX"`; export GTESTER_LOGDIR ; \ + ignore_logdir=false ; \ + fi ; \ + if test -d "$(top_srcdir)/.git" ; then \ + REVISION=`git describe` ; \ + else \ + REVISION=$(VERSION) ; \ + fi ; \ + for subdir in $(SUBDIRS) . ; do \ + test "$$subdir" = "." -o "$$subdir" = "po" -o "$$subdir" = "docs" || \ + ( cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $@ ) || exit $? ; \ + done ; \ + $$ignore_logdir || { \ + echo '<?xml version="1.0"?>' > $@.xml ; \ + echo '<report-collection>' >> $@.xml ; \ + echo '<info>' >> $@.xml ; \ + echo ' <package>$(PACKAGE)</package>' >> $@.xml ; \ + echo ' <version>$(VERSION)</version>' >> $@.xml ; \ + echo " <revision>$$REVISION</revision>" >> $@.xml ; \ + echo '</info>' >> $@.xml ; \ + for lf in `ls -L "$$GTESTER_LOGDIR"/.` ; do \ + sed '1,1s/^<?xml\b[^>?]*?>//' <"$$GTESTER_LOGDIR"/"$$lf" >> $@.xml ; \ + done ; \ + echo >> $@.xml ; \ + echo '</report-collection>' >> $@.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 test-nonrecursive + +# run tests in cwd as part of make check +check-local: test-nonrecursive diff --git a/tests/libebook/Makefile.am b/tests/libebook/Makefile.am index 325b8f716..41ebe8897 100644 --- a/tests/libebook/Makefile.am +++ b/tests/libebook/Makefile.am @@ -97,3 +97,4 @@ test_ebook_remove_contacts_LDADD=$(TEST_LIBS) test_ebook_remove_contacts_CPPFLAGS=$(TEST_CPPFLAGS) -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/libebook/client/Makefile.am b/tests/libebook/client/Makefile.am index 746b8e571..89d6a21a6 100644 --- a/tests/libebook/client/Makefile.am +++ b/tests/libebook/client/Makefile.am @@ -116,3 +116,4 @@ test_client_self_LDADD=$(TEST_LIBS) test_client_self_CPPFLAGS=$(TEST_CPPFLAGS) -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/libebook/vcard/Makefile.am b/tests/libebook/vcard/Makefile.am index 91f39f10e..a27d23f53 100644 --- a/tests/libebook/vcard/Makefile.am +++ b/tests/libebook/vcard/Makefile.am @@ -17,3 +17,4 @@ dump_vcard_LDADD = \ EXTRA_DIST=1.vcf 2.vcf 3.vcf 4.vcf 5.vcf 6.vcf 7.vcf 8.vcf 9.vcf 10.vcf 11.vcf -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/libecal/Makefile.am b/tests/libecal/Makefile.am index 7212c6dfe..bddcc465d 100644 --- a/tests/libecal/Makefile.am +++ b/tests/libecal/Makefile.am @@ -108,3 +108,4 @@ test_ecal_set_default_timezone_LDADD=$(TEST_ECAL_LIBS) test_ecal_set_default_timezone_CPPFLAGS=$(TEST_ECAL_CPPFLAGS) -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/libecal/client/Makefile.am b/tests/libecal/client/Makefile.am index f2dc4b1d1..99bce1a22 100644 --- a/tests/libecal/client/Makefile.am +++ b/tests/libecal/client/Makefile.am @@ -86,3 +86,4 @@ test_client_send_objects_LDADD=$(TEST_LIBS) test_client_send_objects_CPPFLAGS=$(TEST_CPPFLAGS) -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/libedata-cal/Makefile.am b/tests/libedata-cal/Makefile.am index 145c13b2e..b27c65e92 100644 --- a/tests/libedata-cal/Makefile.am +++ b/tests/libedata-cal/Makefile.am @@ -43,3 +43,4 @@ test_intervaltree_CPPFLAGS = $(test_CPPFLAGS) test_intervaltree_LDADD = $(test_LDADD) -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/libedataserver/Makefile.am b/tests/libedataserver/Makefile.am index 983c2bb7a..ce64549f9 100644 --- a/tests/libedataserver/Makefile.am +++ b/tests/libedataserver/Makefile.am @@ -56,3 +56,4 @@ e_user_prompter_test_LDADD = $(top_builddir)/libebackend/libebackend-1.2.la $(te endif -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester diff --git a/tests/test-server-utils/Makefile.am b/tests/test-server-utils/Makefile.am index ae90c80da..c1ddec530 100644 --- a/tests/test-server-utils/Makefile.am +++ b/tests/test-server-utils/Makefile.am @@ -56,6 +56,7 @@ test_fixture_LDADD = $(common_libs) libetestserverutils.la test_fixture_SOURCES = test-fixture.c -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester ###################################### # The test directory needs to be # diff --git a/tests/test-server-utils/services/Makefile.am b/tests/test-server-utils/services/Makefile.am index f3d52870d..dce8ccdd3 100644 --- a/tests/test-server-utils/services/Makefile.am +++ b/tests/test-server-utils/services/Makefile.am @@ -4,3 +4,4 @@ EXTRA_DIST = \ org.gnome.evolution.dataserver.Sources.service.in -include $(top_srcdir)/git.mk +-include $(top_srcdir)/tests/Makefile.gtester |