diff options
author | Luiz Augusto von Dentz <luiz.von.dentz@intel.com> | 2013-12-11 11:01:25 +0200 |
---|---|---|
committer | Luiz Augusto von Dentz <luiz.von.dentz@intel.com> | 2014-12-12 12:24:10 -0200 |
commit | 6a56b171b6c4a8bdc3db47ce5b9627db68ac468b (patch) | |
tree | 96c443ae9ee91af93be211cf26fc4004a41b7b79 | |
parent | b1b312d4ec0ec4123e96ddb2719933120a09ea00 (diff) | |
download | bluez-6a56b171b6c4a8bdc3db47ce5b9627db68ac468b.tar.gz |
build: Add coverage support
Coverage is enabled with --enable-maintainer-mode, 2 new targets are
added 'coverage' and 'clean-coverage', the first generate the reports
using lcov and depend on the second to cleanup previous generated
reports and .gcda files.
-rw-r--r-- | .gitignore | 4 | ||||
-rw-r--r-- | Makefile.am | 20 | ||||
-rw-r--r-- | acinclude.m4 | 4 | ||||
-rw-r--r-- | configure.ac | 5 |
4 files changed, 33 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore index 484f41f39..a0c93898b 100644 --- a/.gitignore +++ b/.gitignore @@ -3,6 +3,8 @@ *.lo *.la *.so +*.gcno +*.gcda .deps .libs .dirstamp @@ -27,7 +29,9 @@ stamp-h1 autom4te.cache test-driver test-suite.log +coverage.info +coverage lib/bluez.pc lib/bluetooth src/builtin.h diff --git a/Makefile.am b/Makefile.am index d6cd8870c..f2b22ae80 100644 --- a/Makefile.am +++ b/Makefile.am @@ -442,5 +442,25 @@ lib/bluetooth/%.h: lib/%.h $(AM_V_at)$(MKDIR_P) lib/bluetooth $(AM_V_GEN)$(LN_S) -f "$(abs_top_builddir)"/$< $@ +if COVERAGE +clean-coverage: + @lcov --directory $(top_builddir) --zerocounters + $(RM) -r coverage $(top_builddir)/coverage.info + +coverage: check + @lcov --compat-libtool --directory $(top_builddir) --capture \ + --output-file $(top_builddir)/coverage.info + $(AM_V_at)$(MKDIR_P) coverage + @genhtml -o coverage/ $(top_builddir)/coverage.info + +clean-local: clean-coverage + -find $(top_builddir) -name "*.gcno" -delete + -find $(top_builddir) -name "*.gcda" -delete + $(RM) -r lib/bluetooth + +else clean-local: + -find $(top_builddir) -name "*.gcno" -delete + -find $(top_builddir) -name "*.gcda" -delete $(RM) -r lib/bluetooth +endif diff --git a/acinclude.m4 b/acinclude.m4 index 4c241bf0b..4cfc80a0d 100644 --- a/acinclude.m4 +++ b/acinclude.m4 @@ -52,6 +52,10 @@ AC_DEFUN([MISC_FLAGS], [ misc_ldflags="$misc_ldflags -pie" fi ]) + if (test "$USE_MAINTAINER_MODE" = "yes"); then + misc_cflags="$misc_cflags --coverage" + misc_ldflags="$misc_ldflags --coverage" + fi AC_SUBST([MISC_CFLAGS], $misc_cflags) AC_SUBST([MISC_LDFLAGS], $misc_ldflags) ]) diff --git a/configure.ac b/configure.ac index e04a6eb4a..196e7849d 100644 --- a/configure.ac +++ b/configure.ac @@ -274,4 +274,9 @@ fi AC_DEFINE_UNQUOTED(ANDROID_STORAGEDIR, "${storagedir}/android", [Directory for the Android daemon storage files]) +if (test "$USE_MAINTAINER_MODE" = "yes"); then + AC_CHECK_PROG([LCOV], [lcov], [yes], AC_MSG_ERROR(lcov is required)) +fi +AM_CONDITIONAL(COVERAGE, test "$LCOV" = "yes") + AC_OUTPUT(Makefile src/bluetoothd.8 lib/bluez.pc) |