Merge topic 'robust-ctest_empty_binary_directory'

35fbc10 CTest: more aggressive implementation of ctest_empty_binary_directory()
9d9f102 Tests: added test for ctest_empty_binary_directory()
This commit is contained in:
Brad King 2013-11-04 07:53:47 -05:00 committed by CMake Topic Stage
commit ae57fb8ef6
4 changed files with 140 additions and 3 deletions

View File

@ -22,6 +22,7 @@
//#include <cmsys/RegularExpression.hxx> //#include <cmsys/RegularExpression.hxx>
#include <cmsys/Process.h> #include <cmsys/Process.h>
#include <cmsys/Directory.hxx>
// used for sleep // used for sleep
#ifdef _WIN32 #ifdef _WIN32
@ -1056,15 +1057,71 @@ bool cmCTestScriptHandler::EmptyBinaryDirectory(const char *sname)
return false; return false;
} }
// consider non existing target directory a success
if(!cmSystemTools::FileExists(sname))
{
return true;
}
// try to avoid deleting directories that we shouldn't // try to avoid deleting directories that we shouldn't
std::string check = sname; std::string check = sname;
check += "/CMakeCache.txt"; check += "/CMakeCache.txt";
if(cmSystemTools::FileExists(check.c_str()) &&
!cmSystemTools::RemoveADirectory(sname)) if(!cmSystemTools::FileExists(check.c_str()))
{ {
return false; return false;
} }
return true;
for(int i = 0; i < 5; ++i)
{
if(TryToRemoveBinaryDirectoryOnce(sname))
{
return true;
}
cmSystemTools::Delay(100);
}
return false;
}
//-------------------------------------------------------------------------
bool cmCTestScriptHandler::TryToRemoveBinaryDirectoryOnce(
const std::string& directoryPath)
{
cmsys::Directory directory;
directory.Load(directoryPath.c_str());
for(unsigned long i = 0; i < directory.GetNumberOfFiles(); ++i)
{
std::string path = directory.GetFile(i);
if(path == "." || path == ".." || path == "CMakeCache.txt")
{
continue;
}
std::string fullPath = directoryPath + std::string("/") + path;
bool isDirectory = cmSystemTools::FileIsDirectory(fullPath.c_str()) &&
!cmSystemTools::FileIsSymlink(fullPath.c_str());
if(isDirectory)
{
if(!cmSystemTools::RemoveADirectory(fullPath.c_str()))
{
return false;
}
}
else
{
if(!cmSystemTools::RemoveFile(fullPath.c_str()))
{
return false;
}
}
}
return cmSystemTools::RemoveADirectory(directoryPath.c_str());
} }
//------------------------------------------------------------------------- //-------------------------------------------------------------------------

View File

@ -135,6 +135,9 @@ private:
// Add ctest command // Add ctest command
void AddCTestCommand(cmCTestCommand* command); void AddCTestCommand(cmCTestCommand* command);
// Try to remove the binary directory once
static bool TryToRemoveBinaryDirectoryOnce(const std::string& directoryPath);
std::vector<cmStdString> ConfigurationScripts; std::vector<cmStdString> ConfigurationScripts;
std::vector<bool> ScriptProcessScope; std::vector<bool> ScriptProcessScope;

View File

@ -1942,6 +1942,17 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=master -P ${CMake_SOURCE_DIR}/Utilities/
set_tests_properties(CTestTestUpload PROPERTIES set_tests_properties(CTestTestUpload PROPERTIES
PASS_REGULAR_EXPRESSION "Upload\\.xml") PASS_REGULAR_EXPRESSION "Upload\\.xml")
configure_file(
"${CMake_SOURCE_DIR}/Tests/CTestTestEmptyBinaryDirectory/test.cmake.in"
"${CMake_BINARY_DIR}/Tests/CTestTestEmptyBinaryDirectory/test.cmake"
@ONLY ESCAPE_QUOTES)
add_test(CTestTestEmptyBinaryDirectory ${CMAKE_CTEST_COMMAND}
-S "${CMake_BINARY_DIR}/Tests/CTestTestEmptyBinaryDirectory/test.cmake" -V
--output-log "${CMake_BINARY_DIR}/Tests/CTestTestEmptyBinaryDirectory/testOut.log"
)
set_tests_properties(CTestTestEmptyBinaryDirectory PROPERTIES
PASS_REGULAR_EXPRESSION "TEST_SUCCESS")
configure_file( configure_file(
"${CMake_SOURCE_DIR}/Tests/CTestTestConfigFileInBuildDir/test1.cmake.in" "${CMake_SOURCE_DIR}/Tests/CTestTestConfigFileInBuildDir/test1.cmake.in"
"${CMake_BINARY_DIR}/Tests/CTestTestConfigFileInBuildDir1/test1.cmake" "${CMake_BINARY_DIR}/Tests/CTestTestConfigFileInBuildDir1/test1.cmake"

View File

@ -0,0 +1,66 @@
cmake_minimum_required(VERSION 2.8.12)
set(CTEST_RUN_CURRENT_SCRIPT 0)
set(CTEST_SOURCE_DIRECTORY "@CMake_SOURCE_DIR@/Tests/CTestTestEmptyBinaryDirectory")
set(CTEST_BINARY_DIRECTORY "@CMake_BINARY_DIR@/Tests/CTestTestEmptyBinaryDirectory")
# make sure ctest does not remove directories without a CMakeCache.txt in it
set(EMPTY_BINARY_DIR "${CTEST_BINARY_DIRECTORY}/empty_binary_dir")
file(MAKE_DIRECTORY "${EMPTY_BINARY_DIR}")
if(NOT EXISTS "${EMPTY_BINARY_DIR}"
OR EXISTS "${EMPTY_BINARY_DIR}/CMakeCache.txt")
message(FATAL_ERROR "empty_binary_dir precondition failed")
endif()
ctest_empty_binary_directory("${EMPTY_BINARY_DIR}")
if(NOT EXISTS "${EMPTY_BINARY_DIR}")
message(FATAL_ERROR "empty_binary_dir should not have been removed")
endif()
# make sure ctest does remove directories with a CMakeCache.txt
set(VALID_BINARY_DIR "${CTEST_BINARY_DIRECTORY}/valid_binary_dir")
file(MAKE_DIRECTORY "${VALID_BINARY_DIR}")
file(WRITE "${VALID_BINARY_DIR}/CMakeCache.txt")
if(NOT EXISTS "${VALID_BINARY_DIR}"
OR NOT EXISTS "${VALID_BINARY_DIR}/CMakeCache.txt")
message(FATAL_ERROR "valid_binary_dir precondition failed")
endif()
ctest_empty_binary_directory("${VALID_BINARY_DIR}")
if(EXISTS "${VALID_BINARY_DIR}")
message(FATAL_ERROR "valid_binary_dir should have been removed")
endif()
# make sure ctest removes build directories recursively
set(DEEP_BINARY_DIR "${CTEST_BINARY_DIRECTORY}/deep_binary_dir")
file(MAKE_DIRECTORY "${DEEP_BINARY_DIR}")
file(WRITE "${DEEP_BINARY_DIR}/CMakeCache.txt")
foreach(SUBDIR A Z A/A A/Z Z/A Z/Z)
set(FULL_SUBDIR "${DEEP_BINARY_DIR}/${SUBDIR}")
file(MAKE_DIRECTORY "${FULL_SUBDIR}")
foreach(SUBFILE A.cpp Z.bat)
set(FULL_SUBFILE "${FULL_SUBDIR}/${SUBFILE}")
file(WRITE "${FULL_SUBFILE}" "I am '${FULL_SUBFILE}'")
endforeach()
endforeach()
if(NOT EXISTS "${DEEP_BINARY_DIR}"
OR NOT EXISTS "${DEEP_BINARY_DIR}/CMakeCache.txt"
OR NOT EXISTS "${DEEP_BINARY_DIR}/Z/A/Z.bat")
message(FATAL_ERROR "deep_binary_dir precondition failed")
endif()
ctest_empty_binary_directory("${DEEP_BINARY_DIR}")
if(EXISTS "${DEEP_BINARY_DIR}")
message(FATAL_ERROR "deep_binary_dir should have been removed")
endif()
message("TEST_SUCCESS")