我希望每次成功构建项目时都启动测试。如果一些测试被打破了,我希望我的构建也被打破。默认情况下,我需要通过运行ctest
命令手动运行测试。CTest实际上可以构建项目,但我使用IDE调用make
来构建源代码。make
不运行测试
我将这个命令添加到我的根CMakeLists.txt文件中,但它不起作用。
add_custom_command(OUTPUT tests.txt
POST_BUILD
COMMAND ctest --output-on-failure)
CMake不返回任何错误,一切构建良好,但我的自定义命令不调用。我怎么能运行的东西后,每次成功构建在CMake?
更新:
我的最终解决方案是创建这个宏:
macro(add_unit_test target target_test)
set(UNIT_TEST_TARGETS ${UNIT_TEST_TARGETS} ${target_test} PARENT_SCOPE)
add_test(target ${CMAKE_CURRENT_BINARY_DIR}/${target_test})
endmacro(add_unit_test)
调用add_test
并在列表中记忆测试目标。由此宏添加的项目中的每个测试。在根CMakeLists.txt中,我有以下代码:
add_custom_target( all_tests ALL
DEPENDS ${UNIT_TEST_TARGETS}
)
add_custom_command(TARGET all_tests
COMMENT "Run tests"
POST_BUILD COMMAND ctest ARGS --output-on-failure
WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
)
它创建依赖于项目中所有单元测试的自定义目标。自定义命令在all_tests
目标构建后运行。
这种形式的add_custom_command
只会在另一个CMake目标依赖于"tests.txt"时执行。我假设没有其他目标将"tests.txt"作为输入文件,因此自定义命令永远不会运行。
我认为你可以使用add_custom_command
的第二种形式来实现你的目标;比如:
add_custom_command(TARGET MainTest
POST_BUILD
COMMAND ctest -C $<CONFIGURATION> --output-on-failure)