From 62c6f6fd085f63b00707d47c06815a72a9f78123 Mon Sep 17 00:00:00 2001 From: David Hotham Date: Tue, 23 May 2023 05:54:29 +0100 Subject: [PATCH] fix check for in-project-venv (#7977) (cherry picked from commit 846aee3a6b08b99fd7cc63ec591ba7e64019eade) --- src/poetry/utils/env.py | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/poetry/utils/env.py b/src/poetry/utils/env.py index 33b2682abae..5f774757305 100644 --- a/src/poetry/utils/env.py +++ b/src/poetry/utils/env.py @@ -698,7 +698,7 @@ def get(self, reload: bool = False) -> Env: if not in_venv or env is not None: # Checking if a local virtualenv exists - if self.use_in_project_venv(): + if self.in_project_venv_exists(): venv = self.in_project_venv return VirtualEnv(venv) @@ -736,7 +736,7 @@ def list(self, name: str | None = None) -> list[VirtualEnv]: venv_path = self._poetry.config.virtualenvs_path env_list = [VirtualEnv(p) for p in sorted(venv_path.glob(f"{venv_name}-py*"))] - if self.use_in_project_venv(): + if self.in_project_venv_exists(): venv = self.in_project_venv env_list.insert(0, VirtualEnv(venv)) return env_list @@ -855,6 +855,14 @@ def use_in_project_venv(self) -> bool: in_project: bool | None = self._poetry.config.get("virtualenvs.in-project") if in_project is not None: return in_project + + return self.in_project_venv.is_dir() + + def in_project_venv_exists(self) -> bool: + in_project: bool | None = self._poetry.config.get("virtualenvs.in-project") + if in_project is False: + return False + return self.in_project_venv.is_dir() def create_venv(