diff options
author | Martin Braun <martin.braun@ettus.com> | 2019-05-21 11:33:41 -0700 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2019-05-22 15:34:52 -0700 |
commit | a76ce96c9f8dae6521e9e1fc59283cbf72e6461a (patch) | |
tree | 093e20567f5da0d24bc32021c2b7d5da2775c33b | |
parent | 7a062a181ae1a0270408fff594d18a4c2dc3c009 (diff) | |
download | uhd-a76ce96c9f8dae6521e9e1fc59283cbf72e6461a.tar.gz uhd-a76ce96c9f8dae6521e9e1fc59283cbf72e6461a.tar.bz2 uhd-a76ce96c9f8dae6521e9e1fc59283cbf72e6461a.zip |
cmake: tests: Add macro for non-API based unit tests
All unit tests which require extra sources (i.e., can't just interact
with the UHD API) have been manually added to the CMakeLists.txt in
a clumsy fashion. This macro cleans that up a little.
-rw-r--r-- | host/cmake/Modules/UHDUnitTest.cmake | 1 | ||||
-rw-r--r-- | host/tests/CMakeLists.txt | 108 |
2 files changed, 60 insertions, 49 deletions
diff --git a/host/cmake/Modules/UHDUnitTest.cmake b/host/cmake/Modules/UHDUnitTest.cmake index 0807fe3b5..3ebf3f08c 100644 --- a/host/cmake/Modules/UHDUnitTest.cmake +++ b/host/cmake/Modules/UHDUnitTest.cmake @@ -1,6 +1,7 @@ # # Copyright 2010-2012,2015 Ettus Research LLC # Copyright 2018 Ettus Research, a National Instruments Company +# Copyright 2019 Ettus Research, a National Instruments Brand # # SPDX-License-Identifier: GPL-3.0-or-later # diff --git a/host/tests/CMakeLists.txt b/host/tests/CMakeLists.txt index 33fbcdbf9..a7d2120aa 100644 --- a/host/tests/CMakeLists.txt +++ b/host/tests/CMakeLists.txt @@ -104,73 +104,86 @@ foreach(benchmark_source ${benchmark_sources}) UHD_INSTALL(TARGETS ${benchmark_name} RUNTIME DESTINATION ${PKG_LIB_DIR}/tests COMPONENT tests) endforeach(benchmark_source) -# Other tests that don't directly link with libuhd: (TODO find a nicer way to do this) + +############################################################################### +# Add a unit test that requires linkage to internal parts of UHD which are not +# API +############################################################################### +macro(UHD_ADD_NONAPI_TEST) + cmake_parse_arguments(test "NOAUTORUN" "TARGET" "INCLUDE_DIRS;EXTRA_SOURCES;EXTRA_LIBS" ${ARGN}) + get_filename_component(test_name ${test_TARGET} NAME_WE) + include_directories(${test_INCLUDE_DIRS}) + add_executable(${test_name} ${test_TARGET} ${test_EXTRA_SOURCES}) + target_link_libraries(${test_name} uhd ${Boost_LIBRARIES}) + if(NOT ${test_NOAUTORUN}) + UHD_ADD_TEST(${test_name} ${test_name}) + endif(NOT ${test_NOAUTORUN}) + UHD_INSTALL(TARGETS ${test_name} + RUNTIME + DESTINATION ${PKG_LIB_DIR}/tests + COMPONENT tests) +endmacro(UHD_ADD_NONAPI_TEST) + +############################################################################### +# Now add all unit tests that require special linkage +############################################################################### if(ENABLE_DPDK) - include_directories(${CMAKE_BINARY_DIR}/lib/transport/) - include_directories(${CMAKE_SOURCE_DIR}/lib/transport/) find_package(DPDK) - include_directories(${DPDK_INCLUDE_DIR}) - add_executable(dpdk_test - dpdk_test.cpp + UHD_ADD_NONAPI_TEST( + TARGET "dpdk_test.cpp" + EXTRA_SOURCES ${CMAKE_SOURCE_DIR}/lib/utils/config_parser.cpp ${CMAKE_SOURCE_DIR}/lib/utils/paths.cpp ${CMAKE_SOURCE_DIR}/lib/utils/pathslib.cpp ${CMAKE_SOURCE_DIR}/lib/utils/prefs.cpp ${CMAKE_SOURCE_DIR}/lib/transport/dpdk_zero_copy.cpp + INCLUDE_DIRS + ${DPDK_INCLUDE_DIR} + ${CMAKE_BINARY_DIR}/lib/transport/ + ${CMAKE_SOURCE_DIR}/lib/transport/ + EXTRA_LIBS ${DPDK_LIBRARIES} + NOAUTORUN # Don't register for auto-run, it requires special config ) - target_link_libraries(dpdk_test uhd ${Boost_LIBRARIES} ${DPDK_LIBRARIES}) - # For the DPDK test, don't automatically run (requires specific config) - UHD_INSTALL(TARGETS dpdk_test RUNTIME DESTINATION ${PKG_LIB_DIR}/tests COMPONENT tests) ENDIF(ENABLE_DPDK) -include_directories(${CMAKE_BINARY_DIR}/lib/rfnoc/nocscript/) -include_directories(${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/) -add_executable(nocscript_expr_test - nocscript_expr_test.cpp - ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/expression.cpp +UHD_ADD_NONAPI_TEST( + TARGET "nocscript_expr_test.cpp" + EXTRA_SOURCES + "${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/expression.cpp" + INCLUDE_DIRS + ${CMAKE_BINARY_DIR}/lib/rfnoc/nocscript/ + ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/ ) -target_link_libraries(nocscript_expr_test uhd ${Boost_LIBRARIES}) -UHD_ADD_TEST(nocscript_expr_test nocscript_expr_test) -UHD_INSTALL(TARGETS nocscript_expr_test RUNTIME DESTINATION ${PKG_LIB_DIR}/tests COMPONENT tests) -add_executable(nocscript_ftable_test - nocscript_ftable_test.cpp +UHD_ADD_NONAPI_TEST( + TARGET "nocscript_ftable_test.cpp" + EXTRA_SOURCES ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/function_table.cpp ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/expression.cpp + INCLUDE_DIRS + ${CMAKE_BINARY_DIR}/lib/rfnoc/nocscript/ + ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/ ) -target_link_libraries(nocscript_ftable_test uhd ${Boost_LIBRARIES}) -UHD_ADD_TEST(nocscript_ftable_test nocscript_ftable_test) -UHD_INSTALL(TARGETS nocscript_ftable_test RUNTIME DESTINATION ${PKG_LIB_DIR}/tests COMPONENT tests) -add_executable(nocscript_parser_test - nocscript_parser_test.cpp +UHD_ADD_NONAPI_TEST( + TARGET "nocscript_parser_test.cpp" + EXTRA_SOURCES ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/parser.cpp ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/function_table.cpp ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/expression.cpp + INCLUDE_DIRS + ${CMAKE_BINARY_DIR}/lib/rfnoc/nocscript/ + ${CMAKE_SOURCE_DIR}/lib/rfnoc/nocscript/ ) -target_link_libraries(nocscript_parser_test uhd ${Boost_LIBRARIES}) -UHD_ADD_TEST(nocscript_parser_test nocscript_parser_test) -UHD_INSTALL(TARGETS nocscript_parser_test RUNTIME DESTINATION ${PKG_LIB_DIR}/tests COMPONENT tests) -add_executable(config_parser_test - config_parser_test.cpp - ${CMAKE_SOURCE_DIR}/lib/utils/config_parser.cpp -) -target_link_libraries(config_parser_test uhd ${Boost_LIBRARIES}) -UHD_ADD_TEST(config_parser_test config_parser_test) -UHD_INSTALL(TARGETS - config_parser_test - RUNTIME - DESTINATION ${PKG_LIB_DIR}/tests - COMPONENT tests +UHD_ADD_NONAPI_TEST( + TARGET "config_parser_test.cpp" + EXTRA_SOURCES ${CMAKE_SOURCE_DIR}/lib/utils/config_parser.cpp ) -add_executable(paths_test - paths_test.cpp - ${CMAKE_SOURCE_DIR}/lib/utils/pathslib.cpp -) # Careful: This is to satisfy the out-of-library build of paths.cpp. This is # duplicate code from lib/utils/CMakeLists.txt, and it's been simplified. +# TODO Figure out if this is even needed set(UHD_LIB_DIR "lib") file(TO_NATIVE_PATH "${CMAKE_INSTALL_PREFIX}" UHD_PKG_PATH) string(REPLACE "\\" "\\\\" UHD_PKG_PATH "${UHD_PKG_PATH}") @@ -179,13 +192,10 @@ set_source_files_properties( PROPERTIES COMPILE_DEFINITIONS "UHD_PKG_PATH=\"${UHD_PKG_PATH}\";UHD_LIB_DIR=\"${UHD_LIB_DIR}\"" ) -target_link_libraries(paths_test uhd ${Boost_LIBRARIES}) -UHD_ADD_TEST(paths_test paths_test) -UHD_INSTALL(TARGETS - paths_test - RUNTIME - DESTINATION ${PKG_LIB_DIR}/tests - COMPONENT tests +UHD_ADD_NONAPI_TEST( + TARGET "paths_test.cpp" + EXTRA_SOURCES + ${CMAKE_SOURCE_DIR}/lib/utils/pathslib.cpp ) ######################################################################## |