We teach CTest to report in a <Revision> element the revision of the source tree that was tested. This makes sense for all modern VCS tools because they version the whole tree. We simply omit this element for CVS because it only versions files. See issue #7541.
159 lines
4.7 KiB
CMake
159 lines
4.7 KiB
CMake
# This script drives creation of a CVS repository and checks
|
|
# that CTest can update from it.
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Test in a directory next to this script.
|
|
get_filename_component(TOP "${CMAKE_CURRENT_LIST_FILE}" PATH)
|
|
set(TOP "${TOP}/@CTestUpdateCVS_DIR@")
|
|
set(UPDATE_NOT_GLOBAL 1)
|
|
|
|
# Include code common to all update tests.
|
|
include("@CMAKE_CURRENT_SOURCE_DIR@/CTestUpdateCommon.cmake")
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Report CVS tools in use.
|
|
message("Using CVS tools:")
|
|
set(CVS "@CVS_EXECUTABLE@")
|
|
message(" cvs = ${CVS}")
|
|
|
|
set(REPO ${TOP}/repo)
|
|
set(CVSCMD ${CVS} -d${REPO})
|
|
|
|
# CVSNT requires an extra option to 'cvs init'.
|
|
set(CVS_INIT_OPT)
|
|
execute_process(
|
|
COMMAND ${CVS} --version
|
|
RESULT_VARIABLE RESULT
|
|
OUTPUT_VARIABLE OUTPUT
|
|
ERROR_VARIABLE OUTPUT
|
|
)
|
|
if("${RESULT}" STREQUAL "0" AND "${OUTPUT}" MATCHES "\\(CVSNT\\)")
|
|
set(CVS_INIT_OPT -n)
|
|
message(" cvs init needs -n")
|
|
endif()
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Initialize the testing directory.
|
|
message("Creating test directory...")
|
|
init_testing()
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Create the repository.
|
|
message("Creating repository...")
|
|
file(MAKE_DIRECTORY ${TOP}/repo)
|
|
run_child(
|
|
COMMAND ${CVSCMD} init ${CVS_INIT_OPT}
|
|
)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Import initial content into the repository.
|
|
message("Importing content...")
|
|
create_content(import)
|
|
|
|
# Import the content into the repository.
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/import
|
|
COMMAND ${CVSCMD} import -m "Initial content" Project vendor-tag release-tag
|
|
)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Create a working tree.
|
|
message("Checking out revision 1...")
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}
|
|
COMMAND ${CVSCMD} co -d user-source Project
|
|
)
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} tag Revision1
|
|
)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Make changes in the working tree.
|
|
message("Changing content...")
|
|
update_content(user-source files_added files_removed dirs_added)
|
|
if(dirs_added)
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} add ${dirs_added}
|
|
)
|
|
endif(dirs_added)
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} add ${files_added}
|
|
)
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} rm ${files_removed}
|
|
)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Commit the changes to the repository.
|
|
message("Committing revision 2...")
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} commit -m "Changed content"
|
|
)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Make changes in the working tree.
|
|
message("Changing content again...")
|
|
change_content(user-source)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Commit the changes to the repository.
|
|
message("Committing revision 3...")
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} commit -m "Changed content again"
|
|
)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Go back to before the changes so we can test updating.
|
|
message("Backing up to revision 1...")
|
|
run_child(
|
|
WORKING_DIRECTORY ${TOP}/user-source
|
|
COMMAND ${CVSCMD} up -rRevision1
|
|
)
|
|
|
|
# Delay 1 second so the modification produces a newer time stamp.
|
|
find_program(SLEEP sleep)
|
|
if(SLEEP)
|
|
message("Delaying...")
|
|
execute_process(COMMAND ${SLEEP} 1)
|
|
endif()
|
|
|
|
# Create a modified file.
|
|
message("Modifying locally...")
|
|
modify_content(user-source)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Test updating the user work directory with the command-line interface.
|
|
message("Running CTest Dashboard Command Line...")
|
|
|
|
# Create the user build tree.
|
|
create_build_tree(user-source user-binary)
|
|
file(APPEND ${TOP}/user-binary/CTestConfiguration.ini
|
|
"# CVS command configuration
|
|
CVSCommand: ${CVS}
|
|
CVSUpdateOptions: -dAP
|
|
")
|
|
|
|
# Run the dashboard command line interface.
|
|
run_dashboard_command_line(user-binary)
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Test initial checkout and update with a dashboard script.
|
|
message("Running CTest Dashboard Script...")
|
|
|
|
create_dashboard_script(dashboard.cmake
|
|
"# CVS command configuration
|
|
set(CTEST_CVS_COMMAND \"${CVS}\")
|
|
set(CTEST_CVS_UPDATE_OPTIONS -dAP)
|
|
set(CTEST_CHECKOUT_COMMAND
|
|
\"\\\"\${CTEST_CVS_COMMAND}\\\" -d \\\"${REPO}\\\" co -rRevision1 -d dash-source Project\")
|
|
")
|
|
|
|
# Run the dashboard script with CTest.
|
|
run_dashboard_script(dashboard.cmake)
|