从测试中获取详细输出

时间:2015-02-25 17:53:46

标签: cmake ctest

我如何得到"进行测试"显示详细输出?我想"进行测试"通过命令行执行与ctest -V相同的操作。

我尝试将以下内容添加到我的CMakeLists.txt中,没有任何效果:(

set(ENV{CTEST_OUTPUT_ON_FAILURE} TRUE)

add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND} --verbose)

add_custom_command(TARGET test PRE_BUILD
               COMMAND ${CMAKE_CTEST_COMMAND} -V)

但是当我运行make test时,我仍然会得到这个:

  Start   1: unittest1
  1/143 Test   #1: unittest1 ....................................   Passed    0.01 sec
        Start   2: unittest2
  2/143 Test   #2: unittest2 ............................   Passed    0.03 sec
        Start   3: unittest3
  3/143 Test   #3: unittest3 ....................   Passed    0.02 sec

为了澄清,我想在我的CMakeLists.txt中添加一些内容以使其成为可能,我不想要一个手动解决方案,需要我添加一些东西来进行测试"在命令行中,如

CTEST_OUTPUT_ON_FAILURE=TRUE make test

ctest -V 

我的问题类似于 Using cmake how do I get verbose output from ctest?

1 个答案:

答案 0 :(得分:5)

GNU Radio's wiki页面开始对树外模块进行测试(由Braun先生提供):

从构建目录(通常)运行ctest -V,它将为您提供详细信息。添加-R regex以仅执行与regex匹配的测试。

现在,重新运行失败测试似乎对我来说很有意义 - 并且不会在每个make test上自动执行此操作,因为测试可能非常耗时,并且不应该#39;默认情况下,在破坏的构建环境等中重复。

如何将该行为添加到默认的make test行为当然取决于您的CMake基础架构,我无法在不阅读您的代码的情况下回答这一问题。