diff options
author | Marc Chevrier <marc.chevrier@gmail.com> | 2020-11-11 15:16:49 (GMT) |
---|---|---|
committer | Marc Chevrier <marc.chevrier@gmail.com> | 2020-11-11 15:16:49 (GMT) |
commit | a00603af0b61ae93c96bc77b576315134ee36f22 (patch) | |
tree | efe3c08af27e9776e7561257177d7861f0166a0d | |
parent | b1208722c559920d83c571c26a382d0a158d5460 (diff) | |
download | CMake-a00603af0b61ae93c96bc77b576315134ee36f22.zip CMake-a00603af0b61ae93c96bc77b576315134ee36f22.tar.gz CMake-a00603af0b61ae93c96bc77b576315134ee36f22.tar.bz2 |
FindPython: Fix version range tests
Tests must be successful when multiple versions are installed.
-rw-r--r-- | Tests/FindPython/VersionRange/CMakeLists.txt | 41 |
1 files changed, 25 insertions, 16 deletions
diff --git a/Tests/FindPython/VersionRange/CMakeLists.txt b/Tests/FindPython/VersionRange/CMakeLists.txt index e8873cb..957941d 100644 --- a/Tests/FindPython/VersionRange/CMakeLists.txt +++ b/Tests/FindPython/VersionRange/CMakeLists.txt @@ -16,40 +16,49 @@ else() set (OUT_VERSION_RANGE 3.0...<${${Python}_VERSION}) endif() -function (FIND_PYTHON EXPECTED_VERSION) - unset (_${Python}_EXECUTABLE CACHE) - unset (_${Python}_LIBRARY_RELEASE CACHE) - unset (_${Python}_INCLUDE_DIR CACHE) - unset (${Python}_FOUND) +function (FIND_PYTHON EXPECTED_VERSION RANGE) + macro (FIND_PYTHON_PACKAGE) + unset (_${Python}_EXECUTABLE CACHE) + unset (_${Python}_LIBRARY_RELEASE CACHE) + unset (_${Python}_INCLUDE_DIR CACHE) + unset (${Python}_FOUND) - find_package (${ARGN}) + find_package (${Python} ${ARGV}) + endmacro() + + find_python_package(${RANGE} ${ARGN}) if (EXPECTED_VERSION STREQUAL "NONE") + while (${Python}_FOUND AND ${Python}_VERSION VERSION_GREATER ${Python_REQUESTED_VERSION}) + # Possible if multiple versions are installed + # Try with a different range + find_python_package(${Python_REQUESTED_VERSION}.0...<${${Python}_VERSION} ${ARGN}) + endwhile() if (${Python}_FOUND) - message (SEND_ERROR "Unexpectedly found version: ${${Python}_VERSION} for ${ARGN}") + message (SEND_ERROR "Unexpectedly found version: ${${Python}_VERSION} for '${Python} ${Python_REQUESTED_VERSION}.0...<${${Python}_VERSION} ${ARGN}'") endif() return() endif() if (NOT ${Python}_FOUND) - message (SEND_ERROR "Not found: ${ARGN}") + message (SEND_ERROR "Not found: ${Python} ${RANGE} ${ARGN}") elseif (NOT ${Python}_VERSION VERSION_EQUAL EXPECTED_VERSION) - message (SEND_ERROR "Wrong version: ${${Python}_VERSION} for ${ARGN}") + message (SEND_ERROR "Wrong version: ${${Python}_VERSION} for '${Python} ${RANGE} ${ARGN}'") endif() endfunction() -find_python (${${Python}_VERSION} ${Python} ${IN_VERSION_RANGE} COMPONENTS Interpreter) +find_python (${${Python}_VERSION} ${IN_VERSION_RANGE} COMPONENTS Interpreter) if (${Python}_FIND_IMPLEMENTATIONS STREQUAL "IronPython") - find_python (${${Python}_VERSION} ${Python} ${IN_VERSION_RANGE} COMPONENTS Compiler) + find_python (${${Python}_VERSION} ${IN_VERSION_RANGE} COMPONENTS Compiler) else() - find_python (${${Python}_VERSION} ${Python} ${IN_VERSION_RANGE} COMPONENTS Development) + find_python (${${Python}_VERSION} ${IN_VERSION_RANGE} COMPONENTS Development) endif() -find_python ("NONE" ${Python} ${OUT_VERSION_RANGE} COMPONENTS Interpreter) +find_python ("NONE" ${OUT_VERSION_RANGE} COMPONENTS Interpreter) if (${Python}_FIND_IMPLEMENTATIONS STREQUAL "IronPython") - find_python ("NONE" ${Python} ${OUT_VERSION_RANGE} COMPONENTS Compiler) + find_python ("NONE" ${OUT_VERSION_RANGE} COMPONENTS Compiler) else() - find_python ("NONE" ${Python} ${OUT_VERSION_RANGE} COMPONENTS Development) + find_python ("NONE" ${OUT_VERSION_RANGE} COMPONENTS Development) endif() -find_python ("NONE" ${Python} 5...6 COMPONENTS Interpreter) +find_python ("NONE" 5...6 COMPONENTS Interpreter) |