From b5e7a5ba5ab43dee3682865b7dba79e3084e10c7 Mon Sep 17 00:00:00 2001 From: Eric Callahan Date: Sun, 1 May 2022 11:44:49 -0400 Subject: [PATCH] update_manager: resolve pip location issues If the supplied python executable is a symbolic link attempt to read the location at which it points. If this is a virtualenv this should give us the correct pip location. Signed-off-by: Eric Callahan --- moonraker/components/update_manager/app_deploy.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/moonraker/components/update_manager/app_deploy.py b/moonraker/components/update_manager/app_deploy.py index 334ed2a..5a7b4a6 100644 --- a/moonraker/components/update_manager/app_deploy.py +++ b/moonraker/components/update_manager/app_deploy.py @@ -5,6 +5,7 @@ # This file may be distributed under the terms of the GNU GPLv3 license. from __future__ import annotations +import os import pathlib import shutil import hashlib @@ -72,9 +73,14 @@ class AppDeploy(BaseDeploy): self.executable = pathlib.Path(executable).expanduser() self.pip_exe = self.executable.parent.joinpath("pip") if not self.pip_exe.exists(): - self.server.add_warning( - f"Update Manger {self.name}: Unable to locate pip " - "executable") + if self.executable.is_symlink(): + self.executable = pathlib.Path(os.readlink(self.executable)) + self.pip_exe = self.executable.parent.joinpath("pip") + if not self.pip_exe.exists(): + logging.info( + f"Update Manger {self.name}: Unable to locate pip " + "executable") + self.pip_exe = None self._verify_path(config, 'env', self.executable) self.venv_args = config.get('venv_args', None)