From 1466a02ebacfcbc9fe4e71b00d36f03d8ea14840 Mon Sep 17 00:00:00 2001 From: JI HUN LEE <51016231+easyhooon@users.noreply.github.com> Date: Mon, 22 Apr 2024 20:50:23 +0900 Subject: [PATCH 1/2] =?UTF-8?q?fix:=20flow=20=EB=B0=98=ED=99=98=20?= =?UTF-8?q?=ED=83=80=EC=9E=85=20=ED=95=A8=EC=88=98=20suspend=20=ED=82=A4?= =?UTF-8?q?=EC=9B=8C=EB=93=9C=20=EC=A0=9C=EA=B1=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../app/core/data/repository/DefaultSessionRepository.kt | 2 +- .../droidknights/app/core/data/repository/SessionRepository.kt | 2 +- .../app/core/domain/usecase/GetBookmarkedSessionIdsUseCase.kt | 2 +- .../app/core/domain/usecase/FakeSessionRepository.kt | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/core/data/src/main/java/com/droidknights/app/core/data/repository/DefaultSessionRepository.kt b/core/data/src/main/java/com/droidknights/app/core/data/repository/DefaultSessionRepository.kt index 0582667e..7231f514 100644 --- a/core/data/src/main/java/com/droidknights/app/core/data/repository/DefaultSessionRepository.kt +++ b/core/data/src/main/java/com/droidknights/app/core/data/repository/DefaultSessionRepository.kt @@ -33,7 +33,7 @@ internal class DefaultSessionRepository @Inject constructor( ?: error("Session not found with id: $sessionId") } - override suspend fun getBookmarkedSessionIds(): Flow> { + override fun getBookmarkedSessionIds(): Flow> { return bookmarkIds.filterNotNull() } diff --git a/core/data/src/main/java/com/droidknights/app/core/data/repository/SessionRepository.kt b/core/data/src/main/java/com/droidknights/app/core/data/repository/SessionRepository.kt index cd61ad8b..b32c025b 100644 --- a/core/data/src/main/java/com/droidknights/app/core/data/repository/SessionRepository.kt +++ b/core/data/src/main/java/com/droidknights/app/core/data/repository/SessionRepository.kt @@ -9,7 +9,7 @@ interface SessionRepository { suspend fun getSession(sessionId: String): Session - suspend fun getBookmarkedSessionIds(): Flow> + fun getBookmarkedSessionIds(): Flow> suspend fun bookmarkSession(sessionId: String, bookmark: Boolean) } diff --git a/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionIdsUseCase.kt b/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionIdsUseCase.kt index 1f08ff03..cf67b859 100644 --- a/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionIdsUseCase.kt +++ b/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionIdsUseCase.kt @@ -8,7 +8,7 @@ class GetBookmarkedSessionIdsUseCase @Inject constructor( private val sessionRepository: SessionRepository, ) { - suspend operator fun invoke(): Flow> { + operator fun invoke(): Flow> { return sessionRepository.getBookmarkedSessionIds() } } diff --git a/core/domain/src/test/java/com/droidknights/app/core/domain/usecase/FakeSessionRepository.kt b/core/domain/src/test/java/com/droidknights/app/core/domain/usecase/FakeSessionRepository.kt index 9841660f..5b7d1b04 100644 --- a/core/domain/src/test/java/com/droidknights/app/core/domain/usecase/FakeSessionRepository.kt +++ b/core/domain/src/test/java/com/droidknights/app/core/domain/usecase/FakeSessionRepository.kt @@ -18,7 +18,7 @@ internal class FakeSessionRepository( return sessions.first { it.id == sessionId } } - override suspend fun getBookmarkedSessionIds(): Flow> { + override fun getBookmarkedSessionIds(): Flow> { return flow { emit(bookmarkedSessionIds) } } From e98576b9dc7b3444d3dce8681e32a954ba662836 Mon Sep 17 00:00:00 2001 From: JI HUN LEE <51016231+easyhooon@users.noreply.github.com> Date: Mon, 22 Apr 2024 21:42:10 +0900 Subject: [PATCH 2/2] fix: unit test error --- .../app/core/domain/usecase/GetBookmarkedSessionsUseCase.kt | 2 +- .../droidknights/app/core/domain/usecase/GetSessionsUseCase.kt | 2 +- .../droidknights/app/feature/session/SessionViewModelTest.kt | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionsUseCase.kt b/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionsUseCase.kt index 9edf3b48..f571b58f 100644 --- a/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionsUseCase.kt +++ b/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetBookmarkedSessionsUseCase.kt @@ -10,7 +10,7 @@ class GetBookmarkedSessionsUseCase @Inject constructor( private val getBookmarkedSessionIdsUseCase: GetBookmarkedSessionIdsUseCase, ) { - suspend operator fun invoke(): Flow> = + operator fun invoke(): Flow> = combine( getSessionsUseCase(), getBookmarkedSessionIdsUseCase() diff --git a/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetSessionsUseCase.kt b/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetSessionsUseCase.kt index 774acc71..34cefacf 100644 --- a/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetSessionsUseCase.kt +++ b/core/domain/src/main/java/com/droidknights/app/core/domain/usecase/GetSessionsUseCase.kt @@ -9,7 +9,7 @@ import kotlinx.coroutines.flow.flow class GetSessionsUseCase @Inject constructor( private val sessionRepository: SessionRepository, ) { - suspend operator fun invoke(): Flow> { + operator fun invoke(): Flow> { return flow { emit(sessionRepository.getSessions()) } diff --git a/feature/session/src/test/java/com/droidknights/app/feature/session/SessionViewModelTest.kt b/feature/session/src/test/java/com/droidknights/app/feature/session/SessionViewModelTest.kt index ec82509e..95a1b6f4 100644 --- a/feature/session/src/test/java/com/droidknights/app/feature/session/SessionViewModelTest.kt +++ b/feature/session/src/test/java/com/droidknights/app/feature/session/SessionViewModelTest.kt @@ -41,7 +41,7 @@ internal class SessionViewModelTest { @Test fun `세션 데이터를 확인할 수 있다`() = runTest { // given - coEvery { getSessionsUseCase() } returns listOf(fakeSession) + coEvery { getSessionsUseCase() } returns flowOf(listOf(fakeSession)) coEvery { getBookmarkedSessionIdsUseCase() } returns flowOf(emptySet()) viewModel = SessionViewModel(getSessionsUseCase, getBookmarkedSessionIdsUseCase)