summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStef Walter <stefw@gnome.org>2013-03-20 20:58:49 +0100
committerStef Walter <stefw@gnome.org>2013-03-20 22:22:18 +0100
commit9cf89e4b43e5e018bb3103be1873a3993769ce4a (patch)
tree9a69429d69f4d22d49fcfe51f0d495ec8ab9ba97
parent0ecabc858dd6c1c2055f53202a01251e2ad7d2c2 (diff)
downloadp11-kit-9cf89e4b43e5e018bb3103be1873a3993769ce4a.tar.gz
Add a bit of infrastructure for running valgrind
* make memcheck: Runs basic memory checking * make leakcheck: Also runs leak checking
-rw-r--r--Makefile.am2
-rw-r--r--build/Makefile.am4
-rw-r--r--build/Makefile.decl11
-rw-r--r--build/Makefile.tests11
-rw-r--r--common/Makefile.am3
-rw-r--r--common/tests/Makefile.am2
-rw-r--r--doc/Makefile.am4
-rw-r--r--doc/manual/p11-kit-devel.xml4
-rw-r--r--p11-kit/Makefile.am3
-rw-r--r--tools/Makefile.am3
-rw-r--r--tools/tests/Makefile.am4
-rw-r--r--trust/Makefile.am3
-rw-r--r--trust/tests/Makefile.am2
13 files changed, 46 insertions, 10 deletions
diff --git a/Makefile.am b/Makefile.am
index 863bc02..13de2bb 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -1,4 +1,6 @@
+include $(top_srcdir)/build/Makefile.decl
+
WEBHOST = anarchy.freedesktop.org
WEBBASE = /srv/p11-glue.freedesktop.org/www
diff --git a/build/Makefile.am b/build/Makefile.am
index de76c58..6f80eab 100644
--- a/build/Makefile.am
+++ b/build/Makefile.am
@@ -11,3 +11,7 @@ noinst_LTLIBRARIES = \
libcutest_la_SOURCES = \
cutest/CuTest.c \
cutest/CuTest.h
+
+memcheck:
+
+leakcheck:
diff --git a/build/Makefile.decl b/build/Makefile.decl
new file mode 100644
index 0000000..c90c22b
--- /dev/null
+++ b/build/Makefile.decl
@@ -0,0 +1,11 @@
+NULL =
+
+memcheck:
+ @for dir in $(SUBDIRS); do \
+ test "$$dir" = "." || $(MAKE) -C $$dir memcheck; \
+ done
+
+leakcheck:
+ @for dir in $(SUBDIRS); do \
+ test "$$dir" = "." || $(MAKE) -C $$dir leakcheck; \
+ done
diff --git a/build/Makefile.tests b/build/Makefile.tests
index 9f41045..3faa7f3 100644
--- a/build/Makefile.tests
+++ b/build/Makefile.tests
@@ -1,3 +1,4 @@
+NULL =
CUTEST_CFLAGS = \
-I$(top_srcdir)/build/cutest \
@@ -6,3 +7,13 @@ CUTEST_CFLAGS = \
-DP11_KIT_FUTURE_UNSTABLE_API
CUTEST_LIBS = $(top_builddir)/build/libcutest.la
+
+MEMCHECK_ENV = $(TEST_RUNNER) valgrind --error-exitcode=80 --quiet --trace-children=yes
+
+LEAKCHECK_ENV = $(TEST_RUNNER) valgrind --error-exitcode=81 --quiet --leak-check=yes
+
+memcheck: all
+ make $(AM_MAKEFLAGS) TESTS_ENVIRONMENT="$(MEMCHECK_ENV)" check-TESTS
+
+leakcheck: all
+ make $(AM_MAKEFLAGS) TESTS_ENVIRONMENT="$(LEAKCHECK_ENV)" check-TESTS
diff --git a/common/Makefile.am b/common/Makefile.am
index 14432fc..bfed1d7 100644
--- a/common/Makefile.am
+++ b/common/Makefile.am
@@ -1,4 +1,5 @@
-NULL =
+
+include $(top_srcdir)/build/Makefile.decl
SUBDIRS = . tests
diff --git a/common/tests/Makefile.am b/common/tests/Makefile.am
index 70f369c..adc06cb 100644
--- a/common/tests/Makefile.am
+++ b/common/tests/Makefile.am
@@ -1,8 +1,6 @@
include $(top_srcdir)/build/Makefile.tests
-NULL =
-
COMMON = $(top_srcdir)/common
INCLUDES = \
diff --git a/doc/Makefile.am b/doc/Makefile.am
index 27b5b47..de840c0 100644
--- a/doc/Makefile.am
+++ b/doc/Makefile.am
@@ -1,2 +1,6 @@
SUBDIRS = manual
+
+memcheck:
+
+leakcheck:
diff --git a/doc/manual/p11-kit-devel.xml b/doc/manual/p11-kit-devel.xml
index 52535d3..12beb5d 100644
--- a/doc/manual/p11-kit-devel.xml
+++ b/doc/manual/p11-kit-devel.xml
@@ -266,6 +266,10 @@ $ make install
the tests. If you run it from a subdirectory only the tests in that
directory will be run.</para>
+ <para>To check for memory errors or memory leaks, run <literal>make memcheck</literal>
+ or <literal>make leakcheck</literal> respectively. This requires valgrind
+ be installed.</para>
+
<para>Build p11-kit with the <option>--enable-coverage</option> configure
option to build code coverage support.</para>
diff --git a/p11-kit/Makefile.am b/p11-kit/Makefile.am
index 0afa084..1967403 100644
--- a/p11-kit/Makefile.am
+++ b/p11-kit/Makefile.am
@@ -1,4 +1,5 @@
-NULL =
+
+include $(top_srcdir)/build/Makefile.decl
SUBDIRS = . tests
diff --git a/tools/Makefile.am b/tools/Makefile.am
index 4977221..aaf7e99 100644
--- a/tools/Makefile.am
+++ b/tools/Makefile.am
@@ -1,4 +1,5 @@
-NULL =
+
+include $(top_srcdir)/build/Makefile.decl
SUBDIRS = . tests
diff --git a/tools/tests/Makefile.am b/tools/tests/Makefile.am
index a74c981..feffcc9 100644
--- a/tools/tests/Makefile.am
+++ b/tools/tests/Makefile.am
@@ -1,8 +1,6 @@
include $(top_srcdir)/build/Makefile.tests
-NULL =
-
EXTRA_DIST = files
if WITH_ASN1
@@ -10,6 +8,8 @@ if WITH_ASN1
COMMON = $(top_srcdir)/common
TOOLS = $(top_srcdir)/tools
+TEST_RUNNER = libtool --mode=execute
+
INCLUDES = \
-I$(top_srcdir) \
-I$(top_srcdir)/p11-kit \
diff --git a/trust/Makefile.am b/trust/Makefile.am
index 38c6b98..60323a8 100644
--- a/trust/Makefile.am
+++ b/trust/Makefile.am
@@ -1,4 +1,5 @@
-NULL =
+
+include $(top_srcdir)/build/Makefile.decl
SUBDIRS = . tests
diff --git a/trust/tests/Makefile.am b/trust/tests/Makefile.am
index 4617546..243b45c 100644
--- a/trust/tests/Makefile.am
+++ b/trust/tests/Makefile.am
@@ -1,8 +1,6 @@
include $(top_srcdir)/build/Makefile.tests
-NULL =
-
INCLUDES = \
-I$(top_srcdir) \
-I$(srcdir)/.. \