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/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());
|
||||||
}
|
}
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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