Я создаю проект fortran с cmake, и я не могу найти решение для печати на консоли результатов теста 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}"
)





Результаты тестов 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
и он запустит ваш тестовый драйвер.
Я решил проблему отсутствия результатов тестов с помощью настраиваемой цели CMake, которая будет вызывать ctest в подробном режиме и т. д. например
enable_testing()
add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}
--force-new-ctest-process
--verbose
--output-on-failure
)