Browse Source

BUG: Additional fix necessary for issue #8481 so that Xcode builds do not write files into the source tree. Also add a test that runs last to check for local modifications in CMake_SOURCE_DIR based on whether 'cvs -q -n up -dP' output is empty. Test fails on dashboard runs when there are local modifications. Test passes on non-dashboard runs with local modifications so that CMake developers may have mods when running the test locally.

David Cole 16 years ago
parent
commit
5bea9620dc

+ 6 - 0
Source/cmGlobalXCodeGenerator.cxx

@@ -2714,11 +2714,17 @@ void cmGlobalXCodeGenerator
     buildSettings->AddAttribute("MACOSX_DEPLOYMENT_TARGET",
                                 this->CreateString(deploymentTarget));
     }
+
+  std::string symroot = root->GetMakefile()->GetCurrentOutputDirectory();
+  symroot += "/build";
+  buildSettings->AddAttribute("SYMROOT", this->CreateString(symroot.c_str()));
+
   for( std::vector<cmXCodeObject*>::iterator i = configs.begin();
        i != configs.end(); ++i)
     {
     (*i)->AddAttribute("buildSettings", buildSettings);
     }
+
   this->RootObject->AddAttribute("buildConfigurationList", 
                              this->CreateObjectReference(configlist));
 

+ 27 - 6
Tests/CMakeLists.txt

@@ -37,6 +37,21 @@ IF(BUILD_TESTING)
     MARK_AS_ADVANCED(CTEST_TEST_CTEST)
   ENDIF (CMAKE_RUN_LONG_TESTS)
 
+  # Should tests that use CVS be run?
+  #
+  find_package(CVS)
+  set(do_cvs_tests 0)
+
+  if(CVS_EXECUTABLE)
+    set(do_cvs_tests 1)
+  endif()
+
+  if(do_cvs_tests AND NOT UNIX)
+    if("${CVS_EXECUTABLE}" MATCHES "cygwin")
+      set(do_cvs_tests 0)
+    endif()
+  endif()
+
   # Should CPack tests be run? By default, yes, but...
   #
   # Disable packaging test on Apple 10.3 and below. PackageMaker starts
@@ -947,9 +962,9 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=CVS -P ${CMake_SOURCE_DIR}/Utilities/Rel
     MARK_AS_ADVANCED(BZR_EXECUTABLE)
     SET(CTEST_TEST_UPDATE_BZR 0)
     IF(BZR_EXECUTABLE)
-      IF(NOT "${CVS_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
+      IF(NOT "${BZR_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
         SET(CTEST_TEST_UPDATE_BZR 1)
-      ENDIF(NOT "${CVS_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
+      ENDIF(NOT "${BZR_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
     ENDIF(BZR_EXECUTABLE)
     IF(CTEST_TEST_UPDATE_BZR)
       # Check if xmloutput plugin is there
@@ -979,9 +994,9 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=CVS -P ${CMake_SOURCE_DIR}/Utilities/Rel
     MARK_AS_ADVANCED(GIT_EXECUTABLE)
     SET(CTEST_TEST_UPDATE_GIT 0)
     IF(GIT_EXECUTABLE)
-      IF(NOT "${CVS_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
+      IF(NOT "${GIT_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
         SET(CTEST_TEST_UPDATE_GIT 1)
-      ENDIF(NOT "${CVS_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
+      ENDIF(NOT "${GIT_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
     ENDIF(GIT_EXECUTABLE)
     IF(CTEST_TEST_UPDATE_GIT)
       SET(CTestUpdateGIT_DIR "CTest UpdateGIT")
@@ -998,9 +1013,9 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=CVS -P ${CMake_SOURCE_DIR}/Utilities/Rel
     MARK_AS_ADVANCED(HG_EXECUTABLE)
     SET(CTEST_TEST_UPDATE_HG 0)
     IF(HG_EXECUTABLE)
-      IF(NOT "${CVS_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
+      IF(NOT "${HG_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
         SET(CTEST_TEST_UPDATE_HG 1)
-      ENDIF(NOT "${CVS_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
+      ENDIF(NOT "${HG_EXECUTABLE}" MATCHES "cygwin" OR UNIX)
     ENDIF(HG_EXECUTABLE)
     IF(CTEST_TEST_UPDATE_HG)
       SET(CTestUpdateHG_DIR "CTest UpdateHG")
@@ -1236,3 +1251,9 @@ ${CMake_BINARY_DIR}/bin/cmake -DVERSION=CVS -P ${CMake_SOURCE_DIR}/Utilities/Rel
 ENDIF(BUILD_TESTING)
 
 SUBDIRS(CMakeTests)
+
+if(BUILD_TESTING)
+  if(do_cvs_tests)
+    add_test(IsSourceTreeUnmodified ${CMAKE_CMAKE_COMMAND} -P "IsSourceTreeUnmodified.cmake")
+  endif(do_cvs_tests)
+endif(BUILD_TESTING)

+ 12 - 0
Tests/CMakeTests/CMakeLists.txt

@@ -25,3 +25,15 @@ SET(GetPrerequisites_PreArgs
   "-DCTEST_CONFIGURATION_TYPE:STRING=\\\${CTEST_CONFIGURATION_TYPE}"
   )
 AddCMakeTest(GetPrerequisites "${GetPrerequisites_PreArgs}")
+
+# Run CheckSourceTree as the very last test in the CMake/CTest/CPack test
+# suite. It detects if any changes have been made to the CMake source tree
+# by any previous configure, build or test steps.
+#
+if(do_cvs_tests)
+  set(CheckSourceTree_PreArgs
+    "-DCMake_SOURCE_DIR:PATH=${CMake_SOURCE_DIR}"
+    "-DCVS_EXECUTABLE:STRING=${CVS_EXECUTABLE}"
+    )
+  AddCMakeTest(CheckSourceTree "${CheckSourceTree_PreArgs}")
+endif()

+ 49 - 0
Tests/CMakeTests/CheckSourceTreeTest.cmake.in

@@ -0,0 +1,49 @@
+# Check the CMake source tree and report anything suspicious...
+#
+message(STATUS
+  "=============================================================================")
+message(STATUS "CTEST_FULL_OUTPUT (Avoid ctest truncation of output)")
+message(STATUS "")
+message(STATUS "CMake_SOURCE_DIR='${CMake_SOURCE_DIR}'")
+message(STATUS "CVS_EXECUTABLE='${CVS_EXECUTABLE}'")
+message(STATUS "ENV{DASHBOARD_TEST_FROM_CTEST}='$ENV{DASHBOARD_TEST_FROM_CTEST}'")
+message(STATUS "")
+
+
+# Check with "cvs -q -n up -dP" if there are any local modifications to the
+# CMake source tree:
+#
+message(STATUS
+  "=============================================================================")
+execute_process(COMMAND ${CVS_EXECUTABLE} -q -n up -dP
+  WORKING_DIRECTORY ${CMake_SOURCE_DIR}
+  OUTPUT_VARIABLE ov
+  ERROR_VARIABLE ev
+  RESULT_VARIABLE rv)
+
+set(modifications 0)
+if(NOT ov STREQUAL "")
+  set(modifications 1)
+endif()
+
+message(STATUS "Results of running '${CVS_EXECUTABLE} -q -n up -dP'")
+message(STATUS "rv='${rv}'")
+message(STATUS "ov='${ov}'")
+message(STATUS "ev='${ev}'")
+message(STATUS "modifications='${modifications}'")
+
+
+# Decide if the test passes or fails:
+#
+if("$ENV{DASHBOARD_TEST_FROM_CTEST}" STREQUAL "")
+  message(STATUS "non-dashboard interactive test run")
+    # developers are allowed to have local modifications... :-)
+else()
+  message(STATUS "dashboard test run")
+
+  if(modifications)
+    message(FATAL_ERROR "test fails: source tree modifications")
+  endif()
+endif()
+
+message(STATUS "test passes")