From 35113c0b0c9f7b581d640da10568b9557ed5c6c7 Mon Sep 17 00:00:00 2001 From: Marco Collovati Date: Fri, 15 Nov 2024 15:28:03 +0100 Subject: [PATCH] fix: prevent sending null session to backend connector --- .../kubernetes/starter/sessiontracker/SessionSerializer.java | 4 +++- .../starter/sessiontracker/SessionSerializerTest.java | 3 ++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/kubernetes-kit-starter/src/main/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializer.java b/kubernetes-kit-starter/src/main/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializer.java index 5faa872..5c2591f 100644 --- a/kubernetes-kit-starter/src/main/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializer.java +++ b/kubernetes-kit-starter/src/main/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializer.java @@ -279,7 +279,9 @@ private void queueSerialization(String sessionId, sessionId, clusterKey, error); } else { Consumer whenSerialized = sessionInfo -> { - backendConnector.sendSession(sessionInfo); + if (sessionInfo != null) { + backendConnector.sendSession(sessionInfo); + } backendConnector .markSerializationComplete(clusterKey); }; diff --git a/kubernetes-kit-starter/src/test/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializerTest.java b/kubernetes-kit-starter/src/test/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializerTest.java index a48038d..4b13b95 100644 --- a/kubernetes-kit-starter/src/test/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializerTest.java +++ b/kubernetes-kit-starter/src/test/java/com/vaadin/kubernetes/starter/sessiontracker/SessionSerializerTest.java @@ -291,7 +291,8 @@ void serialize_notSerializableException_notFallbackToPessimistic() { verify(connector).markSerializationStarted(clusterSID); await().atMost(500, MILLISECONDS).untilTrue(serializationCompleted); - verify(connector).sendSession(isNull()); + verify(connector, never()).sendSession(any()); + verify(connector).markSerializationComplete(clusterSID); locks.forEach(l -> verify(l, never()).lock()); }