2007-05-09 23:10:12 +04:00
|
|
|
# this test creates a static library and an executable
|
|
|
|
# the source to the library is then changed
|
|
|
|
# and the build is done on the executable and if things
|
|
|
|
# are working the executable should relink with the new
|
|
|
|
# value. The subdir Project contains the CMakelists.txt
|
|
|
|
# and source files for the test project.
|
|
|
|
project(BuildDepends)
|
2007-06-14 00:26:50 +04:00
|
|
|
|
|
|
|
file(MAKE_DIRECTORY ${BuildDepends_BINARY_DIR}/Project)
|
|
|
|
message("Creating Project/foo.cxx")
|
2007-05-16 15:55:00 +04:00
|
|
|
write_file(${BuildDepends_BINARY_DIR}/Project/foo.cxx
|
2007-05-09 23:10:12 +04:00
|
|
|
"const char* foo() { return \"foo\";}" )
|
2007-06-14 00:26:50 +04:00
|
|
|
|
2007-09-17 18:51:05 +04:00
|
|
|
file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot.hxx.in
|
|
|
|
"static const char* zot = \"zot\";\n")
|
|
|
|
|
2007-06-14 00:26:50 +04:00
|
|
|
message("Building project first time")
|
2007-05-09 23:10:12 +04:00
|
|
|
try_compile(RESULT
|
|
|
|
${BuildDepends_BINARY_DIR}/Project
|
|
|
|
${BuildDepends_SOURCE_DIR}/Project
|
|
|
|
testRebuild
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
2007-06-14 00:26:50 +04:00
|
|
|
if("${CMAKE_GENERATOR}" MATCHES "Xcode")
|
2007-05-24 01:58:14 +04:00
|
|
|
try_compile(RESULT
|
|
|
|
${BuildDepends_BINARY_DIR}/Project
|
|
|
|
${BuildDepends_SOURCE_DIR}/Project
|
|
|
|
testRebuild
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
|
|
|
try_compile(RESULT
|
|
|
|
${BuildDepends_BINARY_DIR}/Project
|
|
|
|
${BuildDepends_SOURCE_DIR}/Project
|
|
|
|
testRebuild
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
2007-06-14 00:26:50 +04:00
|
|
|
endif("${CMAKE_GENERATOR}" MATCHES "Xcode")
|
2007-05-24 01:58:14 +04:00
|
|
|
|
2007-05-16 15:55:00 +04:00
|
|
|
if(NOT RESULT)
|
|
|
|
message(SEND_ERROR "Could not build test project: ${OUTPUT}")
|
|
|
|
endif(NOT RESULT)
|
|
|
|
|
2007-05-10 18:05:52 +04:00
|
|
|
set(bar ${BuildDepends_BINARY_DIR}/Project/bar${CMAKE_EXECUTABLE_SUFFIX})
|
|
|
|
if(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}" )
|
|
|
|
message("found debug")
|
|
|
|
set(bar
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
|
|
|
|
endif(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
|
2007-09-17 18:51:05 +04:00
|
|
|
set(zot ${BuildDepends_BINARY_DIR}/Project/zot${CMAKE_EXECUTABLE_SUFFIX})
|
|
|
|
if(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}" )
|
|
|
|
message("found debug")
|
|
|
|
set(zot
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
|
|
|
|
endif(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
|
2007-06-14 00:26:50 +04:00
|
|
|
|
|
|
|
message("Running ${bar} ")
|
|
|
|
execute_process(COMMAND ${bar} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
|
2007-05-10 18:05:52 +04:00
|
|
|
string(REGEX REPLACE "[\r\n]" " " out "${out}")
|
2007-06-14 00:26:50 +04:00
|
|
|
message("Run result: ${runResult} Output: \"${out}\"")
|
|
|
|
|
2007-05-10 18:05:52 +04:00
|
|
|
if("${out}" STREQUAL "foo ")
|
2007-05-09 23:10:12 +04:00
|
|
|
message("Worked!")
|
2007-05-10 18:05:52 +04:00
|
|
|
else("${out}" STREQUAL "foo ")
|
2007-05-24 01:58:14 +04:00
|
|
|
message(SEND_ERROR "Project did not initially build properly: ${out}")
|
2007-05-10 18:05:52 +04:00
|
|
|
endif("${out}" STREQUAL "foo ")
|
2007-05-09 23:10:12 +04:00
|
|
|
|
2007-09-17 18:51:05 +04:00
|
|
|
message("Running ${zot} ")
|
|
|
|
execute_process(COMMAND ${zot} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
|
|
|
|
string(REGEX REPLACE "[\r\n]" " " out "${out}")
|
|
|
|
message("Run result: ${runResult} Output: \"${out}\"")
|
|
|
|
|
|
|
|
if("${out}" STREQUAL "zot ")
|
|
|
|
message("Worked!")
|
|
|
|
else("${out}" STREQUAL "zot ")
|
|
|
|
message(SEND_ERROR "Project did not initially build properly: ${out}")
|
|
|
|
endif("${out}" STREQUAL "zot ")
|
|
|
|
|
2007-06-14 00:26:50 +04:00
|
|
|
message("Waiting 3 seconds...")
|
|
|
|
# any additional argument will cause ${bar} to wait forever
|
|
|
|
execute_process(COMMAND ${bar} -infinite TIMEOUT 3 OUTPUT_VARIABLE out)
|
|
|
|
|
|
|
|
message("Modifying Project/foo.cxx")
|
2007-05-16 15:55:00 +04:00
|
|
|
write_file(${BuildDepends_BINARY_DIR}/Project/foo.cxx
|
2007-05-09 23:10:12 +04:00
|
|
|
"const char* foo() { return \"foo changed\";}" )
|
2007-09-17 18:51:05 +04:00
|
|
|
file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot.hxx.in
|
|
|
|
"static const char* zot = \"zot changed\";\n")
|
2007-06-14 00:26:50 +04:00
|
|
|
|
|
|
|
message("Building project second time")
|
2007-05-09 23:10:12 +04:00
|
|
|
try_compile(RESULT
|
|
|
|
${BuildDepends_BINARY_DIR}/Project
|
|
|
|
${BuildDepends_SOURCE_DIR}/Project
|
|
|
|
testRebuild
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
|
|
|
|
2007-05-24 01:58:14 +04:00
|
|
|
# Xcode is in serious need of help here
|
2007-06-14 00:26:50 +04:00
|
|
|
if("${CMAKE_GENERATOR}" MATCHES "Xcode")
|
2007-05-24 01:58:14 +04:00
|
|
|
try_compile(RESULT
|
|
|
|
${BuildDepends_BINARY_DIR}/Project
|
|
|
|
${BuildDepends_SOURCE_DIR}/Project
|
|
|
|
testRebuild
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
|
|
|
try_compile(RESULT
|
|
|
|
${BuildDepends_BINARY_DIR}/Project
|
|
|
|
${BuildDepends_SOURCE_DIR}/Project
|
|
|
|
testRebuild
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
2007-06-14 00:26:50 +04:00
|
|
|
endif("${CMAKE_GENERATOR}" MATCHES "Xcode")
|
2007-05-24 01:58:14 +04:00
|
|
|
|
2007-05-16 15:55:00 +04:00
|
|
|
if(NOT RESULT)
|
|
|
|
message(SEND_ERROR "Could not build test project: ${OUTPUT}")
|
|
|
|
endif(NOT RESULT)
|
2007-05-10 18:05:52 +04:00
|
|
|
if(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}" )
|
|
|
|
message("found debug")
|
|
|
|
endif(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
|
2007-09-17 18:51:05 +04:00
|
|
|
if(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}" )
|
|
|
|
message("found debug")
|
|
|
|
endif(EXISTS
|
|
|
|
"${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
|
2007-05-10 18:05:52 +04:00
|
|
|
|
2007-06-14 00:26:50 +04:00
|
|
|
message("Running ${bar} ")
|
|
|
|
execute_process(COMMAND ${bar} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
|
2007-05-10 18:05:52 +04:00
|
|
|
string(REGEX REPLACE "[\r\n]" " " out "${out}")
|
2007-06-14 00:26:50 +04:00
|
|
|
message("Run result: ${runResult} Output: \"${out}\"")
|
2007-05-09 23:10:12 +04:00
|
|
|
|
2007-05-10 18:05:52 +04:00
|
|
|
if("${out}" STREQUAL "foo changed ")
|
2007-05-09 23:10:12 +04:00
|
|
|
message("Worked!")
|
2007-05-10 18:05:52 +04:00
|
|
|
else("${out}" STREQUAL "foo changed ")
|
2007-05-23 21:27:00 +04:00
|
|
|
message(SEND_ERROR "Project did not rebuild properly!")
|
2007-05-10 18:05:52 +04:00
|
|
|
endif("${out}" STREQUAL "foo changed ")
|
2007-09-17 18:51:05 +04:00
|
|
|
|
|
|
|
message("Running ${zot} ")
|
|
|
|
execute_process(COMMAND ${zot} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
|
|
|
|
string(REGEX REPLACE "[\r\n]" " " out "${out}")
|
|
|
|
message("Run result: ${runResult} Output: \"${out}\"")
|
|
|
|
|
|
|
|
if("${out}" STREQUAL "zot changed ")
|
|
|
|
message("Worked!")
|
|
|
|
else("${out}" STREQUAL "zot changed ")
|
|
|
|
message(SEND_ERROR "Project did not rebuild properly!")
|
|
|
|
endif("${out}" STREQUAL "zot changed ")
|