From 228d6c0ebd4233cd8484befd55b0d512b0106f34 Mon Sep 17 00:00:00 2001 From: Archish Thakkar Date: Thu, 4 Jul 2024 12:24:16 +0530 Subject: [PATCH] :bug: fix for timer getting reset on retrival of session id --- .../io/opentelemetry/android/SessionId.java | 2 +- .../opentelemetry/android/SessionIdTest.java | 27 ++++++++++++++++--- 2 files changed, 24 insertions(+), 5 deletions(-) diff --git a/android-agent/src/main/java/io/opentelemetry/android/SessionId.java b/android-agent/src/main/java/io/opentelemetry/android/SessionId.java index 50f8c32f3..aa89afbe6 100644 --- a/android-agent/src/main/java/io/opentelemetry/android/SessionId.java +++ b/android-agent/src/main/java/io/opentelemetry/android/SessionId.java @@ -62,9 +62,9 @@ String getSessionId() { } // value will never be null currentValue = requireNonNull(value.get()); + timeoutHandler.bump(); } - timeoutHandler.bump(); // sessionId change listener needs to be called after bumping the timer because it may // create a new span SessionIdChangeListener sessionIdChangeListener = this.sessionIdChangeListener; diff --git a/android-agent/src/test/java/io/opentelemetry/android/SessionIdTest.java b/android-agent/src/test/java/io/opentelemetry/android/SessionIdTest.java index 663c30463..9c9d43b25 100644 --- a/android-agent/src/test/java/io/opentelemetry/android/SessionIdTest.java +++ b/android-agent/src/test/java/io/opentelemetry/android/SessionIdTest.java @@ -6,6 +6,7 @@ package io.opentelemetry.android; import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotEquals; import static org.junit.jupiter.api.Assertions.assertNotNull; import static org.junit.jupiter.api.Assertions.assertTrue; @@ -69,7 +70,7 @@ void shouldCallSessionIdChangeListener() { String firstSessionId = sessionId.getSessionId(); clock.advance(3, TimeUnit.HOURS); sessionId.getSessionId(); - verify(timeoutHandler, times(2)).bump(); + verify(timeoutHandler, times(0)).bump(); verify(listener, never()).onChange(anyString(), anyString()); clock.advance(1, TimeUnit.HOURS); @@ -85,14 +86,32 @@ void shouldCreateNewSessionIdAfterTimeout() { SessionId sessionId = new SessionId(timeoutHandler); String value = sessionId.getSessionId(); - verify(timeoutHandler).bump(); assertEquals(value, sessionId.getSessionId()); - verify(timeoutHandler, times(2)).bump(); + verify(timeoutHandler, times(0)).bump(); when(timeoutHandler.hasTimedOut()).thenReturn(true); assertNotEquals(value, sessionId.getSessionId()); - verify(timeoutHandler, times(3)).bump(); + verify(timeoutHandler, times(1)).bump(); + } + + @Test + void shouldNotUpdateSessionIdInForeground() { + timeoutHandler.onApplicationForegrounded(); + SessionId sessionId = new SessionId(timeoutHandler); + String value = sessionId.getSessionId(); + assertEquals(value, sessionId.getSessionId()); + assertFalse(timeoutHandler.hasTimedOut()); + } + + @Test + void shouldUpdateSessionIdIfTimeoutAndInBackground() { + timeoutHandler.onApplicationBackgrounded(); + SessionId sessionId = new SessionId(timeoutHandler); + when(timeoutHandler.hasTimedOut()).thenReturn(true); + String value = sessionId.getSessionId(); + assertTrue(timeoutHandler.hasTimedOut()); + assertNotEquals(value, sessionId.getSessionId()); } }