summaryrefslogtreecommitdiff
path: root/cmake/tests.cmake
diff options
context:
space:
mode:
authorDimitri Staessens <dimitri@ouroboros.rocks>2026-02-02 22:50:17 +0100
committerSander Vrijders <sander@ouroboros.rocks>2026-02-04 08:17:24 +0100
commit4c64d7daef8819d644ab78a911067b16943f023d (patch)
tree7545488b224d510017f08a99006d9949367a9d77 /cmake/tests.cmake
parentb1687570df3e080c961cdcc0d59b708cfbdf955e (diff)
downloadouroboros-4c64d7daef8819d644ab78a911067b16943f023d.tar.gz
ouroboros-4c64d7daef8819d644ab78a911067b16943f023d.zip
build: Refactor CMake back to in-tree CMakeListsbe
This moves the build definitions back to src/ subdirectories (CMakeLists.txt per component). Configuration and dependencies are kept out of tree. Configuration options are bundled into cmake/config/ modules. Dependencies are grouped by component (system/, crypt/, eth/, coverage/, etc.). It now consistently uses target-based commands (target_include_directories, target_link_libraries) instead of global include_directories(). Proper PRIVATE/PUBLIC visibility for executable link libraries. CONFIG_OUROBOROS_DEBUG now properly set based on being a valid debug config (not just checking the string name). It also adds OuroborosTargets export for find_package() support and CMake package config files (OuroborosConfig.cmake) for easier integration with CMake projects. The build logic now follows more idiomatic CMake practices with configuration separated from target definitions. Signed-off-by: Dimitri Staessens <dimitri@ouroboros.rocks> Signed-off-by: Sander Vrijders <sander@ouroboros.rocks>
Diffstat (limited to 'cmake/tests.cmake')
-rw-r--r--cmake/tests.cmake30
1 files changed, 15 insertions, 15 deletions
diff --git a/cmake/tests.cmake b/cmake/tests.cmake
index e3857cab..edc2987c 100644
--- a/cmake/tests.cmake
+++ b/cmake/tests.cmake
@@ -1,30 +1,30 @@
include(CTest) # Sets BUILD_TESTING by default to on.
include(utils/TestUtils)
+# Test configuration options
+include(config/tests)
include(utils/DisableTestLogging)
-if (CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME AND BUILD_TESTING)
+if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME AND BUILD_TESTING)
set(BUILD_TESTS ON)
-else ()
+else()
set(BUILD_TESTS OFF)
endif()
add_custom_target(build_tests)
-if (BUILD_TESTS)
+if(BUILD_TESTS)
add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND})
add_dependencies(check build_tests)
+endif()
- # Add test subdirectories
- add_subdirectory(src/lib/tests)
- add_subdirectory(src/lib/ssm/tests)
- add_subdirectory(src/irmd/oap/tests)
- add_subdirectory(src/ipcpd/unicast/pff/tests)
- add_subdirectory(src/ipcpd/unicast/routing/tests)
- add_subdirectory(src/ipcpd/unicast/dir/tests)
- add_subdirectory(src/irmd/reg/tests)
+# Test subdirectories are added from their parent CMakeLists.txt files
+# via add_subdirectory(tests) - keeping tests with their source code
- # Create coverage target if gcov is available
- include(utils/GenCoverage)
- create_coverage_target()
-endif ()
+# Coverage target setup (called after all targets are defined)
+function(setup_coverage_target)
+ if(BUILD_TESTS)
+ include(utils/GenCoverage)
+ create_coverage_target()
+ endif()
+endfunction()