如何强制cmake在make测试后写测试输出

ubof19bj  于 2023-10-20  发布在  其他
关注(0)|答案(3)|浏览(140)

我正在用cmake构建fortran项目,我找不到解决方案来打印到控制台FRUIT测试结果,它们看起来像这样:

Test module initialized

    . : successful assert,   F : failed assert 

    7.00000000000000       -3.60000000000000        7.00000000000000     
FFF

     Start of FRUIT summary: 

 Some tests failed!

   -- Failed assertion messages:
   [_not_set_]:Expected [7.00000000000000], Got [1.00000000000000]
   [_not_set_]:Expected [-3.60000000000000], Got [2.00000000000000]
   [_not_set_]:Expected [7.00000000000000], Got [6.00000000000000]
   -- end of failed assertion messages.

 Total asserts :              3
 Successful    :              0
 Failed        :              3 
 Successful rate:     0.00%

 Successful asserts / total asserts : [            0 /           3  ]
 Successful cases   / total cases   : [            0 /           0  ]
   -- end of FRUIT summary

我使用make test得到的输出如下:

make test
Running tests...
Test project /home/konrad/Desktop/fortran
    Start 1: unit_tests
1/1 Test #1: unit_tests .......................   Passed    0.01 sec

100% tests passed, 0 tests failed out of 1

Total Test time (real) =   0.01 sec

由于通过cmake测试并不意味着通过FRUIT测试,我想在每次运行测试时打印FRUIT文件(只是为了使它工作)。我尝试在测试命令的末尾添加打印命令(像这样),添加

-P ${CMAKE_TEST_DIR}/unit_tests.txt

在add_test结束时,在构建命令后构建自定义命令(我不能在make test之后运行,所以如果你知道如何做,也会解决它,似乎make test或test不是真正的目标)
我的cmake文件的最后一部分包含所有测试代码:

add_executable(task ${TASK_SOURCES})
add_executable(tests ${TEST_SOURCES})


enable_testing() 

set(run_command "${CMAKE_BINARY_DIR}/tests")
set(UNIT_TEST_NAME "unit_tests.txt")

file(MAKE_DIRECTORY ${CMAKE_TEST_DIR})

add_test( NAME unit_tests
      COMMAND sh -c
     "rm -f ${CMAKE_TEST_DIR}/${UNIT_TEST_NAME} \
      && ${run_command} \
      >> ${CMAKE_TEST_DIR}/${UNIT_TEST_NAME} \
      && less ${CMAKE_TEST_DIR}/${UNIT_TEST_NAME}"
      )
epggiuax

epggiuax1#

我已经解决了一个缺乏测试输出的自定义CMake目标,它将在详细模式下调用ctest等。例如

enable_testing()

add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}
     --force-new-ctest-process
     --verbose
      --output-on-failure
)
e5nqia27

e5nqia272#

cmake测试的输出被捕获到一个文件中(在我当前的项目中是Testing/Temporary/LastTest.log)。
cmake测试依赖于测试程序的返回代码,每个测试一个测试程序。
如果您希望运行一个作为测试“驱动程序”的程序,我推荐使用add_custom_target。此命令将添加一个运行您选择的命令的目标。
例如:

add_custom_target(Name unit_tests tests)
add_dependencies(unit_tests tests)

我不确定在这种情况下是否需要add_dependencies行(因为tests是由cmake管理的目标)。
然后,你可以跑了

make unit_tests

它将运行您的测试驱动程序。

uidvcgyl

uidvcgyl3#

我知道这是一个老问题,但我也有同样的问题。上面提供的解决方案都不适合我。
将test作为post build命令运行可以做到这一点:

# hack to display verbose testing after build
  add_custom_command(TARGET myTestTarget POST_BUILD
    COMMAND ${CMAKE_CTEST_COMMAND} -C ${CMAKE_BUILD_TYPE} --verbose
    COMMENT "\n\n\n---===== PLEASE REVIEW TEST OUTPUT BELOW =====---\n\n\n"
  )

相关问题