3

我正在使用 CMake 开发一个项目,并且刚刚集成了一些 CppUnit 测试。我想使用 CTest,因此我在我的 CMakeLists.txt 文件中使用了 add_test,以便在键入时执行测试make test。然而,我观察到,在输入 时make test,它表示所有测试都通过了,即使我做了一个带有微不足道的错误的测试。错误的测试在手动执行(例如 ./my_test)时报告这些错误,但在使用make test.

这是测试目录中我的 CMakeLists.txt 的内容:

add_executable(TestDataSpace TestDataSpace.cpp)
target_link_libraries(TestDataSpace ${DEP_LIBRARIES} ${CPPUNIT_LIBRARIES})

add_executable(TestVariableManager TestVariableManager.cpp)
target_link_libraries(TestVariableManager ${DEP_LIBRARIES} ${CPPUNIT_LIBRARIES})

add_executable(TestLayoutManager TestLayoutManager.cpp)
target_link_libraries(TestLayoutManager ${DEP_LIBRARIES} ${CPPUNIT_LIBRARIES})

add_test(NAME "TestDataSpace" COMMAND ${MY_PROJECT_SOURCE_DIR}/test/TestDataSpace)
add_test(NAME "TestVariableManager" COMMAND ${MY_PROJECT_SOURCE_DIR}/test/TestVariableManager)
add_test(NAME "TestLayoutManager" COMMAND ${MY_PROJECT_SOURCE_DIR}/test/TestLayoutManager)

CTest 确实找到了可执行文件,因为为命令设置了错误的路径会使 CMake 抱怨它找不到它们。

make test输出以下内容:

运行测试...测试项目

Start 1: TestDataSpace 1/3 Test #1: TestDataSpace ....................   Passed    0.01 sec
Start 2: TestVariableManager 2/3 Test #2: TestVariableManager ..............   Passed    0.02 sec
Start 3: TestLayoutManager 3/3 Test #3: TestLayoutManager ................   Passed    0.01 sec

100% 测试通过,3 次测试中 0 次失败

我错过了什么?

4

1 回答 1

8

我不熟悉 CppUnit,但我怀疑你的可执行文件总是返回0,即使测试失败。CTest 接受一个返回0来表示成功。

如果在测试失败时将返回值更改为非零数字,您应该会看到 CTest 的预期输出。

或者,您可以通过设置和/或set_tests_properties的值来修改 CTest 的行为。如果设置了其中任何一个,则忽略返回值。例如,您可以这样做:PASS_REGULAR_EXPRESSIONFAIL_REGULAR_EXPRESSION

set_tests_properties(
    TestDataSpace
    TestVariableManager
    TestLayoutManager
        PROPERTIES PASS_REGULAR_EXPRESSION "TEST PASSED;Pass")

顺便说一句,您可以避免将完整路径传递给您的案例中的测试可执行文件,因为它们是在同一 CMakeLists.txt 中定义的实际 CMake 目标:

add_test(NAME TestDataSpace COMMAND TestDataSpace)
add_test(NAME TestVariableManager COMMAND TestVariableManager)
add_test(NAME TestLayoutManager COMMAND TestLayoutManager)
于 2013-07-26T23:17:06.143 回答