summaryrefslogtreecommitdiffstats
path: root/Tests/RunCMake/FindPython/Python.cmake
diff options
context:
space:
mode:
authorMarc Chevrier <marc.chevrier@gmail.com>2025-02-16 17:27:23 (GMT)
committerMarc Chevrier <marc.chevrier@gmail.com>2025-02-28 16:55:24 (GMT)
commitaed9dffdc97afeb20c060d2d5c958f5ad6b0dbc1 (patch)
tree09e84a7a2dffcf7f66287e8fa59b9cff64e17d3d /Tests/RunCMake/FindPython/Python.cmake
parent75da788360ca67f752ee70754d310dca52411cf9 (diff)
downloadCMake-aed9dffdc97afeb20c060d2d5c958f5ad6b0dbc1.zip
CMake-aed9dffdc97afeb20c060d2d5c958f5ad6b0dbc1.tar.gz
CMake-aed9dffdc97afeb20c060d2d5c958f5ad6b0dbc1.tar.bz2
FindPython: migrate tests to RunCMake framework
Diffstat (limited to 'Tests/RunCMake/FindPython/Python.cmake')
-rw-r--r--Tests/RunCMake/FindPython/Python.cmake78
1 files changed, 78 insertions, 0 deletions
diff --git a/Tests/RunCMake/FindPython/Python.cmake b/Tests/RunCMake/FindPython/Python.cmake
new file mode 100644
index 0000000..2171055
--- /dev/null
+++ b/Tests/RunCMake/FindPython/Python.cmake
@@ -0,0 +1,78 @@
+enable_language(C)
+
+include(CTest)
+
+find_package(Python ${Python_REQUESTED_VERSION} REQUIRED COMPONENTS Interpreter Development)
+if (NOT Python_FOUND)
+ message (FATAL_ERROR "Failed to find Python ${Python_REQUESTED_VERSION}")
+endif()
+if (NOT Python_Development.Module_FOUND)
+ message (FATAL_ERROR "Failed to find Python ${Python_REQUESTED_VERSION}, COMPONENT 'Development.Module'")
+endif()
+if (NOT Python_Development.Embed_FOUND)
+ message (FATAL_ERROR "Failed to find Python ${Python_REQUESTED_VERSION}, COMPOENENT 'Development.Embed'")
+endif()
+
+if(NOT TARGET Python::Interpreter)
+ message(SEND_ERROR "Python::Interpreter not found")
+endif()
+
+if(NOT TARGET Python::Python)
+ message(SEND_ERROR "Python::Python not found")
+endif()
+if(NOT TARGET Python::Module)
+ message(SEND_ERROR "Python::Module not found")
+endif()
+
+if (Python_REQUESTED_VERSION)
+ Python_add_library (spam${Python_REQUESTED_VERSION} MODULE spam.c)
+ target_compile_definitions (spam${Python_REQUESTED_VERSION} PRIVATE PYTHON${Python_REQUESTED_VERSION})
+
+ add_test (NAME python_spam${Python_REQUESTED_VERSION}
+ COMMAND "${CMAKE_COMMAND}" -E env "PYTHONPATH=$<TARGET_FILE_DIR:spam${Python_REQUESTED_VERSION}>"
+ "${Python_INTERPRETER}" -c "import spam${Python_REQUESTED_VERSION}; spam${Python_REQUESTED_VERSION}.system(\"cd\")")
+else()
+ add_test(NAME findpython_script
+ COMMAND "${CMAKE_COMMAND}" -DPYTHON_PACKAGE_NAME=Python
+ -P "${CMAKE_CURRENT_LIST_DIR}/FindPythonScript.cmake")
+endif()
+
+
+#
+# New search with user's prefix
+#
+foreach(item IN ITEMS FOUND Development_FOUND Development.Module_FOUND Development.Embed_FOUND)
+ unset(Python_${item})
+endforeach()
+
+set(Python_ARTIFACTS_PREFIX "_TEST")
+find_package(Python ${Python_REQUESTED_VERSION} REQUIRED COMPONENTS Interpreter Development)
+if (NOT Python_TEST_FOUND OR NOT Python_FOUND)
+ message (FATAL_ERROR "Failed to find Python ${Python_REQUESTED_VERSION} (TEST prefix)")
+endif()
+if (NOT Python_TEST_Development.Module_FOUND OR NOT Python_Development.Module_FOUND)
+ message (FATAL_ERROR "Failed to find Python ${Python_REQUESTED_VERSION}, COMPONENT 'Development.Module' (TEST prefix)")
+endif()
+if (NOT Python_TEST_Development.Embed_FOUND OR NOT Python_Development.Embed_FOUND)
+ message (FATAL_ERROR "Failed to find Python ${Python_REQUESTED_VERSION}, COMPOENENT 'Development.Embed' (TEST prefix)")
+endif()
+
+if(NOT TARGET Python_TEST::Interpreter)
+ message(SEND_ERROR "Python_TEST::Interpreter not found")
+endif()
+
+if(NOT TARGET Python_TEST::Python)
+ message(SEND_ERROR "Python_TEST::Python not found")
+endif()
+if(NOT TARGET Python_TEST::Module)
+ message(SEND_ERROR "Python_TEST::Module not found")
+endif()
+
+if (Python_REQUESTED_VERSION)
+ Python_TEST_add_library (TEST_spam${Python_REQUESTED_VERSION} MODULE TEST_spam.c)
+ target_compile_definitions (TEST_spam${Python_REQUESTED_VERSION} PRIVATE PYTHON${Python_REQUESTED_VERSION})
+
+ add_test (NAME python_TEST_spam${Python_REQUESTED_VERSION}
+ COMMAND "${CMAKE_COMMAND}" -E env "PYTHONPATH=$<TARGET_FILE_DIR:TEST_spam${Python_REQUESTED_VERSION}>"
+ "${Python_INTERPRETER}" -c "import TEST_spam${Python_REQUESTED_VERSION}; TEST_spam${Python_REQUESTED_VERSION}.system(\"cd\")")
+endif()