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:
commit
ae57fb8ef6
|
@ -22,6 +22,7 @@
|
|||
|
||||
//#include <cmsys/RegularExpression.hxx>
|
||||
#include <cmsys/Process.h>
|
||||
#include <cmsys/Directory.hxx>
|
||||
|
||||
// used for sleep
|
||||
#ifdef _WIN32
|
||||
|
@ -1056,15 +1057,71 @@ bool cmCTestScriptHandler::EmptyBinaryDirectory(const char *sname)
|
|||
return false;
|
||||
}
|
||||
|
||||
// consider non existing target directory a success
|
||||
if(!cmSystemTools::FileExists(sname))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
// try to avoid deleting directories that we shouldn't
|
||||
std::string check = sname;
|
||||
check += "/CMakeCache.txt";
|
||||
if(cmSystemTools::FileExists(check.c_str()) &&
|
||||
!cmSystemTools::RemoveADirectory(sname))
|
||||
|
||||
if(!cmSystemTools::FileExists(check.c_str()))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
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());
|
||||
}
|
||||
|
||||
//-------------------------------------------------------------------------
|
||||
|
|
|
@ -135,6 +135,9 @@ private:
|
|||
// Add ctest 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<bool> ScriptProcessScope;
|
||||
|
||||
|
|
|
@ -1942,6 +1942,17 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=master -P ${CMake_SOURCE_DIR}/Utilities/
|
|||
set_tests_properties(CTestTestUpload PROPERTIES
|
||||
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(
|
||||
"${CMake_SOURCE_DIR}/Tests/CTestTestConfigFileInBuildDir/test1.cmake.in"
|
||||
"${CMake_BINARY_DIR}/Tests/CTestTestConfigFileInBuildDir1/test1.cmake"
|
||||
|
|
|
@ -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")
|
Loading…
Reference in New Issue