Add sanitize mode

This commit is contained in:
方而静 2024-06-19 07:24:17 +00:00
parent 273ce0c186
commit f4d676548f
2 changed files with 39 additions and 17 deletions

View File

@ -61,18 +61,32 @@ endif()
# PK_IS_MAIN determines whether the project is being used from root # PK_IS_MAIN determines whether the project is being used from root
# or if it is added as a dependency (through add_subdirectory for example). # or if it is added as a dependency (through add_subdirectory for example).
if ("${CMAKE_SOURCE_DIR}" STREQUAL "${CMAKE_CURRENT_SOURCE_DIR}") if ("${CMAKE_SOURCE_DIR}" STREQUAL "${CMAKE_CURRENT_SOURCE_DIR}")
set(PK_IS_MAIN TRUE) set(PK_IS_MAIN TRUE)
option(PK_BUILD_SHARED_LIB "Build shared library" OFF) option(PK_BUILD_SHARED_LIB "Build shared library" OFF)
option(PK_BUILD_STATIC_LIB "Build static library" OFF) option(PK_BUILD_STATIC_LIB "Build static library" OFF)
include(CTest) # @szdytom favored testing
if (BUILD_TESTING) # disabled by default because @blueloveTH doesn't like it :C
add_subdirectory(tests/) option(BUILD_TESTING "Build the testing tree." OFF)
endif() if (BUILD_TESTING)
option(BUILD_TESTING_SANITIZE "Build the source with sanitizers" OFF)
if (BUILD_TESTING_SANITIZE)
if (MSVC)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /fsanitize=address /fno-omit-frame-pointer")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /fsanitize=address /fno-omit-frame-pointer")
else()
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address,leak,undefined")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fsanitize=address,leak,undefined")
endif()
endif()
enable_testing()
add_subdirectory(tests/)
endif()
else() else()
set(PK_IS_MAIN FALSE) set(PK_IS_MAIN FALSE)
option(PK_BUILD_SHARED_LIB "Build shared library" OFF) option(PK_BUILD_SHARED_LIB "Build shared library" OFF)
option(PK_BUILD_STATIC_LIB "Build static library" ON) option(PK_BUILD_STATIC_LIB "Build static library" ON)
endif() endif()
if(PK_BUILD_SHARED_LIB) if(PK_BUILD_SHARED_LIB)
@ -82,12 +96,15 @@ elseif(PK_BUILD_STATIC_LIB)
else() else()
set(PROJECT_EXE_NAME main) set(PROJECT_EXE_NAME main)
add_executable(${PROJECT_EXE_NAME} src2/main.cpp) add_executable(${PROJECT_EXE_NAME} src2/main.cpp)
# shared linked main if (BUILD_TESTING_SANITIZE)
add_library(${PROJECT_NAME} SHARED ${POCKETPY_SRC}) # static linked main, for sanitizing purpose
target_link_libraries(${PROJECT_EXE_NAME} ${PROJECT_NAME} ${CMAKE_DL_LIBS}) add_library(${PROJECT_NAME} STATIC ${POCKETPY_SRC})
# static linked main target_link_libraries(${PROJECT_EXE_NAME} ${PROJECT_NAME})
# add_library(${PROJECT_NAME} STATIC ${POCKETPY_SRC}) else()
# target_link_libraries(${PROJECT_EXE_NAME} ${PROJECT_NAME}) # shared linked main, used by default, for CI and others
add_library(${PROJECT_NAME} SHARED ${POCKETPY_SRC})
target_link_libraries(${PROJECT_EXE_NAME} ${PROJECT_NAME} ${CMAKE_DL_LIBS})
endif()
endif() endif()
if(PK_USE_CJSON) if(PK_USE_CJSON)

View File

@ -1,3 +1,7 @@
# @szdytom favored testing, set BUILD_TESTING to enable it
# You can use scripts/run_tests.py as an alternative
# Note: the CI uses scripts/run_tests.py to run the tests
cmake_minimum_required(VERSION 3.10) cmake_minimum_required(VERSION 3.10)
function(pkpy_add_test pyfile) function(pkpy_add_test pyfile)
@ -7,9 +11,10 @@ function(pkpy_add_test pyfile)
COMMAND $<TARGET_FILE:main> ${pyfile} COMMAND $<TARGET_FILE:main> ${pyfile}
WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}/.. WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}/..
) )
message("Added test " ${test_name})
endfunction() endfunction()
message("Testing enabled")
file(GLOB PK_PYTHON_TESTCASES_FILES RELATIVE ${CMAKE_CURRENT_LIST_DIR}/.. "*.py") file(GLOB PK_PYTHON_TESTCASES_FILES RELATIVE ${CMAKE_CURRENT_LIST_DIR}/.. "*.py")
foreach(pyfile ${PK_PYTHON_TESTCASES_FILES}) foreach(pyfile ${PK_PYTHON_TESTCASES_FILES})