aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2019-05-21 11:33:41 -0700
committerMartin Braun <martin.braun@ettus.com>2019-05-22 15:34:52 -0700
commita76ce96c9f8dae6521e9e1fc59283cbf72e6461a (patch)
tree093e20567f5da0d24bc32021c2b7d5da2775c33b
parent7a062a181ae1a0270408fff594d18a4c2dc3c009 (diff)
downloaduhd-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.cmake1
-rw-r--r--host/tests/CMakeLists.txt108
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
)
########################################################################