From 128d383873b2690cae5b42bd0db249b116da42bc Mon Sep 17 00:00:00 2001 From: Ralf Grubenmann Date: Mon, 13 May 2024 09:03:41 +0200 Subject: [PATCH] fix: don't fail session launch when gitlab couldn't be reached --- renku/core/session/renkulab.py | 42 ++++++++++++++++++++++++++-------- 1 file changed, 33 insertions(+), 9 deletions(-) diff --git a/renku/core/session/renkulab.py b/renku/core/session/renkulab.py index 82f70c25a1..57ee2badeb 100644 --- a/renku/core/session/renkulab.py +++ b/renku/core/session/renkulab.py @@ -116,7 +116,9 @@ def _wait_for_session_status( start = monotonic() while monotonic() - start < self.DEFAULT_TIMEOUT_SECONDS: res = self._send_renku_request( - "get", f"{self._notebooks_url()}/servers/{name}", headers=self._auth_header() + "get", + f"{self._notebooks_url()}/servers/{name}", + headers=self._auth_header(), ) if res.status_code == 404 and status == "stopping": return @@ -266,10 +268,15 @@ def find_image(self, image_name: str, config: Optional[Dict[str, Any]]) -> bool: def get_cloudstorage(self): """Get cloudstorage configured for the project.""" storage_service = cast(IStorageService, inject.instance(IStorageService)) - project_id = storage_service.project_id + + try: + project_id = storage_service.project_id + except errors.ProjectNotFound: + project_id = None + if project_id is None: - communication.warn("Couldn't get project ID from Gitlab, skipping mounting cloudstorage") - return + communication.warn("Skipping cloud storage mounting as project couldn't be loaded from gitlab.") + return [] storages = storage_service.list(project_id) @@ -291,7 +298,12 @@ def get_cloudstorage(self): secret = communication.prompt(f"{field['help']}\nPlease provide a value for secret '{name}'") storage.configuration[name] = secret - storages_to_mount.append({"storage_id": storage.storage_id, "configuration": storage.configuration}) + storages_to_mount.append( + { + "storage_id": storage.storage_id, + "configuration": storage.configuration, + } + ) return storages_to_mount @@ -447,21 +459,27 @@ def session_stop(self, project_name: str, session_name: Optional[str], stop_all: for session in sessions: responses.append( self._send_renku_request( - "delete", f"{self._notebooks_url()}/servers/{session.id}", headers=self._auth_header() + "delete", + f"{self._notebooks_url()}/servers/{session.id}", + headers=self._auth_header(), ) ) self._wait_for_session_status(session.id, "stopping") elif session_name: responses.append( self._send_renku_request( - "delete", f"{self._notebooks_url()}/servers/{session_name}", headers=self._auth_header() + "delete", + f"{self._notebooks_url()}/servers/{session_name}", + headers=self._auth_header(), ) ) self._wait_for_session_status(session_name, "stopping") elif n_sessions == 1: responses.append( self._send_renku_request( - "delete", f"{self._notebooks_url()}/servers/{sessions[0].id}", headers=self._auth_header() + "delete", + f"{self._notebooks_url()}/servers/{sessions[0].id}", + headers=self._auth_header(), ) ) self._wait_for_session_status(sessions[0].id, "stopping") @@ -474,7 +492,13 @@ def session_stop(self, project_name: str, session_name: Optional[str], stop_all: return SessionStopStatus.SUCCESSFUL if n_successfully_stopped == n_sessions else SessionStopStatus.FAILED - def session_open(self, project_name: str, session_name: Optional[str], ssh: bool = False, **kwargs) -> bool: + def session_open( + self, + project_name: str, + session_name: Optional[str], + ssh: bool = False, + **kwargs, + ) -> bool: """Open a given interactive session. Args: