RunCMakeTest.cmake 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
  1. include(RunCMake)
  2. include(RunCTest)
  3. # Do not use any proxy for lookup of an invalid site.
  4. # DNS failure by proxy looks different than DNS failure without proxy.
  5. set(ENV{no_proxy} "$ENV{no_proxy},badhostname.invalid")
  6. set(RunCMake_TEST_TIMEOUT 60)
  7. block()
  8. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/FailureLabels)
  9. set(RunCMake_TEST_NO_CLEAN 1)
  10. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  11. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  12. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  13. add_test(ShortName \"${CMAKE_COMMAND}\" -E false)
  14. set_tests_properties(ShortName PROPERTIES LABELS \"Label1;Label2\")
  15. add_test(LongerName \"${CMAKE_COMMAND}\" -E false)
  16. set_tests_properties(LongerName PROPERTIES LABELS \"Label3\")
  17. add_test(Long_Test_Name_That_Is_Over_Fifty_Characters_In_Length \"${CMAKE_COMMAND}\" -E false)
  18. set_tests_properties(Long_Test_Name_That_Is_Over_Fifty_Characters_In_Length PROPERTIES LABELS \"Label4\")
  19. ")
  20. run_cmake_command(FailureLabels ${CMAKE_CTEST_COMMAND})
  21. endblock()
  22. run_cmake_command(repeat-opt-bad1
  23. ${CMAKE_CTEST_COMMAND} --repeat until-pass
  24. )
  25. run_cmake_command(repeat-opt-bad2
  26. ${CMAKE_CTEST_COMMAND} --repeat until-pass:foo
  27. )
  28. run_cmake_command(repeat-opt-bad3
  29. ${CMAKE_CTEST_COMMAND} --repeat until-fail:2 --repeat-until-fail 2
  30. )
  31. run_cmake_command(repeat-opt-bad4
  32. ${CMAKE_CTEST_COMMAND} --repeat-until-fail 2 --repeat until-fail:2
  33. )
  34. run_cmake_command(repeat-opt-until-pass
  35. ${CMAKE_CTEST_COMMAND} --repeat until-pass:2
  36. )
  37. run_cmake_command(repeat-opt-until-fail
  38. ${CMAKE_CTEST_COMMAND} --repeat until-fail:2
  39. )
  40. run_cmake_command(repeat-opt-after-timeout
  41. ${CMAKE_CTEST_COMMAND} --repeat after-timeout:2
  42. )
  43. run_cmake_command(repeat-until-fail-bad1
  44. ${CMAKE_CTEST_COMMAND} --repeat-until-fail
  45. )
  46. run_cmake_command(repeat-until-fail-bad2
  47. ${CMAKE_CTEST_COMMAND} --repeat-until-fail foo
  48. )
  49. run_cmake_command(repeat-until-fail-good
  50. ${CMAKE_CTEST_COMMAND} --repeat-until-fail 2
  51. )
  52. function(run_repeat_until_pass_tests)
  53. # Use a single build tree for a few tests without cleaning.
  54. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/repeat-until-pass-build)
  55. run_cmake(repeat-until-pass-cmake)
  56. set(RunCMake_TEST_NO_CLEAN 1)
  57. run_cmake_command(repeat-until-pass-ctest
  58. ${CMAKE_CTEST_COMMAND} -C Debug --repeat until-pass:3
  59. )
  60. endfunction()
  61. run_repeat_until_pass_tests()
  62. function(run_repeat_after_timeout_tests)
  63. # Use a single build tree for a few tests without cleaning.
  64. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/repeat-after-timeout-build)
  65. run_cmake(repeat-after-timeout-cmake)
  66. set(RunCMake_TEST_NO_CLEAN 1)
  67. run_cmake_command(repeat-after-timeout-ctest
  68. ${CMAKE_CTEST_COMMAND} -C Debug --repeat after-timeout:3
  69. )
  70. endfunction()
  71. run_repeat_after_timeout_tests()
  72. function(run_repeat_until_fail_tests)
  73. # Use a single build tree for a few tests without cleaning.
  74. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/repeat-until-fail-build)
  75. run_cmake(repeat-until-fail-cmake)
  76. set(RunCMake_TEST_NO_CLEAN 1)
  77. run_cmake_command(repeat-until-fail-ctest
  78. ${CMAKE_CTEST_COMMAND} -C Debug ${ARGN}
  79. )
  80. endfunction()
  81. run_repeat_until_fail_tests(--repeat-until-fail 3)
  82. run_repeat_until_fail_tests(--repeat until-fail:3)
  83. function(run_BadCTestTestfile)
  84. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/BadCTestTestfile)
  85. set(RunCMake_TEST_NO_CLEAN 1)
  86. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  87. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  88. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  89. subdirs()
  90. ")
  91. run_cmake_command(BadCTestTestfile ${CMAKE_CTEST_COMMAND})
  92. endfunction()
  93. run_BadCTestTestfile()
  94. function(run_Subdirectories)
  95. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/Subdirectories)
  96. set(RunCMake_TEST_NO_CLEAN 1)
  97. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  98. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  99. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}/add_subdirectory")
  100. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}/add_subdirectory/sub")
  101. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}/subdirs")
  102. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}/subdirs/sub")
  103. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  104. add_subdirectory(add_subdirectory)
  105. subdirs(subdirs)
  106. ")
  107. file(WRITE "${RunCMake_TEST_BINARY_DIR}/add_subdirectory/CTestTestfile.cmake" "
  108. add_test(add_subdirectory \"${CMAKE_COMMAND}\" -E echo add_subdirectory)
  109. add_subdirectory(sub)
  110. ")
  111. file(WRITE "${RunCMake_TEST_BINARY_DIR}/add_subdirectory/sub/CTestTestfile.cmake" "
  112. add_test(add_subdirectory.sub \"${CMAKE_COMMAND}\" -E echo add_subdirectory.sub)
  113. ")
  114. file(WRITE "${RunCMake_TEST_BINARY_DIR}/subdirs/CTestTestfile.cmake" "
  115. add_test(subdirs \"${CMAKE_COMMAND}\" -E echo subdirs)
  116. subdirs(sub)
  117. ")
  118. file(WRITE "${RunCMake_TEST_BINARY_DIR}/subdirs/sub/CTestTestfile.cmake" "
  119. add_test(subdirs.sub \"${CMAKE_COMMAND}\" -E echo subdirs.sub)
  120. ")
  121. run_cmake_command(Subdirectories ${CMAKE_CTEST_COMMAND} -N)
  122. endfunction()
  123. run_Subdirectories()
  124. function(run_MergeOutput)
  125. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/MergeOutput)
  126. set(RunCMake_TEST_NO_CLEAN 1)
  127. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  128. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  129. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  130. add_test(MergeOutput \"${CMAKE_COMMAND}\" -P \"${RunCMake_SOURCE_DIR}/MergeOutput.cmake\")
  131. ")
  132. run_cmake_command(MergeOutput ${CMAKE_CTEST_COMMAND} -V)
  133. endfunction()
  134. run_MergeOutput()
  135. function(run_LabelCount)
  136. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/LabelCount)
  137. set(RunCMake_TEST_NO_CLEAN 1)
  138. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  139. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  140. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  141. add_test(test1 \"${CMAKE_COMMAND}\" -E echo \"test1\")
  142. set_tests_properties(test1 PROPERTIES LABELS 'bar')
  143. add_test(test2 \"${CMAKE_COMMAND}\" -E echo \"test2\")
  144. set_tests_properties(test2 PROPERTIES LABELS 'bar')
  145. add_test(test3 \"${CMAKE_COMMAND}\" -E echo \"test3\")
  146. set_tests_properties(test3 PROPERTIES LABELS 'foo')
  147. add_test(test4 \"${CMAKE_COMMAND}\" -E echo \"test4\")
  148. set_tests_properties(test4 PROPERTIES LABELS 'bar')
  149. ")
  150. run_cmake_command(LabelCount ${CMAKE_CTEST_COMMAND} -V)
  151. endfunction()
  152. run_LabelCount()
  153. function(run_RequiredRegexFoundTest)
  154. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/RequiredRegexFound)
  155. set(RunCMake_TEST_NO_CLEAN 1)
  156. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  157. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  158. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  159. add_test(test1 \"${CMAKE_COMMAND}\" -E echo \"test1\")
  160. set_tests_properties(test1 PROPERTIES PASS_REGULAR_EXPRESSION \"foo;test1;bar\")
  161. ")
  162. run_cmake_command(RequiredRegexFound ${CMAKE_CTEST_COMMAND} -V)
  163. endfunction()
  164. run_RequiredRegexFoundTest()
  165. function(run_RequiredRegexNotFoundTest)
  166. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/RequiredRegexNotFound)
  167. set(RunCMake_TEST_NO_CLEAN 1)
  168. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  169. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  170. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  171. add_test(test1 \"${CMAKE_COMMAND}\" -E echo \"test1\")
  172. set_tests_properties(test1 PROPERTIES PASS_REGULAR_EXPRESSION \"foo;toast1;bar\" WILL_FAIL True)
  173. ")
  174. run_cmake_command(RequiredRegexNotFound ${CMAKE_CTEST_COMMAND} -V)
  175. endfunction()
  176. run_RequiredRegexNotFoundTest()
  177. function(run_FailRegexFoundTest)
  178. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/FailRegexFound)
  179. set(RunCMake_TEST_NO_CLEAN 1)
  180. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  181. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  182. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  183. add_test(test1 \"${CMAKE_COMMAND}\" -E echo \"test1\")
  184. set_tests_properties(test1 PROPERTIES FAIL_REGULAR_EXPRESSION \"foo;test1;bar\" WILL_FAIL True)
  185. ")
  186. run_cmake_command(FailRegexFound ${CMAKE_CTEST_COMMAND} -V)
  187. endfunction()
  188. run_FailRegexFoundTest()
  189. function(run_SkipRegexFoundTest)
  190. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/SkipRegexFound)
  191. set(RunCMake_TEST_NO_CLEAN 1)
  192. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  193. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  194. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  195. add_test(test1 \"${CMAKE_COMMAND}\" -E echo \"test1\")
  196. set_tests_properties(test1 PROPERTIES SKIP_REGULAR_EXPRESSION \"test1\")
  197. ")
  198. run_cmake_command(SkipRegexFound ${CMAKE_CTEST_COMMAND} -V)
  199. endfunction()
  200. run_SkipRegexFoundTest()
  201. function(run_TestsFromFileTest case)
  202. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TestsFromFile-${case})
  203. set(RunCMake_TEST_NO_CLEAN 1)
  204. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  205. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  206. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  207. add_test(Test1 \"${CMAKE_COMMAND}\" -E echo \"test1\")
  208. add_test(Test2 \"${CMAKE_COMMAND}\" -E echo \"test2\")
  209. add_test(Test11 \"${CMAKE_COMMAND}\" -E echo \"test11\")
  210. ")
  211. run_cmake_command(TestsFromFile-${case} ${CMAKE_CTEST_COMMAND} ${ARGN})
  212. endfunction()
  213. run_TestsFromFileTest(include --tests-from-file ${RunCMake_SOURCE_DIR}/TestsFromFile-TestList.txt)
  214. run_TestsFromFileTest(exclude --exclude-from-file ${RunCMake_SOURCE_DIR}/TestsFromFile-TestList.txt)
  215. run_TestsFromFileTest(include-empty --tests-from-file ${RunCMake_SOURCE_DIR}/TestsFromFile-TestList-empty.txt)
  216. run_TestsFromFileTest(exclude-empty --exclude-from-file ${RunCMake_SOURCE_DIR}/TestsFromFile-TestList-empty.txt)
  217. run_TestsFromFileTest(include-missing --tests-from-file ${RunCMake_SOURCE_DIR}/TestsFromFile-TestList-missing.txt)
  218. run_TestsFromFileTest(exclude-missing --exclude-from-file ${RunCMake_SOURCE_DIR}/TestsFromFile-TestList-missing.txt)
  219. function(run_SerialFailed)
  220. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/SerialFailed)
  221. set(RunCMake_TEST_NO_CLEAN 1)
  222. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  223. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  224. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  225. add_test(NoSuchCommand no_such_command)
  226. set_tests_properties(NoSuchCommand PROPERTIES RUN_SERIAL ON)
  227. add_test(Echo \"${CMAKE_COMMAND}\" -E echo \"EchoTest\")
  228. ")
  229. run_cmake_command(SerialFailed ${CMAKE_CTEST_COMMAND} -V)
  230. endfunction()
  231. run_SerialFailed()
  232. function(run_Parallel case)
  233. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/Parallel-${case})
  234. set(RunCMake_TEST_NO_CLEAN 1)
  235. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  236. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  237. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  238. foreach(i RANGE 1 6)
  239. add_test(test\${i} \"${CMAKE_COMMAND}\" -E true)
  240. endforeach()
  241. ")
  242. run_cmake_command(Parallel-${case} ${CMAKE_CTEST_COMMAND} ${ARGN})
  243. endfunction()
  244. # Spoof a number of processors to make these tests predictable.
  245. set(ENV{__CTEST_FAKE_PROCESSOR_COUNT_FOR_TESTING} 1)
  246. run_Parallel(bad --parallel bad)
  247. run_Parallel(j-bad -j bad)
  248. set(RunCMake_TEST_RAW_ARGS [[--parallel ""]])
  249. run_Parallel(empty) # With 1 processor, defaults to 2.
  250. unset(RunCMake_TEST_RAW_ARGS)
  251. run_Parallel(j -j) # With 1 processor, defaults to 2.
  252. run_Parallel(0 -j0)
  253. run_Parallel(4 --parallel 4)
  254. run_Parallel(N --parallel -N)
  255. set(ENV{CTEST_PARALLEL_LEVEL} bad)
  256. run_Parallel(env-bad)
  257. if(CMAKE_HOST_WIN32)
  258. set(ENV{CTEST_PARALLEL_LEVEL} " ")
  259. else()
  260. set(ENV{CTEST_PARALLEL_LEVEL} "")
  261. endif()
  262. run_Parallel(env-empty) # With 1 processor, defaults to 2.
  263. set(ENV{CTEST_PARALLEL_LEVEL} 0)
  264. run_Parallel(env-0)
  265. set(ENV{CTEST_PARALLEL_LEVEL} 3)
  266. run_Parallel(env-3)
  267. unset(ENV{CTEST_PARALLEL_LEVEL})
  268. unset(ENV{__CTEST_FAKE_PROCESSOR_COUNT_FOR_TESTING)
  269. function(run_TestLoad name load)
  270. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TestLoad)
  271. set(RunCMake_TEST_NO_CLEAN 1)
  272. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  273. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  274. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  275. add_test(TestLoad1 \"${CMAKE_COMMAND}\" -E echo \"test of --test-load\")
  276. set_tests_properties(TestLoad1 PROPERTIES PROCESSORS 2)
  277. add_test(TestLoad2 \"${CMAKE_COMMAND}\" -E echo \"test of --test-load\")
  278. set_tests_properties(TestLoad2 PROPERTIES PROCESSORS 2)
  279. ")
  280. run_cmake_command(${name} ${CMAKE_CTEST_COMMAND} -VV -j8 --test-load ${load})
  281. endfunction()
  282. # Tests for the --test-load feature of ctest
  283. #
  284. # Spoof a load average value to make these tests more reliable.
  285. set(ENV{__CTEST_FAKE_LOAD_AVERAGE_FOR_TESTING} 7)
  286. # Verify that new tests are not started when the load average exceeds
  287. # our threshold and that they then run once the load average drops.
  288. run_TestLoad(test-load-wait0 5)
  289. run_TestLoad(test-load-wait1 8)
  290. # Verify that warning message is displayed but tests still start when
  291. # an invalid argument is given.
  292. run_TestLoad(test-load-invalid 'two')
  293. # Verify that new tests are started when the load average falls below
  294. # our threshold.
  295. run_TestLoad(test-load-pass 12)
  296. unset(ENV{__CTEST_FAKE_LOAD_AVERAGE_FOR_TESTING})
  297. function(run_TestOutputSize)
  298. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TestOutputSize)
  299. set(RunCMake_TEST_NO_CLEAN 1)
  300. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  301. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  302. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  303. add_test(PassingTest \"${CMAKE_COMMAND}\" -E echo PassingTestOutput)
  304. add_test(FailingTest \"${CMAKE_COMMAND}\" -E no_such_command)
  305. ")
  306. run_cmake_command(TestOutputSize
  307. ${CMAKE_CTEST_COMMAND} -M Experimental -T Test
  308. --no-compress-output
  309. --test-output-size-passed 10
  310. --test-output-size-failed 12
  311. )
  312. endfunction()
  313. run_TestOutputSize()
  314. # Test --test-output-truncation
  315. function(run_TestOutputTruncation mode expected)
  316. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TestOutputTruncation_${mode})
  317. set(RunCMake_TEST_NO_CLEAN 1)
  318. set(TRUNCATED_OUTPUT ${expected}) # used in TestOutputTruncation-check.cmake
  319. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  320. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  321. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  322. add_test(Truncation_${mode} \"${CMAKE_COMMAND}\" -E echo 123456789)
  323. ")
  324. run_cmake_command(TestOutputTruncation_${mode}
  325. ${CMAKE_CTEST_COMMAND} -M Experimental -T Test
  326. --no-compress-output
  327. --test-output-size-passed 5
  328. --test-output-truncation ${mode}
  329. )
  330. endfunction()
  331. run_TestOutputTruncation("head" "\\.\\.\\.6789")
  332. run_TestOutputTruncation("middle" "12\\.\\.\\..*\\.\\.\\.89")
  333. run_TestOutputTruncation("tail" "12345\\.\\.\\.")
  334. run_TestOutputTruncation("bad" "")
  335. # Test --stop-on-failure
  336. function(run_stop_on_failure)
  337. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/stop-on-failure)
  338. set(RunCMake_TEST_NO_CLEAN 1)
  339. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  340. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  341. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  342. add_test(test1 \"${CMAKE_COMMAND}\" -E false)
  343. add_test(test2 \"${CMAKE_COMMAND}\" -E echo \"not running\")
  344. ")
  345. run_cmake_command(stop-on-failure ${CMAKE_CTEST_COMMAND} --stop-on-failure)
  346. endfunction()
  347. run_stop_on_failure()
  348. function(run_TestAffinity)
  349. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TestAffinity)
  350. set(RunCMake_TEST_NO_CLEAN 1)
  351. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  352. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  353. # Create a test with affinity enabled. The default PROCESSORS
  354. # value is 1, so our expected output checks that this is the
  355. # number of processors in the mask.
  356. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  357. add_test(Affinity \"${TEST_AFFINITY}\")
  358. set_tests_properties(Affinity PROPERTIES PROCESSOR_AFFINITY ON)
  359. ")
  360. # Run ctest with a large parallel level so that the value is
  361. # not responsible for capping the number of processors available.
  362. run_cmake_command(TestAffinity ${CMAKE_CTEST_COMMAND} -V -j 64)
  363. endfunction()
  364. if(TEST_AFFINITY)
  365. run_TestAffinity()
  366. endif()
  367. function(run_TestStdin)
  368. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TestStdin)
  369. set(RunCMake_TEST_NO_CLEAN 1)
  370. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  371. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  372. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  373. add_test(TestStdin \"${TEST_PRINT_STDIN}\")
  374. ")
  375. run_cmake_command(TestStdin ${CMAKE_CTEST_COMMAND} -V)
  376. endfunction()
  377. run_TestStdin()
  378. function(show_only_json_check_python v)
  379. if(RunCMake_TEST_FAILED OR NOT Python_EXECUTABLE)
  380. return()
  381. endif()
  382. set(json_file "${RunCMake_TEST_BINARY_DIR}/ctest.json")
  383. file(WRITE "${json_file}" "${actual_stdout}")
  384. set(actual_stdout "" PARENT_SCOPE)
  385. execute_process(
  386. COMMAND ${Python_EXECUTABLE} "${RunCMake_SOURCE_DIR}/show-only_json-v${v}_check.py" "${json_file}"
  387. RESULT_VARIABLE result
  388. OUTPUT_VARIABLE output
  389. ERROR_VARIABLE output
  390. )
  391. if(NOT result EQUAL 0)
  392. string(REPLACE "\n" "\n " output " ${output}")
  393. set(RunCMake_TEST_FAILED "Unexpected output:\n${output}" PARENT_SCOPE)
  394. endif()
  395. endfunction()
  396. function(run_ShowOnly)
  397. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/ShowOnly)
  398. set(RunCMake_TEST_NO_CLEAN 1)
  399. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  400. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  401. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  402. add_test(ShowOnly \"${CMAKE_COMMAND}\" -E echo)
  403. set_tests_properties(ShowOnly PROPERTIES
  404. WILL_FAIL true
  405. RESOURCE_GROUPS \"2,threads:2,gpus:4;gpus:2,threads:4\"
  406. REQUIRED_FILES RequiredFileDoesNotExist
  407. _BACKTRACE_TRIPLES \"file1;1;add_test;file0;;\"
  408. USER_DEFINED_A \"User defined property A value\"
  409. USER_DEFINED_B \"User defined property B value\"
  410. )
  411. add_test(ShowOnlyNotAvailable NOT_AVAILABLE)
  412. ")
  413. run_cmake_command(show-only_human ${CMAKE_CTEST_COMMAND} --show-only=human)
  414. run_cmake_command(show-only_bad ${CMAKE_CTEST_COMMAND} --show-only=bad)
  415. run_cmake_command(show-only_json-v1 ${CMAKE_CTEST_COMMAND} --show-only=json-v1)
  416. endfunction()
  417. run_ShowOnly()
  418. function(run_NoTests)
  419. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/NoTests)
  420. set(RunCMake_TEST_NO_CLEAN 1)
  421. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  422. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  423. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "")
  424. run_cmake_command(no-tests_ignore ${CMAKE_CTEST_COMMAND} --no-tests=ignore)
  425. run_cmake_command(no-tests_error ${CMAKE_CTEST_COMMAND} --no-tests=error)
  426. run_cmake_command(no-tests_bad ${CMAKE_CTEST_COMMAND} --no-tests=bad)
  427. run_cmake_command(no-tests_legacy ${CMAKE_CTEST_COMMAND})
  428. run_cmake_command(no-tests_env_ignore ${CMAKE_COMMAND} -E env CTEST_NO_TESTS_ACTION=ignore ${CMAKE_CTEST_COMMAND})
  429. run_cmake_command(no-tests_env_error ${CMAKE_COMMAND} -E env CTEST_NO_TESTS_ACTION=error ${CMAKE_CTEST_COMMAND})
  430. run_cmake_command(no-tests_env_bad ${CMAKE_COMMAND} -E env CTEST_NO_TESTS_ACTION=bad ${CMAKE_CTEST_COMMAND})
  431. run_cmake_command(no-tests_env_empty_legacy ${CMAKE_COMMAND} -E env CTEST_NO_TESTS_ACTION= ${CMAKE_CTEST_COMMAND})
  432. run_cmake_command(no-tests_env_bad_with_cli_error ${CMAKE_COMMAND} -E env CTEST_NO_TESTS_ACTION=bad ${CMAKE_CTEST_COMMAND} --no-tests=error)
  433. file(WRITE "${RunCMake_TEST_BINARY_DIR}/NoTestsScript.cmake" "
  434. set(CTEST_COMMAND \"${CMAKE_CTEST_COMMAND}\")
  435. set(CTEST_SOURCE_DIRECTORY \"${RunCMake_SOURCE_DIR}\")
  436. set(CTEST_BINARY_DIRECTORY \"${RunCMake_TEST_BINARY_DIR}\")
  437. ctest_start(Experimental)
  438. ctest_test()
  439. ")
  440. run_cmake_command(
  441. no-tests-script_ignore ${CMAKE_CTEST_COMMAND} --no-tests=ignore
  442. -S "${RunCMake_TEST_BINARY_DIR}/NoTestsScript.cmake")
  443. run_cmake_command(
  444. no-tests-script_error ${CMAKE_CTEST_COMMAND} --no-tests=error
  445. -S "${RunCMake_TEST_BINARY_DIR}/NoTestsScript.cmake")
  446. run_cmake_command(
  447. no-tests-script_legacy ${CMAKE_CTEST_COMMAND}
  448. -S "${RunCMake_TEST_BINARY_DIR}/NoTestsScript.cmake")
  449. endfunction()
  450. run_NoTests()
  451. # Check the configuration type variable is passed
  452. run_ctest(check-configuration-type)
  453. function(run_FailDrop case)
  454. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/FailDrop-${case}-build)
  455. run_cmake_with_options(FailDrop-${case} ${ARGN})
  456. unset(ENV{CMAKE_TLS_VERIFY}) # Test that env variable is saved in ctest config file.
  457. unset(ENV{CMAKE_TLS_VERSION}) # Test that env variable is saved in ctest config file.
  458. set(RunCMake_TEST_NO_CLEAN 1)
  459. run_cmake_command(FailDrop-${case}-ctest
  460. ${CMAKE_CTEST_COMMAND} -M Experimental -T Submit -VV
  461. )
  462. endfunction()
  463. run_FailDrop(TLSVersion-1.1 -DCTEST_TLS_VERSION=1.1)
  464. run_FailDrop(TLSVersion-1.1-cmake -DCMAKE_TLS_VERSION=1.1) # Test fallback to CMake variable.
  465. set(ENV{CMAKE_TLS_VERSION} 1.1) # Test fallback to env variable.
  466. run_FailDrop(TLSVersion-1.1-env)
  467. unset(ENV{CMAKE_TLS_VERSION})
  468. run_FailDrop(TLSVerify-ON -DCTEST_TLS_VERIFY=ON)
  469. run_FailDrop(TLSVerify-ON-cmake -DCMAKE_TLS_VERIFY=ON) # Test fallback to CMake variable.
  470. set(ENV{CMAKE_TLS_VERIFY} 1) # Test fallback to env variable.
  471. run_FailDrop(TLSVerify-ON-env)
  472. unset(ENV{CMAKE_TLS_VERIFY})
  473. run_FailDrop(TLSVerify-OFF -DCTEST_TLS_VERIFY=OFF)
  474. run_FailDrop(TLSVerify-OFF-cmake -DCMAKE_TLS_VERIFY=OFF) # Test fallback to CMake variable.
  475. set(ENV{CMAKE_TLS_VERIFY} 0) # Test fallback to env variable.
  476. run_FailDrop(TLSVerify-OFF-env)
  477. unset(ENV{CMAKE_TLS_VERIFY})
  478. run_cmake_command(EmptyDirCoverage-ctest
  479. ${CMAKE_CTEST_COMMAND} -C Debug -M Experimental -T Coverage
  480. )
  481. function(run_MemCheckSan case opts)
  482. # Use a single build tree for a few tests without cleaning.
  483. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/MemCheckSan${case}-build)
  484. set(RunCMake_TEST_OPTIONS
  485. "-DMEMORYCHECK_TYPE=${case}Sanitizer"
  486. "-DMEMORYCHECK_SANITIZER_OPTIONS=${opts}"
  487. )
  488. run_cmake(MemCheckSan)
  489. unset(RunCMake_TEST_OPTIONS)
  490. set(RunCMake_TEST_NO_CLEAN 1)
  491. set(RunCMake-stdout-file "../ctest_memcheck/Dummy${case}Sanitizer-stdout.txt")
  492. run_cmake_command(MemCheckSan${case}-ctest
  493. ${CMAKE_CTEST_COMMAND} -C Debug -M Experimental -T MemCheck -V
  494. )
  495. endfunction()
  496. run_MemCheckSan(Address "simulate_sanitizer=1:report_bugs=1:history_size=5:exitcode=55")
  497. run_MemCheckSan(Leak "simulate_sanitizer=1:report_bugs=1:history_size=5:exitcode=55")
  498. run_MemCheckSan(Memory "simulate_sanitizer=1:report_bugs=1:history_size=5:exitcode=55")
  499. run_MemCheckSan(Thread "report_bugs=1:history_size=5:exitcode=55")
  500. run_MemCheckSan(UndefinedBehavior "simulate_sanitizer=1")
  501. run_cmake_command(test-dir-invalid-arg ${CMAKE_CTEST_COMMAND} --test-dir)
  502. run_cmake_command(test-dir-non-existing-dir ${CMAKE_CTEST_COMMAND} --test-dir non-existing-dir)
  503. function(run_testDir testName testPreset)
  504. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/testDir)
  505. set(RunCMake_TEST_NO_CLEAN 1)
  506. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  507. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  508. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}/sub")
  509. file(WRITE "${RunCMake_TEST_BINARY_DIR}/sub/CTestTestfile.cmake" "
  510. add_test(Test1 \"${CMAKE_COMMAND}\" -E true)
  511. add_test(Test2 \"${CMAKE_COMMAND}\" -E true)
  512. ")
  513. if (testPreset)
  514. set(presetCommandLine --preset=default)
  515. configure_file(
  516. ${RunCMake_SOURCE_DIR}/testDir-presets.json.in
  517. ${RunCMake_TEST_BINARY_DIR}/CMakePresets.json)
  518. endif()
  519. run_cmake_command(${testName} ${CMAKE_CTEST_COMMAND} --test-dir "${RunCMake_TEST_BINARY_DIR}/sub" ${presetCommandLine})
  520. endfunction()
  521. run_testDir(testDir 0)
  522. run_testDir(testDir-preset 1)
  523. # Test --output-junit
  524. function(run_output_junit)
  525. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/output-junit)
  526. set(RunCMake_TEST_NO_CLEAN 1)
  527. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  528. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  529. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  530. add_test(test1 \"${CMAKE_COMMAND}\" -E false)
  531. add_test(test2 \"${CMAKE_COMMAND}\" -E echo \"hello world\")
  532. add_test(test3 \"${CMAKE_COMMAND}\" -E true)
  533. set_tests_properties(test3 PROPERTIES DISABLED \"ON\")
  534. add_test(test4 \"${CMAKE_CURRENT_SOURCE_DIR}/does_not_exist\")
  535. add_test(test5 \"${CMAKE_COMMAND}\" -E echo \"please skip\")
  536. set_tests_properties(test5 PROPERTIES SKIP_REGULAR_EXPRESSION \"please skip\")
  537. ")
  538. run_cmake_command(output-junit ${CMAKE_CTEST_COMMAND} --output-junit "${RunCMake_TEST_BINARY_DIR}/junit.xml")
  539. endfunction()
  540. run_output_junit()
  541. run_cmake_command(invalid-ctest-argument ${CMAKE_CTEST_COMMAND} --not-a-valid-ctest-argument)
  542. if(WIN32)
  543. block()
  544. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TimeoutSignalWindows)
  545. set(RunCMake_TEST_NO_CLEAN 1)
  546. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  547. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  548. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  549. add_test(test1 \"${CMAKE_COMMAND}\" -E true)
  550. set_tests_properties(test1 PROPERTIES TIMEOUT_SIGNAL_NAME SIGUSR1)
  551. set_tests_properties(test1 PROPERTIES TIMEOUT_SIGNAL_GRACE_PERIOD 1)
  552. ")
  553. run_cmake_command(TimeoutSignalWindows ${CMAKE_CTEST_COMMAND})
  554. endblock()
  555. else()
  556. block()
  557. set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/TimeoutSignalBad)
  558. set(RunCMake_TEST_NO_CLEAN 1)
  559. file(REMOVE_RECURSE "${RunCMake_TEST_BINARY_DIR}")
  560. file(MAKE_DIRECTORY "${RunCMake_TEST_BINARY_DIR}")
  561. file(WRITE "${RunCMake_TEST_BINARY_DIR}/CTestTestfile.cmake" "
  562. add_test(test1 \"${CMAKE_COMMAND}\" -E true)
  563. set_tests_properties(test1 PROPERTIES TIMEOUT_SIGNAL_NAME NOTASIG)
  564. set_tests_properties(test1 PROPERTIES TIMEOUT_SIGNAL_GRACE_PERIOD 0)
  565. set_tests_properties(test1 PROPERTIES TIMEOUT_SIGNAL_GRACE_PERIOD 1000)
  566. ")
  567. run_cmake_command(TimeoutSignalBad ${CMAKE_CTEST_COMMAND})
  568. endblock()
  569. endif()