Merge topic 'cleanup-early-include-CTest-failure'
d90f49b
CTest: Fail early without PROJECT_BINARY_DIR (#14005)2e1c2bd
build_command: Fail early without CMAKE_MAKE_PROGRAM (#14005)4e5cb37
Refactor RunCMake.build_command test to allow more cases
This commit is contained in:
commit
8128940ac1
|
@ -16,6 +16,10 @@ if(NOT RUN_FROM_CTEST_OR_DART)
|
||||||
message(FATAL_ERROR "Do not incldue CTestTargets.cmake directly")
|
message(FATAL_ERROR "Do not incldue CTestTargets.cmake directly")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(NOT PROJECT_BINARY_DIR)
|
||||||
|
message(FATAL_ERROR "Do not include(CTest) before calling project().")
|
||||||
|
endif()
|
||||||
|
|
||||||
# make directories in the binary tree
|
# make directories in the binary tree
|
||||||
file(MAKE_DIRECTORY ${PROJECT_BINARY_DIR}/Testing/Temporary)
|
file(MAKE_DIRECTORY ${PROJECT_BINARY_DIR}/Testing/Temporary)
|
||||||
get_filename_component(CMAKE_HOST_PATH ${CMAKE_COMMAND} PATH)
|
get_filename_component(CMAKE_HOST_PATH ${CMAKE_COMMAND} PATH)
|
||||||
|
|
|
@ -87,6 +87,14 @@ bool cmBuildCommand
|
||||||
|
|
||||||
const char* makeprogram
|
const char* makeprogram
|
||||||
= this->Makefile->GetDefinition("CMAKE_MAKE_PROGRAM");
|
= this->Makefile->GetDefinition("CMAKE_MAKE_PROGRAM");
|
||||||
|
if(!makeprogram)
|
||||||
|
{
|
||||||
|
this->Makefile->IssueMessage(
|
||||||
|
cmake::FATAL_ERROR,
|
||||||
|
"build_command() requires CMAKE_MAKE_PROGRAM to be defined. "
|
||||||
|
"Call project() or enable_language() first.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// If null/empty CONFIGURATION argument, GenerateBuildCommand uses 'Debug'
|
// If null/empty CONFIGURATION argument, GenerateBuildCommand uses 'Debug'
|
||||||
// in the currently implemented multi-configuration global generators...
|
// in the currently implemented multi-configuration global generators...
|
||||||
|
|
|
@ -52,6 +52,7 @@ if(XCODE_VERSION AND "${XCODE_VERSION}" VERSION_LESS 3)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_RunCMake_test(CMP0019)
|
add_RunCMake_test(CMP0019)
|
||||||
|
add_RunCMake_test(CTest)
|
||||||
if(UNIX AND "${CMAKE_TEST_GENERATOR}" MATCHES "Unix Makefiles")
|
if(UNIX AND "${CMAKE_TEST_GENERATOR}" MATCHES "Unix Makefiles")
|
||||||
add_RunCMake_test(CompilerChange)
|
add_RunCMake_test(CompilerChange)
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
1
|
|
@ -0,0 +1,6 @@
|
||||||
|
CMake Error at .*/Modules/CTest.cmake:[0-9]+ \(build_command\):
|
||||||
|
build_command\(\) requires CMAKE_MAKE_PROGRAM to be defined. Call project\(\)
|
||||||
|
or enable_language\(\) first.
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
BeforeProject.cmake:[0-9]+ \(include\)
|
||||||
|
CMakeLists.txt:[0-9]+ \(include\)
|
|
@ -0,0 +1,2 @@
|
||||||
|
include(CTest)
|
||||||
|
project(${RunCMake_TEST} NONE)
|
|
@ -0,0 +1,5 @@
|
||||||
|
cmake_minimum_required(VERSION 2.8)
|
||||||
|
if(NOT NoProject)
|
||||||
|
project(${RunCMake_TEST} NONE)
|
||||||
|
endif()
|
||||||
|
include(${RunCMake_TEST}.cmake)
|
|
@ -0,0 +1,5 @@
|
||||||
|
include(RunCMake)
|
||||||
|
|
||||||
|
set(RunCMake_TEST_OPTIONS -DNoProject=1)
|
||||||
|
run_cmake(BeforeProject)
|
||||||
|
unset(RunCMake_TEST_OPTIONS)
|
|
@ -0,0 +1 @@
|
||||||
|
1
|
|
@ -0,0 +1,5 @@
|
||||||
|
CMake Error at BeforeProject.cmake:[0-9]+ \(build_command\):
|
||||||
|
build_command\(\) requires CMAKE_MAKE_PROGRAM to be defined. Call project\(\)
|
||||||
|
or enable_language\(\) first.
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
CMakeLists.txt:[0-9]+ \(include\)
|
|
@ -0,0 +1,2 @@
|
||||||
|
build_command(MAKECOMMAND_DEFAULT_VALUE)
|
||||||
|
project(${RunCMake_TEST} NONE)
|
|
@ -1,59 +1,5 @@
|
||||||
cmake_minimum_required(VERSION 2.8)
|
cmake_minimum_required(VERSION 2.8)
|
||||||
project(${RunCMake_TEST} NONE)
|
if(NOT NoProject)
|
||||||
include(${RunCMake_TEST}.cmake)
|
project(${RunCMake_TEST} NONE)
|
||||||
|
|
||||||
# This CMakeLists file is *sometimes expected* to result in a configure error.
|
|
||||||
#
|
|
||||||
# expect this to succeed:
|
|
||||||
# ../bin/Release/cmake -G Xcode
|
|
||||||
# ../../CMake/Tests/CMakeCommands/build_command
|
|
||||||
#
|
|
||||||
# expect this to fail:
|
|
||||||
# ../bin/Release/cmake -DTEST_ERROR_CONDITIONS:BOOL=ON -G Xcode
|
|
||||||
# ../../CMake/Tests/CMakeCommands/build_command
|
|
||||||
#
|
|
||||||
# This project exists merely to test the CMake command 'build_command'...
|
|
||||||
# ...even purposefully calling it with known-bad argument lists to cover
|
|
||||||
# error handling code.
|
|
||||||
#
|
|
||||||
|
|
||||||
set(cmd "initial")
|
|
||||||
|
|
||||||
message("0. begin")
|
|
||||||
|
|
||||||
if(TEST_ERROR_CONDITIONS)
|
|
||||||
# Test with no arguments (an error):
|
|
||||||
build_command()
|
|
||||||
message("1. cmd='${cmd}'")
|
|
||||||
|
|
||||||
# Test with unknown arguments (also an error):
|
|
||||||
build_command(cmd BOGUS STUFF)
|
|
||||||
message("2. cmd='${cmd}'")
|
|
||||||
|
|
||||||
build_command(cmd STUFF BOGUS)
|
|
||||||
message("3. cmd='${cmd}'")
|
|
||||||
else()
|
|
||||||
message("(skipping cases 1, 2 and 3 because TEST_ERROR_CONDITIONS is OFF)")
|
|
||||||
endif()
|
endif()
|
||||||
|
include(${RunCMake_TEST}.cmake)
|
||||||
# Test the one arg signature with none of the optional KEYWORD arguments:
|
|
||||||
build_command(cmd)
|
|
||||||
message("4. cmd='${cmd}'")
|
|
||||||
|
|
||||||
# Test the two-arg legacy signature:
|
|
||||||
build_command(legacy_cmd ${CMAKE_BUILD_TOOL})
|
|
||||||
message("5. legacy_cmd='${legacy_cmd}'")
|
|
||||||
message(" CMAKE_BUILD_TOOL='${CMAKE_BUILD_TOOL}'")
|
|
||||||
|
|
||||||
# Test the optional KEYWORDs:
|
|
||||||
build_command(cmd CONFIGURATION hoohaaConfig)
|
|
||||||
message("6. cmd='${cmd}'")
|
|
||||||
|
|
||||||
build_command(cmd PROJECT_NAME hoohaaProject)
|
|
||||||
message("7. cmd='${cmd}'")
|
|
||||||
|
|
||||||
build_command(cmd TARGET hoohaaTarget)
|
|
||||||
message("8. cmd='${cmd}'")
|
|
||||||
|
|
||||||
set(cmd "final")
|
|
||||||
message("9. cmd='${cmd}'")
|
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
# This CMakeLists file is *sometimes expected* to result in a configure error.
|
||||||
|
#
|
||||||
|
# expect this to succeed:
|
||||||
|
# ../bin/Release/cmake -G Xcode
|
||||||
|
# ../../CMake/Tests/CMakeCommands/build_command
|
||||||
|
#
|
||||||
|
# expect this to fail:
|
||||||
|
# ../bin/Release/cmake -DTEST_ERROR_CONDITIONS:BOOL=ON -G Xcode
|
||||||
|
# ../../CMake/Tests/CMakeCommands/build_command
|
||||||
|
#
|
||||||
|
# This project exists merely to test the CMake command 'build_command'...
|
||||||
|
# ...even purposefully calling it with known-bad argument lists to cover
|
||||||
|
# error handling code.
|
||||||
|
#
|
||||||
|
|
||||||
|
set(cmd "initial")
|
||||||
|
|
||||||
|
message("0. begin")
|
||||||
|
|
||||||
|
if(TEST_ERROR_CONDITIONS)
|
||||||
|
# Test with no arguments (an error):
|
||||||
|
build_command()
|
||||||
|
message("1. cmd='${cmd}'")
|
||||||
|
|
||||||
|
# Test with unknown arguments (also an error):
|
||||||
|
build_command(cmd BOGUS STUFF)
|
||||||
|
message("2. cmd='${cmd}'")
|
||||||
|
|
||||||
|
build_command(cmd STUFF BOGUS)
|
||||||
|
message("3. cmd='${cmd}'")
|
||||||
|
else()
|
||||||
|
message("(skipping cases 1, 2 and 3 because TEST_ERROR_CONDITIONS is OFF)")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Test the one arg signature with none of the optional KEYWORD arguments:
|
||||||
|
build_command(cmd)
|
||||||
|
message("4. cmd='${cmd}'")
|
||||||
|
|
||||||
|
# Test the two-arg legacy signature:
|
||||||
|
build_command(legacy_cmd ${CMAKE_BUILD_TOOL})
|
||||||
|
message("5. legacy_cmd='${legacy_cmd}'")
|
||||||
|
message(" CMAKE_BUILD_TOOL='${CMAKE_BUILD_TOOL}'")
|
||||||
|
|
||||||
|
# Test the optional KEYWORDs:
|
||||||
|
build_command(cmd CONFIGURATION hoohaaConfig)
|
||||||
|
message("6. cmd='${cmd}'")
|
||||||
|
|
||||||
|
build_command(cmd PROJECT_NAME hoohaaProject)
|
||||||
|
message("7. cmd='${cmd}'")
|
||||||
|
|
||||||
|
build_command(cmd TARGET hoohaaTarget)
|
||||||
|
message("8. cmd='${cmd}'")
|
||||||
|
|
||||||
|
set(cmd "final")
|
||||||
|
message("9. cmd='${cmd}'")
|
|
@ -1 +1,2 @@
|
||||||
set(TEST_ERROR_CONDITIONS OFF)
|
set(TEST_ERROR_CONDITIONS OFF)
|
||||||
|
include(ErrorsCommon.cmake)
|
||||||
|
|
|
@ -1,12 +1,21 @@
|
||||||
CMake Error at CMakeLists.txt:[0-9]+ \(build_command\):
|
CMake Error at ErrorsCommon.cmake:[0-9]+ \(build_command\):
|
||||||
build_command requires at least one argument naming a CMake variable
|
build_command requires at least one argument naming a CMake variable
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
ErrorsON.cmake:[0-9]+ \(include\)
|
||||||
|
CMakeLists.txt:[0-9]+ \(include\)
|
||||||
|
|
||||||
+
|
+
|
||||||
1. cmd='initial'
|
1. cmd='initial'
|
||||||
CMake Error at CMakeLists.txt:[0-9]+ \(build_command\):
|
CMake Error at ErrorsCommon.cmake:[0-9]+ \(build_command\):
|
||||||
build_command unknown argument "BOGUS"
|
build_command unknown argument "BOGUS"
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
ErrorsON.cmake:[0-9]+ \(include\)
|
||||||
|
CMakeLists.txt:[0-9]+ \(include\)
|
||||||
|
|
||||||
+
|
+
|
||||||
2. cmd='initial'
|
2. cmd='initial'
|
||||||
CMake Error at CMakeLists.txt:[0-9]+ \(build_command\):
|
CMake Error at ErrorsCommon.cmake:[0-9]+ \(build_command\):
|
||||||
build_command unknown argument "STUFF"
|
build_command unknown argument "STUFF"
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
ErrorsON.cmake:[0-9]+ \(include\)
|
||||||
|
CMakeLists.txt:[0-9]+ \(include\)
|
||||||
|
|
|
@ -1 +1,2 @@
|
||||||
set(TEST_ERROR_CONDITIONS ON)
|
set(TEST_ERROR_CONDITIONS ON)
|
||||||
|
include(ErrorsCommon.cmake)
|
||||||
|
|
|
@ -2,3 +2,7 @@ include(RunCMake)
|
||||||
|
|
||||||
run_cmake(ErrorsOFF)
|
run_cmake(ErrorsOFF)
|
||||||
run_cmake(ErrorsON)
|
run_cmake(ErrorsON)
|
||||||
|
|
||||||
|
set(RunCMake_TEST_OPTIONS -DNoProject=1)
|
||||||
|
run_cmake(BeforeProject)
|
||||||
|
unset(RunCMake_TEST_OPTIONS)
|
||||||
|
|
Loading…
Reference in New Issue