aboutsummaryrefslogtreecommitdiffstats
path: root/host/tests/CMakeLists.txt
diff options
context:
space:
mode:
Diffstat (limited to 'host/tests/CMakeLists.txt')
-rw-r--r--host/tests/CMakeLists.txt108
1 files changed, 59 insertions, 49 deletions
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
)
########################################################################