mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 02:33:24 -03:00
cmake: Introduce BUILD_FOR_COVERAGE
build option
The new `BUILD_FOR_COVERAGE` build option enables instrumentation for LLVM's Source-based Code Coverage reports.
This commit is contained in:
parent
dbc8ba12f3
commit
68108fa8b5
13 changed files with 60 additions and 5 deletions
|
@ -172,6 +172,8 @@ option(BUILD_BENCH "Build bench_bitcoin executable." OFF)
|
||||||
option(BUILD_FUZZ_BINARY "Build fuzz binary." OFF)
|
option(BUILD_FUZZ_BINARY "Build fuzz binary." OFF)
|
||||||
option(BUILD_FOR_FUZZING "Build for fuzzing. Enabling this will disable all other targets and override BUILD_FUZZ_BINARY." OFF)
|
option(BUILD_FOR_FUZZING "Build for fuzzing. Enabling this will disable all other targets and override BUILD_FUZZ_BINARY." OFF)
|
||||||
|
|
||||||
|
option(BUILD_FOR_COVERAGE "Build with Code Coverage instrumentation" OFF)
|
||||||
|
|
||||||
option(INSTALL_MAN "Install man pages." ON)
|
option(INSTALL_MAN "Install man pages." ON)
|
||||||
|
|
||||||
set(APPEND_CPPFLAGS "" CACHE STRING "Preprocessor flags that are appended to the command line after all other flags added by the build system. This variable is intended for debugging and special builds.")
|
set(APPEND_CPPFLAGS "" CACHE STRING "Preprocessor flags that are appended to the command line after all other flags added by the build system. This variable is intended for debugging and special builds.")
|
||||||
|
@ -372,6 +374,29 @@ if(BUILD_FUZZ_BINARY)
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# The coverage_interface library is intended to be used
|
||||||
|
# only for code whose coverage report is of interest.
|
||||||
|
add_library(coverage_interface INTERFACE)
|
||||||
|
if(BUILD_FOR_COVERAGE)
|
||||||
|
if(NOT CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
|
||||||
|
message(FATAL_ERROR "BUILD_FOR_COVERAGE can only be specified when compiling with Clang.")
|
||||||
|
endif()
|
||||||
|
if(NOT PROFILE_FILE_PATTERN)
|
||||||
|
if(NOT PROFILE_DATA_DIR)
|
||||||
|
file(TO_NATIVE_PATH "${PROJECT_BINARY_DIR}/profiles" PROFILE_DATA_DIR)
|
||||||
|
endif()
|
||||||
|
file(TO_NATIVE_PATH "${PROFILE_DATA_DIR}/%m.profraw" PROFILE_FILE_PATTERN)
|
||||||
|
endif()
|
||||||
|
target_compile_options(coverage_interface INTERFACE
|
||||||
|
-fprofile-instr-generate=${PROFILE_FILE_PATTERN}
|
||||||
|
-fcoverage-mapping
|
||||||
|
)
|
||||||
|
target_link_options(coverage_interface INTERFACE
|
||||||
|
-fprofile-instr-generate=${PROFILE_FILE_PATTERN}
|
||||||
|
-fcoverage-mapping
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
include(AddBoostIfNeeded)
|
include(AddBoostIfNeeded)
|
||||||
add_boost_if_needed()
|
add_boost_if_needed()
|
||||||
|
|
||||||
|
@ -624,6 +649,7 @@ message(" test_bitcoin ........................ ${BUILD_TESTS}")
|
||||||
message(" test_bitcoin-qt ..................... ${BUILD_GUI_TESTS}")
|
message(" test_bitcoin-qt ..................... ${BUILD_GUI_TESTS}")
|
||||||
message(" bench_bitcoin ....................... ${BUILD_BENCH}")
|
message(" bench_bitcoin ....................... ${BUILD_BENCH}")
|
||||||
message(" fuzz binary ......................... ${BUILD_FUZZ_BINARY}")
|
message(" fuzz binary ......................... ${BUILD_FUZZ_BINARY}")
|
||||||
|
message(" Code Coverage instrumentation ....... ${BUILD_FOR_COVERAGE}")
|
||||||
message("")
|
message("")
|
||||||
if(CMAKE_CROSSCOMPILING)
|
if(CMAKE_CROSSCOMPILING)
|
||||||
set(cross_status "TRUE, for ${CMAKE_SYSTEM_NAME}, ${CMAKE_SYSTEM_PROCESSOR}")
|
set(cross_status "TRUE, for ${CMAKE_SYSTEM_NAME}, ${CMAKE_SYSTEM_PROCESSOR}")
|
||||||
|
|
|
@ -20,6 +20,7 @@ add_library(bitcoin_clientversion OBJECT EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_clientversion
|
target_link_libraries(bitcoin_clientversion
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
)
|
)
|
||||||
add_dependencies(bitcoin_clientversion generate_build_info)
|
add_dependencies(bitcoin_clientversion generate_build_info)
|
||||||
|
|
||||||
|
@ -92,6 +93,7 @@ add_library(bitcoin_consensus STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_consensus
|
target_link_libraries(bitcoin_consensus
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_crypto
|
bitcoin_crypto
|
||||||
secp256k1
|
secp256k1
|
||||||
)
|
)
|
||||||
|
@ -156,6 +158,7 @@ add_library(bitcoin_common STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_common
|
target_link_libraries(bitcoin_common
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_consensus
|
bitcoin_consensus
|
||||||
bitcoin_util
|
bitcoin_util
|
||||||
univalue
|
univalue
|
||||||
|
@ -179,6 +182,7 @@ if(ENABLE_WALLET)
|
||||||
add_windows_resources(bitcoin-wallet bitcoin-wallet-res.rc)
|
add_windows_resources(bitcoin-wallet bitcoin-wallet-res.rc)
|
||||||
target_link_libraries(bitcoin-wallet
|
target_link_libraries(bitcoin-wallet
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_wallet
|
bitcoin_wallet
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
bitcoin_util
|
bitcoin_util
|
||||||
|
@ -289,6 +293,7 @@ add_library(bitcoin_node STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_node
|
target_link_libraries(bitcoin_node
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
bitcoin_util
|
bitcoin_util
|
||||||
$<TARGET_NAME_IF_EXISTS:bitcoin_zmq>
|
$<TARGET_NAME_IF_EXISTS:bitcoin_zmq>
|
||||||
|
@ -312,6 +317,7 @@ if(BUILD_DAEMON)
|
||||||
add_windows_resources(bitcoind bitcoind-res.rc)
|
add_windows_resources(bitcoind bitcoind-res.rc)
|
||||||
target_link_libraries(bitcoind
|
target_link_libraries(bitcoind
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_node
|
bitcoin_node
|
||||||
$<TARGET_NAME_IF_EXISTS:bitcoin_wallet>
|
$<TARGET_NAME_IF_EXISTS:bitcoin_wallet>
|
||||||
)
|
)
|
||||||
|
@ -324,6 +330,7 @@ if(WITH_MULTIPROCESS)
|
||||||
)
|
)
|
||||||
target_link_libraries(bitcoin-node
|
target_link_libraries(bitcoin-node
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_node
|
bitcoin_node
|
||||||
bitcoin_ipc
|
bitcoin_ipc
|
||||||
$<TARGET_NAME_IF_EXISTS:bitcoin_wallet>
|
$<TARGET_NAME_IF_EXISTS:bitcoin_wallet>
|
||||||
|
@ -355,6 +362,7 @@ add_library(bitcoin_cli STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_cli
|
target_link_libraries(bitcoin_cli
|
||||||
PUBLIC
|
PUBLIC
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
univalue
|
univalue
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -365,6 +373,7 @@ if(BUILD_CLI)
|
||||||
add_windows_resources(bitcoin-cli bitcoin-cli-res.rc)
|
add_windows_resources(bitcoin-cli bitcoin-cli-res.rc)
|
||||||
target_link_libraries(bitcoin-cli
|
target_link_libraries(bitcoin-cli
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_cli
|
bitcoin_cli
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
bitcoin_util
|
bitcoin_util
|
||||||
|
@ -380,6 +389,7 @@ if(BUILD_TX)
|
||||||
add_windows_resources(bitcoin-tx bitcoin-tx-res.rc)
|
add_windows_resources(bitcoin-tx bitcoin-tx-res.rc)
|
||||||
target_link_libraries(bitcoin-tx
|
target_link_libraries(bitcoin-tx
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
bitcoin_util
|
bitcoin_util
|
||||||
univalue
|
univalue
|
||||||
|
@ -393,6 +403,7 @@ if(BUILD_UTIL)
|
||||||
add_windows_resources(bitcoin-util bitcoin-util-res.rc)
|
add_windows_resources(bitcoin-util bitcoin-util-res.rc)
|
||||||
target_link_libraries(bitcoin-util
|
target_link_libraries(bitcoin-util
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
bitcoin_util
|
bitcoin_util
|
||||||
)
|
)
|
||||||
|
@ -425,6 +436,7 @@ if(BUILD_UTIL_CHAINSTATE)
|
||||||
target_link_libraries(bitcoin-chainstate
|
target_link_libraries(bitcoin-chainstate
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoinkernel
|
bitcoinkernel
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -25,6 +25,7 @@ add_library(bitcoin_crypto STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_crypto
|
target_link_libraries(bitcoin_crypto
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
)
|
)
|
||||||
|
|
||||||
if(HAVE_SSE41)
|
if(HAVE_SSE41)
|
||||||
|
@ -33,7 +34,7 @@ if(HAVE_SSE41)
|
||||||
)
|
)
|
||||||
target_compile_definitions(bitcoin_crypto_sse41 PUBLIC ENABLE_SSE41)
|
target_compile_definitions(bitcoin_crypto_sse41 PUBLIC ENABLE_SSE41)
|
||||||
target_compile_options(bitcoin_crypto_sse41 PRIVATE ${SSE41_CXXFLAGS})
|
target_compile_options(bitcoin_crypto_sse41 PRIVATE ${SSE41_CXXFLAGS})
|
||||||
target_link_libraries(bitcoin_crypto_sse41 PRIVATE core_interface)
|
target_link_libraries(bitcoin_crypto_sse41 PRIVATE core_interface coverage_interface)
|
||||||
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_sse41)
|
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_sse41)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -43,7 +44,7 @@ if(HAVE_AVX2)
|
||||||
)
|
)
|
||||||
target_compile_definitions(bitcoin_crypto_avx2 PUBLIC ENABLE_AVX2)
|
target_compile_definitions(bitcoin_crypto_avx2 PUBLIC ENABLE_AVX2)
|
||||||
target_compile_options(bitcoin_crypto_avx2 PRIVATE ${AVX2_CXXFLAGS})
|
target_compile_options(bitcoin_crypto_avx2 PRIVATE ${AVX2_CXXFLAGS})
|
||||||
target_link_libraries(bitcoin_crypto_avx2 PRIVATE core_interface)
|
target_link_libraries(bitcoin_crypto_avx2 PRIVATE core_interface coverage_interface)
|
||||||
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_avx2)
|
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_avx2)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -53,7 +54,7 @@ if(HAVE_SSE41 AND HAVE_X86_SHANI)
|
||||||
)
|
)
|
||||||
target_compile_definitions(bitcoin_crypto_x86_shani PUBLIC ENABLE_SSE41 ENABLE_X86_SHANI)
|
target_compile_definitions(bitcoin_crypto_x86_shani PUBLIC ENABLE_SSE41 ENABLE_X86_SHANI)
|
||||||
target_compile_options(bitcoin_crypto_x86_shani PRIVATE ${X86_SHANI_CXXFLAGS})
|
target_compile_options(bitcoin_crypto_x86_shani PRIVATE ${X86_SHANI_CXXFLAGS})
|
||||||
target_link_libraries(bitcoin_crypto_x86_shani PRIVATE core_interface)
|
target_link_libraries(bitcoin_crypto_x86_shani PRIVATE core_interface coverage_interface)
|
||||||
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_x86_shani)
|
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_x86_shani)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -63,6 +64,6 @@ if(HAVE_ARM_SHANI)
|
||||||
)
|
)
|
||||||
target_compile_definitions(bitcoin_crypto_arm_shani PUBLIC ENABLE_ARM_SHANI)
|
target_compile_definitions(bitcoin_crypto_arm_shani PUBLIC ENABLE_ARM_SHANI)
|
||||||
target_compile_options(bitcoin_crypto_arm_shani PRIVATE ${ARM_SHANI_CXXFLAGS})
|
target_compile_options(bitcoin_crypto_arm_shani PRIVATE ${ARM_SHANI_CXXFLAGS})
|
||||||
target_link_libraries(bitcoin_crypto_arm_shani PRIVATE core_interface)
|
target_link_libraries(bitcoin_crypto_arm_shani PRIVATE core_interface coverage_interface)
|
||||||
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_arm_shani)
|
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_arm_shani)
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -19,5 +19,6 @@ target_capnp_sources(bitcoin_ipc ${PROJECT_SOURCE_DIR}
|
||||||
target_link_libraries(bitcoin_ipc
|
target_link_libraries(bitcoin_ipc
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
univalue
|
univalue
|
||||||
)
|
)
|
||||||
|
|
|
@ -81,6 +81,7 @@ add_library(bitcoinkernel
|
||||||
target_link_libraries(bitcoinkernel
|
target_link_libraries(bitcoinkernel
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_clientversion
|
bitcoin_clientversion
|
||||||
bitcoin_crypto
|
bitcoin_crypto
|
||||||
leveldb
|
leveldb
|
||||||
|
|
|
@ -148,6 +148,7 @@ add_executable(test_bitcoin
|
||||||
|
|
||||||
target_link_libraries(test_bitcoin
|
target_link_libraries(test_bitcoin
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
test_util
|
test_util
|
||||||
bitcoin_cli
|
bitcoin_cli
|
||||||
bitcoin_node
|
bitcoin_node
|
||||||
|
@ -165,6 +166,7 @@ if(WITH_MULTIPROCESS)
|
||||||
target_link_libraries(bitcoin_ipc_test
|
target_link_libraries(bitcoin_ipc_test
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
univalue
|
univalue
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -134,6 +134,7 @@ add_executable(fuzz
|
||||||
)
|
)
|
||||||
target_link_libraries(fuzz
|
target_link_libraries(fuzz
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
test_fuzz
|
test_fuzz
|
||||||
bitcoin_cli
|
bitcoin_cli
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
|
|
|
@ -13,6 +13,7 @@ add_library(test_fuzz STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(test_fuzz
|
target_link_libraries(test_fuzz
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
test_util
|
test_util
|
||||||
bitcoin_node
|
bitcoin_node
|
||||||
Boost::headers
|
Boost::headers
|
||||||
|
|
|
@ -23,6 +23,7 @@ add_library(test_util STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(test_util
|
target_link_libraries(test_util
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
Boost::headers
|
Boost::headers
|
||||||
PUBLIC
|
PUBLIC
|
||||||
univalue
|
univalue
|
||||||
|
|
|
@ -12,7 +12,11 @@ target_include_directories(univalue
|
||||||
PUBLIC
|
PUBLIC
|
||||||
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
||||||
)
|
)
|
||||||
target_link_libraries(univalue PRIVATE core_interface)
|
target_link_libraries(univalue
|
||||||
|
PRIVATE
|
||||||
|
core_interface
|
||||||
|
coverage_interface
|
||||||
|
)
|
||||||
|
|
||||||
if(BUILD_TESTS)
|
if(BUILD_TESTS)
|
||||||
add_executable(unitester test/unitester.cpp)
|
add_executable(unitester test/unitester.cpp)
|
||||||
|
@ -23,6 +27,7 @@ if(BUILD_TESTS)
|
||||||
target_link_libraries(unitester
|
target_link_libraries(unitester
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
univalue
|
univalue
|
||||||
)
|
)
|
||||||
add_test(NAME univalue_test
|
add_test(NAME univalue_test
|
||||||
|
@ -33,6 +38,7 @@ if(BUILD_TESTS)
|
||||||
target_link_libraries(object
|
target_link_libraries(object
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
univalue
|
univalue
|
||||||
)
|
)
|
||||||
add_test(NAME univalue_object_test
|
add_test(NAME univalue_object_test
|
||||||
|
|
|
@ -39,6 +39,7 @@ add_library(bitcoin_util STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_util
|
target_link_libraries(bitcoin_util
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_clientversion
|
bitcoin_clientversion
|
||||||
bitcoin_crypto
|
bitcoin_crypto
|
||||||
$<$<PLATFORM_ID:Windows>:ws2_32>
|
$<$<PLATFORM_ID:Windows>:ws2_32>
|
||||||
|
|
|
@ -36,6 +36,7 @@ add_library(bitcoin_wallet STATIC EXCLUDE_FROM_ALL
|
||||||
target_link_libraries(bitcoin_wallet
|
target_link_libraries(bitcoin_wallet
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
bitcoin_common
|
bitcoin_common
|
||||||
univalue
|
univalue
|
||||||
Boost::headers
|
Boost::headers
|
||||||
|
|
|
@ -16,6 +16,7 @@ target_compile_definitions(bitcoin_zmq
|
||||||
target_link_libraries(bitcoin_zmq
|
target_link_libraries(bitcoin_zmq
|
||||||
PRIVATE
|
PRIVATE
|
||||||
core_interface
|
core_interface
|
||||||
|
coverage_interface
|
||||||
univalue
|
univalue
|
||||||
zeromq
|
zeromq
|
||||||
)
|
)
|
||||||
|
|
Loading…
Add table
Reference in a new issue