diff options
author | Zach Mullen <zach.mullen@kitware.com> | 2009-09-23 15:38:37 (GMT) |
---|---|---|
committer | Zach Mullen <zach.mullen@kitware.com> | 2009-09-23 15:38:37 (GMT) |
commit | f3dce87e6d508e7552bd378f98d22f82c2011516 (patch) | |
tree | 788e1550eef8d9c1f79a8164bf225047966201f2 | |
parent | 4e121af95eebcff0e203ce19994c0f20f02688c6 (diff) | |
download | CMake-f3dce87e6d508e7552bd378f98d22f82c2011516.zip CMake-f3dce87e6d508e7552bd378f98d22f82c2011516.tar.gz CMake-f3dce87e6d508e7552bd378f98d22f82c2011516.tar.bz2 |
Set new ctest tests to always run, whether CTEST_TEST_CTEST is enabled or not. Changed parallel test to be portable.
-rw-r--r-- | Tests/CMakeLists.txt | 90 | ||||
-rw-r--r-- | Tests/CTestTestParallel/CMakeLists.txt | 3 | ||||
-rw-r--r-- | Tests/CTestTestParallel/lockFile.c | 20 | ||||
-rw-r--r-- | Tests/CTestTestParallel/lockFile.cxx | 20 |
4 files changed, 66 insertions, 67 deletions
diff --git a/Tests/CMakeLists.txt b/Tests/CMakeLists.txt index 2420fc0..2c49de9 100644 --- a/Tests/CMakeLists.txt +++ b/Tests/CMakeLists.txt @@ -1030,6 +1030,51 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=CVS -P ${CMake_SOURCE_DIR}/Utilities/Rel ENDIF(CTEST_TEST_UPDATE_HG) ENDIF(CTEST_TEST_UPDATE) + CONFIGURE_FILE( + "${CMake_SOURCE_DIR}/Tests/CTestTestFailure/testNoBuild.cmake.in" + "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoBuild.cmake" + @ONLY ESCAPE_QUOTES) + ADD_TEST(CTestTestNoBuild ${CMAKE_CTEST_COMMAND} + -S "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoBuild.cmake" -V + --output-log "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testOut1.log" + ) + SET_TESTS_PROPERTIES(CTestTestNoBuild PROPERTIES + FAIL_REGULAR_EXPRESSION "Error" WILL_FAIL true) + + CONFIGURE_FILE( + "${CMake_SOURCE_DIR}/Tests/CTestTestFailure/testNoExe.cmake.in" + "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoExe.cmake" + @ONLY ESCAPE_QUOTES) + ADD_TEST(CTestTestNoExe ${CMAKE_CTEST_COMMAND} + -S "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoExe.cmake" -V + --output-log "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testOut2.log" + ) + SET_TESTS_PROPERTIES(CTestTestNoExe PROPERTIES #DEPENDS CTestTestNoBuild + PASS_REGULAR_EXPRESSION "Could not find executable" + FAIL_REGULAR_EXPRESSION "SegFault") + + CONFIGURE_FILE( + "${CMake_SOURCE_DIR}/Tests/CTestTestCrash/test.cmake.in" + "${CMake_BINARY_DIR}/Tests/CTestTestCrash/test.cmake" + @ONLY ESCAPE_QUOTES) + ADD_TEST(CTestTestCrash ${CMAKE_CTEST_COMMAND} + -S "${CMake_BINARY_DIR}/Tests/CTestTestCrash/test.cmake" -V + --output-log "${CMake_BINARY_DIR}/Tests/CTestTestCrash/testOutput.log" + ) + SET_TESTS_PROPERTIES(CTestTestCrash PROPERTIES + PASS_REGULAR_EXPRESSION "SegFault") + + CONFIGURE_FILE( + "${CMake_SOURCE_DIR}/Tests/CTestTestParallel/test.cmake.in" + "${CMake_BINARY_DIR}/Tests/CTestTestParallel/test.cmake" + @ONLY ESCAPE_QUOTES) + ADD_TEST(CTestTestParallel ${CMAKE_CTEST_COMMAND} + -S "${CMake_BINARY_DIR}/Tests/CTestTestParallel/test.cmake" -V + --output-log "${CMake_BINARY_DIR}/Tests/CTestTestParallel/testOutput.log" + ) + ADD_TEST(CTestTestShowOnly ${CMAKE_CTEST_COMMAND} + -N + ) IF (CTEST_TEST_CTEST AND CMAKE_RUN_LONG_TESTS) CONFIGURE_FILE("${CMake_SOURCE_DIR}/Tests/CTestTest/test.cmake.in" "${CMake_BINARY_DIR}/Tests/CTestTest/test.cmake" @ONLY ESCAPE_QUOTES) @@ -1050,51 +1095,6 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=CVS -P ${CMake_SOURCE_DIR}/Utilities/Rel --output-log "${CMake_BINARY_DIR}/Tests/CTestTest3/testOutput.log" ) - CONFIGURE_FILE( - "${CMake_SOURCE_DIR}/Tests/CTestTestFailure/testNoBuild.cmake.in" - "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoBuild.cmake" - @ONLY ESCAPE_QUOTES) - ADD_TEST(CTestTestNoBuild ${CMAKE_CTEST_COMMAND} - -S "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoBuild.cmake" -V - --output-log "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testOut1.log" - ) - SET_TESTS_PROPERTIES(CTestTestNoBuild PROPERTIES - FAIL_REGULAR_EXPRESSION "Error" WILL_FAIL true) - - CONFIGURE_FILE( - "${CMake_SOURCE_DIR}/Tests/CTestTestFailure/testNoExe.cmake.in" - "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoExe.cmake" - @ONLY ESCAPE_QUOTES) - ADD_TEST(CTestTestNoExe ${CMAKE_CTEST_COMMAND} - -S "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testNoExe.cmake" -V - --output-log "${CMake_BINARY_DIR}/Tests/CTestTestFailure/testOut2.log" - ) - SET_TESTS_PROPERTIES(CTestTestNoExe PROPERTIES #DEPENDS CTestTestNoBuild - PASS_REGULAR_EXPRESSION "Could not find executable" - FAIL_REGULAR_EXPRESSION "SegFault") - - CONFIGURE_FILE( - "${CMake_SOURCE_DIR}/Tests/CTestTestCrash/test.cmake.in" - "${CMake_BINARY_DIR}/Tests/CTestTestCrash/test.cmake" - @ONLY ESCAPE_QUOTES) - ADD_TEST(CTestTestCrash ${CMAKE_CTEST_COMMAND} - -S "${CMake_BINARY_DIR}/Tests/CTestTestCrash/test.cmake" -V - --output-log "${CMake_BINARY_DIR}/Tests/CTestTestCrash/testOutput.log" - ) - SET_TESTS_PROPERTIES(CTestTestCrash PROPERTIES - PASS_REGULAR_EXPRESSION "SegFault") - - CONFIGURE_FILE( - "${CMake_SOURCE_DIR}/Tests/CTestTestParallel/test.cmake.in" - "${CMake_BINARY_DIR}/Tests/CTestTestParallel/test.cmake" - @ONLY ESCAPE_QUOTES) - ADD_TEST(CTestTestParallel ${CMAKE_CTEST_COMMAND} - -S "${CMake_BINARY_DIR}/Tests/CTestTestParallel/test.cmake" -V - --output-log "${CMake_BINARY_DIR}/Tests/CTestTestParallel/testOutput.log" - ) - ADD_TEST(CTestTestShowOnly ${CMAKE_CTEST_COMMAND} - -N - ) # these tests take a long time, make sure they have it # if timeouts have not already been set GET_TEST_PROPERTY(CTestTest TIMEOUT PREVIOUS_TIMEOUT) diff --git a/Tests/CTestTestParallel/CMakeLists.txt b/Tests/CTestTestParallel/CMakeLists.txt index b6d31b3..1e57074 100644 --- a/Tests/CTestTestParallel/CMakeLists.txt +++ b/Tests/CTestTestParallel/CMakeLists.txt @@ -8,8 +8,7 @@ INCLUDE (${CMAKE_ROOT}/Modules/Dart.cmake) GET_FILENAME_COMPONENT(CTEST_COMMAND "${CMAKE_COMMAND}" PATH) SET(CTEST_COMMAND "${CTEST_COMMAND}/ctest") -ADD_EXECUTABLE (LockFile lockFile.cxx) -TARGET_LINK_LIBRARIES (NoBuild ${EXTRA_LIBS}) +ADD_EXECUTABLE (LockFile lockFile.c) ENABLE_TESTING () diff --git a/Tests/CTestTestParallel/lockFile.c b/Tests/CTestTestParallel/lockFile.c new file mode 100644 index 0000000..7942b72 --- /dev/null +++ b/Tests/CTestTestParallel/lockFile.c @@ -0,0 +1,20 @@ +#include <stdio.h> + +//if run serially, works fine +//if run in parallel, someone will attempt to delete +//a locked file, which will fail +int main() +{ + FILE* file; + int i; + const char* fname = "lockedFile.txt"; + file = fopen(fname, "w"); + + for(i = 0; i < 10000; i++) + { + fprintf(file, "%s", "x"); + fflush(file); + } + fclose(file); + return remove(fname); +} diff --git a/Tests/CTestTestParallel/lockFile.cxx b/Tests/CTestTestParallel/lockFile.cxx deleted file mode 100644 index e46d0fd..0000000 --- a/Tests/CTestTestParallel/lockFile.cxx +++ /dev/null @@ -1,20 +0,0 @@ -#include <iostream> -#include <fstream> - -//if run serially, works fine -//if run in parallel, someone will attempt to delete -//a locked file, which will fail -int main() -{ - std::string fname = "lockedFile.txt"; - std::fstream fout; - fout.open(fname.c_str(), std::ios::out); - - for(int i = 0; i < 10000; i++) - { - fout << "x"; - fout.flush(); - } - fout.close(); - return std::remove("lockedFile.txt"); -} |