From 15a997aa00f2672c198918b8f2d9193ddf3a2d06 Mon Sep 17 00:00:00 2001 From: Michael Cho Date: Fri, 25 Oct 2024 11:52:59 -0400 Subject: [PATCH] Add CTest support and option to skip test progs --- .github/workflows/cmake.yml | 4 ++++ CMakeLists.txt | 1 + prog/CMakeLists.txt | 23 ++++++++++++++++++++++- prog/reg_wrapper.sh | 2 +- 4 files changed, 28 insertions(+), 2 deletions(-) diff --git a/.github/workflows/cmake.yml b/.github/workflows/cmake.yml index 6eca5fdca..77152d2e8 100644 --- a/.github/workflows/cmake.yml +++ b/.github/workflows/cmake.yml @@ -48,4 +48,8 @@ jobs: - name: Build # Build your program with the given configuration run: sudo cmake --build ${{github.workspace}}/build --config ${{env.BUILD_TYPE}} --target install + + - name: Test + if: runner.os == 'Linux' + run: ctest --test-dir ${{github.workspace}}/build diff --git a/CMakeLists.txt b/CMakeLists.txt index c13128664..8f0a32def 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -43,6 +43,7 @@ project( leptonica LANGUAGES C VERSION 1.85.1) +include(CTest) set(CMAKE_C_STANDARD 11) set(CMAKE_C_STANDARD_REQUIRED ON) diff --git a/prog/CMakeLists.txt b/prog/CMakeLists.txt index e7d9533d6..c48647530 100644 --- a/prog/CMakeLists.txt +++ b/prog/CMakeLists.txt @@ -1,10 +1,31 @@ +set (MANUAL_REG_PROGS + alltests_reg bilateral1_reg + binmorph2_reg binmorph4_reg binmorph5_reg + dwamorph2_reg + files_reg fmorphauto_reg + morphseq_reg pixalloc_reg pixtile_reg + smoothedge_reg +) set(math_progs "blend4_reg|dna_reg|extrema_reg|insert_reg|locminmax_reg|numa1_reg|otsutest1|pixalloc_reg|plottest|pta_reg|rankhisto_reg|rotatefastalt|watershed_reg") +file(RELATIVE_PATH relative_reg_dir ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) + ######################################## # FUNCTION add_prog_target ######################################## function(add_prog_target target) + if(${target} MATCHES "_reg$") + if(NOT BUILD_TESTING) + return() + endif() + if(NOT target IN_LIST MANUAL_REG_PROGS) + add_test(NAME ${target} + COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/reg_wrapper.sh ${relative_reg_dir}/${target} + WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}) + set_tests_properties(${target} PROPERTIES SKIP_RETURN_CODE 78) + endif() + endif() set (${target}_src "${ARGN}") add_executable (${target} ${${target}_src}) string(FIND ${target} "gif" GIF_TEST_FOUND) @@ -15,7 +36,7 @@ function(add_prog_target target) if (BUILD_SHARED_LIBS) target_compile_definitions (${target} PRIVATE -DLIBLEPT_IMPORTS) endif() - if(FREEBSD AND HAVE_LIBM AND ${target} MATCHES ${math_progs}) + if(HAVE_LIBM AND ${target} MATCHES ${math_progs}) target_link_libraries (${target} leptonica m) else() target_link_libraries (${target} leptonica) diff --git a/prog/reg_wrapper.sh b/prog/reg_wrapper.sh index de1d20a21..5dd4f96ee 100755 --- a/prog/reg_wrapper.sh +++ b/prog/reg_wrapper.sh @@ -41,7 +41,7 @@ case "${TEST_NAME}" in GNUPLOT=$(which gnuplot || which wgnuplot) if [ -z "${GNUPLOT}" ] || [ -n "$(${GNUPLOT} -e 'set terminal png' 2>&1)" ] ; then - exec ${@%${TEST}} /bin/sh -c "exit 77" + exec ${@%${TEST}} /bin/sh -c "exit 78" fi esac