From e5391b6172cfe92f9dc551ca541d347d04467a37 Mon Sep 17 00:00:00 2001 From: Lars Bilke <lars.bilke@ufz.de> Date: Mon, 14 May 2012 11:15:14 +0200 Subject: [PATCH] Squashed commit of the following: commit f9ac1682aac6e3ae9fcbd62f81cb16d0deece557 Author: Lars Bilke <lars.bilke@ufz.de> Date: Wed Feb 1 12:33:26 2012 +0100 White space fixes. commit 7e0092ae6c6401071ac3b30d3c31a5f944588363 Author: Lars Bilke <lars.bilke@ufz.de> Date: Wed Feb 1 12:30:57 2012 +0100 SOme small fixes. commit 3410933db3f60a029183c3631766977853cd8625 Author: Lars Bilke <lars.bilke@ufz.de> Date: Tue Jan 31 17:29:33 2012 +0100 Cobertura code coverage report generation with gcovr added. commit b27f8064a6348de3be4c397fedbfddcce321fced Author: Lars Bilke <lars.bilke@ufz.de> Date: Tue Jan 31 16:07:39 2012 +0100 Fixed typo. --- scripts/cmake/cmake/CodeCoverage.cmake | 63 ++++++++++++++++++++------ 1 file changed, 48 insertions(+), 15 deletions(-) diff --git a/scripts/cmake/cmake/CodeCoverage.cmake b/scripts/cmake/cmake/CodeCoverage.cmake index 4fe002368b7..1277a3167d1 100644 --- a/scripts/cmake/cmake/CodeCoverage.cmake +++ b/scripts/cmake/cmake/CodeCoverage.cmake @@ -15,19 +15,12 @@ FIND_PROGRAM( GCOV_PATH gcov ) FIND_PROGRAM( LCOV_PATH lcov ) FIND_PROGRAM( GENHTML_PATH genhtml ) +FIND_PROGRAM( GCOVR_PATH gcovr PATHS ${CMAKE_SOURCE_DIR}/tests) IF(NOT GCOV_PATH) MESSAGE(FATAL_ERROR "gcov not found! Aborting...") ENDIF() # NOT GCOV_PATH -IF(NOT LCOV_PATH) - MESSAGE(FATAL_ERROR "lcov not found! Aborting...") -ENDIF() # NOT LCOV_PATH - -IF(NOT GENHTML_PATH) - MESSAGE(FATAL_ERROR "genhtml not found! Aborting...") -ENDIF() # NOT GENHTML_PATH - IF(NOT CMAKE_COMPILER_IS_GNUCXX) MESSAGE(FATAL_ERROR "Compiler is not GNU gcc! Aborting...") ENDIF() # NOT CMAKE_COMPILER_IS_GNUCXX @@ -46,27 +39,34 @@ LINK_LIBRARIES(gcov) # Param _testrunner The name of the target which runs the tests # Param _outputname lcov output is generated as _outputname.info # HTML report is generated in _outputname/index.html -FUNCTION(SETUP_TARGET_FOR_COVERAGE _targetname _testrunnerexe _outputname) +FUNCTION(SETUP_TARGET_FOR_COVERAGE _targetname _testrunner _outputname) + + IF(NOT LCOV_PATH) + MESSAGE(FATAL_ERROR "lcov not found! Aborting...") + ENDIF() # NOT LCOV_PATH + + IF(NOT GENHTML_PATH) + MESSAGE(FATAL_ERROR "genhtml not found! Aborting...") + ENDIF() # NOT GENHTML_PATH # Setup target ADD_CUSTOM_TARGET(${_targetname} # Cleanup lcov - lcov --directory . --zerocounters + ${LCOV_PATH} --directory . --zerocounters # Run tests COMMAND ${_testrunner} # Capturing lcov counters and generating report - COMMAND lcov --directory . --capture --output-file ${_outputname}.info - COMMAND lcov --remove ${_outputname}.info 'tests/*' '/usr/*' --output-file ${_outputname}.info.cleaned - COMMAND genhtml -o ${_outputname} ${_outputname}.info.cleaned + COMMAND ${LCOV_PATH} --directory . --capture --output-file ${_outputname}.info + COMMAND ${LCOV_PATH} --remove ${_outputname}.info 'tests/*' '/usr/*' --output-file ${_outputname}.info.cleaned + COMMAND ${GENHTML_PATH} -o ${_outputname} ${_outputname}.info.cleaned COMMAND ${CMAKE_COMMAND} -E remove ${_outputname}.info ${_outputname}.info.cleaned DEPENDS ${_testrunner} WORKING_DIRECTORY ${CMAKE_BINARY_DIR} - COMMENT "Resetting code coverage counters to zero.\n - Processing code coverage counters and generating report." + COMMENT "Resetting code coverage counters to zero.\nProcessing code coverage counters and generating report." ) # Show info where to find the report @@ -76,3 +76,36 @@ FUNCTION(SETUP_TARGET_FOR_COVERAGE _targetname _testrunnerexe _outputname) ) ENDFUNCTION() # SETUP_TARGET_FOR_COVERAGE + +# Param _targetname The name of new the custom make target +# Param _testrunner The name of the target which runs the tests +# Param _outputname lcov output is generated as _outputname.info +# HTML report is generated in _outputname/index.html +FUNCTION(SETUP_TARGET_FOR_COVERAGE_COBERTURA _targetname _testrunner _outputname) + + IF(NOT PYTHON_EXECUTABLE) + MESSAGE(FATAL_ERROR "Python not found! Aborting...") + ENDIF() # NOT PYTHON_EXECUTABLE + + IF(NOT GCOVR_PATH) + MESSAGE(FATAL_ERROR "gcovr not found! Aborting...") + ENDIF() # NOT GCOVR_PATH + + ADD_CUSTOM_TARGET(${_targetname} + + # Run tests + ${_testrunner} + + # Running gcovr + COMMAND ${GCOVR_PATH} -x -r ${CMAKE_SOURCE_DIR} -o ${_outputname}.xml + WORKING_DIRECTORY ${CMAKE_BINARY_DIR} + COMMENT "Running gcovr to produce Cobertura code coverage report." + ) + + # Show info where to find the report + ADD_CUSTOM_COMMAND(TARGET ${_targetname} POST_BUILD + COMMAND ; + COMMENT "Cobertura code coverage report saved in ${_outputname}.xml." + ) + +ENDFUNCTION() # SETUP_TARGET_FOR_COVERAGE_COBERTURA \ No newline at end of file -- GitLab