From 939d2ebc1ee9bcff236516c38dd29b281fbde2b7 Mon Sep 17 00:00:00 2001 From: MoritzWeber Date: Mon, 11 Nov 2024 07:59:24 +0100 Subject: [PATCH] fix: Handle case where container_statuses is `None` `status.container_statuses` can be `None`. In this case, return `UNKNOWN` as status. --- .../capellacollab/sessions/operators/k8s.py | 39 ++++++++++--------- 1 file changed, 20 insertions(+), 19 deletions(-) diff --git a/backend/capellacollab/sessions/operators/k8s.py b/backend/capellacollab/sessions/operators/k8s.py index 3e5edee6e..3d877c9cb 100644 --- a/backend/capellacollab/sessions/operators/k8s.py +++ b/backend/capellacollab/sessions/operators/k8s.py @@ -228,29 +228,30 @@ def _get_container_state( self, status: client.V1PodStatus, ) -> sessions_models.SessionState: - container_statuses = [ - container_status - for container_status in status.container_statuses - if container_status.name == "session" - ] - if not container_statuses: - return sessions_models.SessionState.UNKNOWN + if status.container_statuses: + container_statuses = [ + container_status + for container_status in status.container_statuses + if container_status.name == "session" + ] + if not container_statuses: + return sessions_models.SessionState.UNKNOWN - state: client.V1ContainerState = container_statuses[0].state + state: client.V1ContainerState = container_statuses[0].state - if state.running: - return sessions_models.SessionState.RUNNING - if state.waiting: - waiting: client.V1ContainerStateWaiting = state.waiting + if state.running: + return sessions_models.SessionState.RUNNING + if state.waiting: + waiting: client.V1ContainerStateWaiting = state.waiting - # https://github.com/kubernetes/kubernetes/blob/da215bf06a3b8ac3da4e0adb110dc5acc7f61fe1/pkg/kubelet/kubelet_pods.go#L83 - if waiting.reason in ("ContainerCreating", "PodInitializing"): - return sessions_models.SessionState.PENDING + # https://github.com/kubernetes/kubernetes/blob/da215bf06a3b8ac3da4e0adb110dc5acc7f61fe1/pkg/kubelet/kubelet_pods.go#L83 + if waiting.reason in ("ContainerCreating", "PodInitializing"): + return sessions_models.SessionState.PENDING - # Handle errors like ImagePullBackOff properly - return sessions_models.SessionState.FAILED - if state.terminated: - return sessions_models.SessionState.TERMINATED + # Handle errors like ImagePullBackOff properly + return sessions_models.SessionState.FAILED + if state.terminated: + return sessions_models.SessionState.TERMINATED return sessions_models.SessionState.UNKNOWN