mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
fix(installer): more reliably upgrade pip
This commit is contained in:
parent
31b9538976
commit
3d1b5c57ea
@ -73,7 +73,7 @@ class Installer:
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
# upgrade pip to the latest version to avoid a confusing message
|
# upgrade pip to the latest version to avoid a confusing message
|
||||||
res = subprocess.check_output([pip, "install", "--upgrade", "pip"]).decode()
|
res = upgrade_pip(Path(venv_dir.name))
|
||||||
if verbose:
|
if verbose:
|
||||||
print(res)
|
print(res)
|
||||||
|
|
||||||
@ -169,6 +169,7 @@ class InvokeAiInstance:
|
|||||||
set_sys_path(venv)
|
set_sys_path(venv)
|
||||||
os.environ["INVOKEAI_ROOT"] = str(self.runtime.expanduser().resolve())
|
os.environ["INVOKEAI_ROOT"] = str(self.runtime.expanduser().resolve())
|
||||||
os.environ["VIRTUAL_ENV"] = str(self.venv.expanduser().resolve())
|
os.environ["VIRTUAL_ENV"] = str(self.venv.expanduser().resolve())
|
||||||
|
upgrade_pip(venv)
|
||||||
|
|
||||||
def get(self) -> tuple[Path, Path]:
|
def get(self) -> tuple[Path, Path]:
|
||||||
"""
|
"""
|
||||||
@ -218,7 +219,6 @@ class InvokeAiInstance:
|
|||||||
from plumbum import FG, ProcessExecutionError, local # type: ignore
|
from plumbum import FG, ProcessExecutionError, local # type: ignore
|
||||||
|
|
||||||
pip = local[self.pip]
|
pip = local[self.pip]
|
||||||
_ = pip["install", "--upgrade", "pip"] & FG
|
|
||||||
|
|
||||||
pipeline = pip[
|
pipeline = pip[
|
||||||
"install",
|
"install",
|
||||||
@ -330,6 +330,23 @@ def get_pip_from_venv(venv_path: Path) -> str:
|
|||||||
return str(venv_path.expanduser().resolve() / pip)
|
return str(venv_path.expanduser().resolve() / pip)
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade_pip(venv_path: Path) -> str | None:
|
||||||
|
"""
|
||||||
|
Upgrade the pip executable in the given virtual environment
|
||||||
|
"""
|
||||||
|
|
||||||
|
python = "Scripts\\python.exe" if OS == "Windows" else "bin/python"
|
||||||
|
python = str(venv_path.expanduser().resolve() / python)
|
||||||
|
|
||||||
|
try:
|
||||||
|
result = subprocess.check_output([python, "-m", "pip", "install", "--upgrade", "pip"]).decode()
|
||||||
|
except subprocess.CalledProcessError as e:
|
||||||
|
print(e)
|
||||||
|
result = None
|
||||||
|
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
def set_sys_path(venv_path: Path) -> None:
|
def set_sys_path(venv_path: Path) -> None:
|
||||||
"""
|
"""
|
||||||
Given a path to a virtual environment, set the sys.path, in a cross-platform fashion,
|
Given a path to a virtual environment, set the sys.path, in a cross-platform fashion,
|
||||||
|
Loading…
Reference in New Issue
Block a user