CMakeLists.txt 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. # this test creates a static library and an executable
  2. # the source to the library is then changed
  3. # and the build is done on the executable and if things
  4. # are working the executable should relink with the new
  5. # value. The subdir Project contains the CMakelists.txt
  6. # and source files for the test project.
  7. cmake_minimum_required (VERSION 2.6)
  8. project(BuildDepends)
  9. # This entire test takes place during the initial
  10. # configure step. It should not run again when the
  11. # project is built.
  12. set(CMAKE_SUPPRESS_REGENERATION 1)
  13. # Xcode needs some help with the fancy dependencies in this test.
  14. if("${CMAKE_GENERATOR}" MATCHES "Xcode")
  15. set(HELP_XCODE 1)
  16. endif("${CMAKE_GENERATOR}" MATCHES "Xcode")
  17. function(help_xcode_depends)
  18. if(HELP_XCODE)
  19. file(GLOB_RECURSE MACRO_OBJS
  20. ${BuildDepends_BINARY_DIR}/Project/zot_macro_*.o*
  21. )
  22. if(MACRO_OBJS)
  23. message("Helping Xcode by removing objects [${MACRO_OBJS}]")
  24. file(REMOVE ${MACRO_OBJS})
  25. endif(MACRO_OBJS)
  26. endif(HELP_XCODE)
  27. endfunction(help_xcode_depends)
  28. file(MAKE_DIRECTORY ${BuildDepends_BINARY_DIR}/Project)
  29. message("Creating Project/foo.cxx")
  30. write_file(${BuildDepends_BINARY_DIR}/Project/foo.cxx
  31. "const char* foo() { return \"foo\";}" )
  32. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot.hxx.in
  33. "static const char* zot = \"zot\";\n")
  34. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_custom.hxx.in
  35. "static const char* zot_custom = \"zot_custom\";\n")
  36. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_dir.hxx
  37. "static const char* zot_macro_dir = \"zot_macro_dir\";\n")
  38. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_tgt.hxx
  39. "static const char* zot_macro_tgt = \"zot_macro_tgt\";\n")
  40. help_xcode_depends()
  41. message("Building project first time")
  42. try_compile(RESULT
  43. ${BuildDepends_BINARY_DIR}/Project
  44. ${BuildDepends_SOURCE_DIR}/Project
  45. testRebuild
  46. OUTPUT_VARIABLE OUTPUT)
  47. if(HELP_XCODE)
  48. try_compile(RESULT
  49. ${BuildDepends_BINARY_DIR}/Project
  50. ${BuildDepends_SOURCE_DIR}/Project
  51. testRebuild
  52. OUTPUT_VARIABLE OUTPUT)
  53. try_compile(RESULT
  54. ${BuildDepends_BINARY_DIR}/Project
  55. ${BuildDepends_SOURCE_DIR}/Project
  56. testRebuild
  57. OUTPUT_VARIABLE OUTPUT)
  58. endif(HELP_XCODE)
  59. message("Output from first build:\n${OUTPUT}")
  60. if(NOT RESULT)
  61. message(SEND_ERROR "Could not build test project (1)!")
  62. endif(NOT RESULT)
  63. set(bar ${BuildDepends_BINARY_DIR}/Project/bar${CMAKE_EXECUTABLE_SUFFIX})
  64. if(EXISTS
  65. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}" )
  66. message("found debug")
  67. set(bar
  68. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
  69. endif(EXISTS
  70. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
  71. set(zot ${BuildDepends_BINARY_DIR}/Project/zot${CMAKE_EXECUTABLE_SUFFIX})
  72. if(EXISTS
  73. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}" )
  74. message("found debug")
  75. set(zot
  76. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
  77. endif(EXISTS
  78. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
  79. message("Running ${bar} ")
  80. execute_process(COMMAND ${bar} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  81. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  82. message("Run result: ${runResult} Output: \"${out}\"")
  83. if("${out}" STREQUAL "foo ")
  84. message("Worked!")
  85. else("${out}" STREQUAL "foo ")
  86. message(SEND_ERROR "Project did not initially build properly: ${out}")
  87. endif("${out}" STREQUAL "foo ")
  88. message("Running ${zot} ")
  89. execute_process(COMMAND ${zot} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  90. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  91. message("Run result: ${runResult} Output: \"${out}\"")
  92. set(VALUE_UNCHANGED "[zot] [zot_custom] [zot_macro_dir] [zot_macro_tgt] ")
  93. if("${out}" STREQUAL "${VALUE_UNCHANGED}")
  94. message("Worked!")
  95. else("${out}" STREQUAL "${VALUE_UNCHANGED}")
  96. message(SEND_ERROR "Project did not initially build properly: ${out}")
  97. endif("${out}" STREQUAL "${VALUE_UNCHANGED}")
  98. message("Waiting 3 seconds...")
  99. # any additional argument will cause ${bar} to wait forever
  100. execute_process(COMMAND ${bar} -infinite TIMEOUT 3 OUTPUT_VARIABLE out)
  101. message("Modifying Project/foo.cxx")
  102. write_file(${BuildDepends_BINARY_DIR}/Project/foo.cxx
  103. "const char* foo() { return \"foo changed\";}" )
  104. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot.hxx.in
  105. "static const char* zot = \"zot changed\";\n")
  106. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_custom.hxx.in
  107. "static const char* zot_custom = \"zot_custom changed\";\n")
  108. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_dir.hxx
  109. "static const char* zot_macro_dir = \"zot_macro_dir changed\";\n")
  110. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_tgt.hxx
  111. "static const char* zot_macro_tgt = \"zot_macro_tgt changed\";\n")
  112. help_xcode_depends()
  113. message("Building project second time")
  114. try_compile(RESULT
  115. ${BuildDepends_BINARY_DIR}/Project
  116. ${BuildDepends_SOURCE_DIR}/Project
  117. testRebuild
  118. OUTPUT_VARIABLE OUTPUT)
  119. # Xcode is in serious need of help here
  120. if(HELP_XCODE)
  121. try_compile(RESULT
  122. ${BuildDepends_BINARY_DIR}/Project
  123. ${BuildDepends_SOURCE_DIR}/Project
  124. testRebuild
  125. OUTPUT_VARIABLE OUTPUT)
  126. try_compile(RESULT
  127. ${BuildDepends_BINARY_DIR}/Project
  128. ${BuildDepends_SOURCE_DIR}/Project
  129. testRebuild
  130. OUTPUT_VARIABLE OUTPUT)
  131. endif(HELP_XCODE)
  132. message("Output from second build:\n${OUTPUT}")
  133. if(NOT RESULT)
  134. message(SEND_ERROR "Could not build test project (2)!")
  135. endif(NOT RESULT)
  136. if(EXISTS
  137. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}" )
  138. message("found debug")
  139. endif(EXISTS
  140. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
  141. if(EXISTS
  142. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}" )
  143. message("found debug")
  144. endif(EXISTS
  145. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
  146. message("Running ${bar} ")
  147. execute_process(COMMAND ${bar} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  148. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  149. message("Run result: ${runResult} Output: \"${out}\"")
  150. if("${out}" STREQUAL "foo changed ")
  151. message("Worked!")
  152. else("${out}" STREQUAL "foo changed ")
  153. message(SEND_ERROR "Project did not rebuild properly!")
  154. endif("${out}" STREQUAL "foo changed ")
  155. message("Running ${zot} ")
  156. execute_process(COMMAND ${zot} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  157. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  158. message("Run result: ${runResult} Output: \"${out}\"")
  159. set(VALUE_CHANGED
  160. "[zot changed] [zot_custom changed] [zot_macro_dir changed] [zot_macro_tgt changed] "
  161. )
  162. if("${out}" STREQUAL "${VALUE_CHANGED}")
  163. message("Worked!")
  164. else("${out}" STREQUAL "${VALUE_CHANGED}")
  165. message(SEND_ERROR "Project did not rebuild properly!")
  166. endif("${out}" STREQUAL "${VALUE_CHANGED}")