From 11a808a2e0c33eaae80814440b1ccd4e54a3c49e Mon Sep 17 00:00:00 2001 From: Benoit Marty Date: Thu, 23 Oct 2025 16:37:16 +0200 Subject: [PATCH] Add test on `wasLastSession` value. --- .../libraries/sessionstorage/impl/Fixtures.kt | 6 +++-- .../observer/DefaultSessionObserverTest.kt | 26 +++++++++++++++++-- .../impl/observer/TestSessionListener.kt | 4 +-- 3 files changed, 30 insertions(+), 6 deletions(-) diff --git a/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/Fixtures.kt b/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/Fixtures.kt index 165a91b5b5..2fd9900bdf 100644 --- a/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/Fixtures.kt +++ b/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/Fixtures.kt @@ -10,8 +10,10 @@ package io.element.android.libraries.sessionstorage.impl import io.element.android.libraries.matrix.session.SessionData import io.element.android.libraries.sessionstorage.api.LoginType -internal fun aDbSessionData() = SessionData( - userId = "userId", +internal fun aDbSessionData( + userId: String = "userId", +) = SessionData( + userId = userId, deviceId = "deviceId", accessToken = "accessToken", refreshToken = "refreshToken", diff --git a/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/DefaultSessionObserverTest.kt b/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/DefaultSessionObserverTest.kt index f833f146a4..e9910cbe77 100644 --- a/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/DefaultSessionObserverTest.kt +++ b/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/DefaultSessionObserverTest.kt @@ -23,7 +23,8 @@ import kotlinx.coroutines.test.runTest import org.junit.Before import org.junit.Test -@OptIn(ExperimentalCoroutinesApi::class) class DefaultSessionObserverTest { +@OptIn(ExperimentalCoroutinesApi::class) +class DefaultSessionObserverTest { private lateinit var database: SessionDatabase private lateinit var databaseSessionStore: DatabaseSessionStore @@ -69,7 +70,28 @@ import org.junit.Test databaseSessionStore.removeSession(sessionData.userId) listener.assertEvents( TestSessionListener.Event.Created(sessionData.userId), - TestSessionListener.Event.Deleted(sessionData.userId), + TestSessionListener.Event.Deleted(sessionData.userId, true), + ) + coroutineContext.cancelChildren() + } + + @Test + fun `adding and deleting data twice invokes onSessionCreated and onSessionDeleted`() = runTest { + val sessionData1 = aDbSessionData(userId = "user1") + val sessionData2 = aDbSessionData(userId = "user2") + val sut = createDefaultSessionObserver() + runCurrent() + val listener = TestSessionListener() + sut.addListener(listener) + databaseSessionStore.addSession(sessionData1.toApiModel()) + databaseSessionStore.addSession(sessionData2.toApiModel()) + databaseSessionStore.removeSession(sessionData2.userId) + databaseSessionStore.removeSession(sessionData1.userId) + listener.assertEvents( + TestSessionListener.Event.Created(sessionData1.userId), + TestSessionListener.Event.Created(sessionData2.userId), + TestSessionListener.Event.Deleted(sessionData2.userId, wasLastSession = false), + TestSessionListener.Event.Deleted(sessionData1.userId, wasLastSession = true), ) coroutineContext.cancelChildren() } diff --git a/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/TestSessionListener.kt b/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/TestSessionListener.kt index b08c7ffa6e..87bebf63b5 100644 --- a/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/TestSessionListener.kt +++ b/libraries/session-storage/impl/src/test/kotlin/io/element/android/libraries/sessionstorage/impl/observer/TestSessionListener.kt @@ -13,7 +13,7 @@ import io.element.android.libraries.sessionstorage.api.observer.SessionListener class TestSessionListener : SessionListener { sealed interface Event { data class Created(val userId: String) : Event - data class Deleted(val userId: String) : Event + data class Deleted(val userId: String, val wasLastSession: Boolean) : Event } private val trackRecord: MutableList = mutableListOf() @@ -23,7 +23,7 @@ class TestSessionListener : SessionListener { } override suspend fun onSessionDeleted(userId: String, wasLastSession: Boolean) { - trackRecord.add(Event.Deleted(userId)) + trackRecord.add(Event.Deleted(userId, wasLastSession)) } fun assertEvents(vararg events: Event) {