From d049af28ecff224174070cec3754766bb8950f53 Mon Sep 17 00:00:00 2001 From: PekkaSavolainen <43600314+PekkaSavolainen@users.noreply.github.com> Date: Fri, 7 Jun 2024 18:27:54 +0300 Subject: [PATCH] Fix resolve python interpreter when frozen (#143) Always use embedded Python as default when frozen and on Windows. We cannot search python from the PATH because %USERPROFILE%/AppData/Local/Microsoft/WindowsApps/ is in PATH by default on all users and this dir contains a python.exe that either opens the Microsoft Store or opens the Python that was downloaded from the Microsoft Store. Fixes spine-tools/Spine-Toolbox#2823 --- spine_engine/config.py | 6 +---- spine_engine/utils/helpers.py | 7 +++--- tests/utils/test_helpers.py | 42 ++++++++++++++++++++++++++++++----- 3 files changed, 41 insertions(+), 14 deletions(-) diff --git a/spine_engine/config.py b/spine_engine/config.py index cfd3387..58ebcaa 100644 --- a/spine_engine/config.py +++ b/spine_engine/config.py @@ -10,11 +10,7 @@ # this program. If not, see . ###################################################################################################################### -""" -Application constants. - -""" - +"""Spine Engine constants.""" import os import sys diff --git a/spine_engine/utils/helpers.py b/spine_engine/utils/helpers.py index 6025dd5..121fad8 100644 --- a/spine_engine/utils/helpers.py +++ b/spine_engine/utils/helpers.py @@ -130,9 +130,10 @@ def resolve_current_python_interpreter(): """ if not is_frozen(): return sys.executable - path = resolve_executable_from_path(PYTHON_EXECUTABLE) - if path != "": - return path + if not sys.platform == "win32": + path = resolve_executable_from_path(PYTHON_EXECUTABLE) + if path != "": + return path return EMBEDDED_PYTHON diff --git a/tests/utils/test_helpers.py b/tests/utils/test_helpers.py index 9e8c48b..ef8f41c 100644 --- a/tests/utils/test_helpers.py +++ b/tests/utils/test_helpers.py @@ -10,16 +10,20 @@ # this program. If not, see . ###################################################################################################################### -""" -Unit tests for chunk module. - -""" +"""Unit tests for chunk module.""" +import sys import unittest - +from unittest import mock from spine_engine.project_item.connection import Connection, FilterSettings from spinedb_api.filters.scenario_filter import SCENARIO_FILTER_TYPE from spinedb_api.helpers import remove_credentials_from_url -from spine_engine.utils.helpers import make_dag, gather_leaf_data, get_file_size, required_items_for_execution +from spine_engine.utils.helpers import ( + make_dag, + gather_leaf_data, + get_file_size, + required_items_for_execution, + resolve_python_interpreter, +) class TestRequiredItemsForExecution(unittest.TestCase): @@ -188,5 +192,31 @@ def test_get_file_size(self): self.assertEqual(expected_output, output) +class TestPythonInterpreter(unittest.TestCase): + def test_resolve_python_interpreter(self): + expected_path = "path_to_python" + settings = TestAppSettings(expected_path) + p = resolve_python_interpreter(settings) + self.assertEqual(expected_path, p) + settings = TestAppSettings("") + p = resolve_python_interpreter(settings) + self.assertEqual(sys.executable, p) + if sys.platform == "win32": + with mock.patch("spine_engine.utils.helpers.is_frozen") as mock_helpers_is_frozen: + mock_helpers_is_frozen.return_value = True + p = resolve_python_interpreter(settings) + self.assertIsNone(p) # This is None only on Win. # FIXME: Find a way to mock is_frozen() in config.py + mock_helpers_is_frozen.assert_called() + + +class TestAppSettings: + def __init__(self, test_path): + self.test_path = test_path + + def value(self, key): + if key == "appSettings/pythonPath": + return self.test_path + + if __name__ == "__main__": unittest.main()