some `test/CMakeLists.txt` cleanups (#4067)

* test/CMakeLists.txt: removed unnecessary `CTest` include - gets rid of additional CTest/CDash targets

* test/CMakeLists.txt: adjusted CMake version - `CMAKE_MATCH_<n>` requires 3.9`

* test/CMakeLists.txt: sorted `add_cfg()` calls

* test/CMakeLists.txt: extract test fixtures based on `REGISTER_TEST` macro

* test/CmakeLists.txt: added TODO
This commit is contained in:
Oliver Stöneberg 2022-06-02 22:26:01 +02:00 committed by GitHub
parent 67795cdfcf
commit 133b9c2790
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 27 additions and 32 deletions

View File

@ -37,6 +37,7 @@ if (BUILD_TESTS)
add_dependencies(testrunner copy_addons)
if (LIBXML2_XMLLINT_EXECUTABLE)
# TODO: run the CMake implementation of the tests
# TODO: get rid of the copy
add_custom_target(checkcfg ${CMAKE_COMMAND} -E copy $<TARGET_FILE:cppcheck> ${CMAKE_SOURCE_DIR}
COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/cfg/runtests.sh
@ -44,12 +45,12 @@ if (BUILD_TESTS)
endif()
if (REGISTER_TESTS)
cmake_minimum_required(VERSION 3.4) # cmake_policy(SET CMP0064 NEW)
# CMP0064 requires 3.4
# CMAKE_MATCH_<n> usage for if (MATCHES) requires 3.9
cmake_minimum_required(VERSION 3.9)
cmake_policy(SET CMP0064 NEW)
cmake_policy(SET CMP0057 NEW)
include(CTest)
find_package(Threads REQUIRED)
include(ProcessorCount)
ProcessorCount(N)
@ -84,21 +85,14 @@ if (BUILD_TESTS)
endif()
endfunction()
# TODO: what is this?
add_fixture(TestSamples WORKING_DIRECTORY ${PROJECT_SOURCE_DIR})
foreach(SRC ${srcs})
file(STRINGS ${SRC} FIXTURE_LINE REGEX "TestFixture\\(" LIMIT_COUNT 1)
if(FIXTURE_LINE MATCHES "TestFixture\\(\"([a-zA-z0-9]+)\"\\)")
file(STRINGS ${SRC} FIXTURE_LINE REGEX "^REGISTER_TEST\\([a-zA-z0-9]+\\)$")
foreach(_fixture_line ${FIXTURE_LINE})
if(_fixture_line MATCHES "^REGISTER_TEST\\(([a-zA-z0-9]+)\\)$")
add_fixture(${CMAKE_MATCH_1})
endif()
endforeach()
# TODO: parse files for REGISTER_TEST macro
add_fixture(TestLeakAutoVarStrcpy)
add_fixture(TestLeakAutoVarWindows)
add_fixture(TestMemleakInFunction)
add_fixture(TestMemleakInClass)
add_fixture(TestMemleakStructMember)
add_fixture(TestMemleakNoVar)
endforeach()
function(add_cfg CFG_TEST)
set(options INCONCLUSIVE)
@ -142,29 +136,30 @@ if (BUILD_TESTS)
)
endif()
endfunction()
add_cfg(posix.c)
add_cfg(gnu.c LIBRARY posix;gnu)
add_cfg(qt.cpp INCONCLUSIVE)
add_cfg(boost.cpp INCONCLUSIVE)
add_cfg(bsd.c)
add_cfg(cairo.c)
add_cfg(cppunit.cpp INCONCLUSIVE)
add_cfg(gnu.c LIBRARY posix;gnu)
add_cfg(googletest.cpp INCONCLUSIVE)
add_cfg(gtk.c INCONCLUSIVE)
add_cfg(kde.cpp INCONCLUSIVE)
add_cfg(libcurl.c)
add_cfg(libsigc++.cpp)
add_cfg(lua.c)
add_cfg(opencv2.cpp)
add_cfg(openmp.c)
add_cfg(openssl.c)
add_cfg(posix.c)
add_cfg(python.c)
add_cfg(qt.cpp INCONCLUSIVE)
add_cfg(sqlite3.c INCONCLUSIVE)
add_cfg(std.c INCONCLUSIVE)
add_cfg(std.cpp INCONCLUSIVE)
add_cfg(windows.cpp INCONCLUSIVE NAME windows32A PLATFORM win32A)
add_cfg(windows.cpp INCONCLUSIVE NAME windows32W PLATFORM win32W)
add_cfg(windows.cpp INCONCLUSIVE NAME windows64 PLATFORM win64)
add_cfg(wxwidgets.cpp INCONCLUSIVE)
add_cfg(gtk.c INCONCLUSIVE)
add_cfg(boost.cpp INCONCLUSIVE)
add_cfg(sqlite3.c INCONCLUSIVE)
add_cfg(openmp.c)
add_cfg(python.c)
add_cfg(lua.c)
add_cfg(libcurl.c)
add_cfg(cairo.c)
add_cfg(googletest.cpp INCONCLUSIVE)
add_cfg(kde.cpp INCONCLUSIVE)
add_cfg(libsigc++.cpp)
add_cfg(openssl.c)
add_cfg(opencv2.cpp)
# Set cost of the more expensive tests to help improve parallel scheduling
# of tests