Michal Klimczak
11/13/2020, 7:26 AM@Test
    fun `stateIn self-contained example`() = runBlockingTest {
        suspend fun makeHeavyRequest(): String {
            return "heavy result"
        }
        val flow = flow<Unit> {} //in production this is a channel meant to refresh the Flow
            .onStart { emit(Unit) }
            .map { makeHeavyRequest() } //using mapLatest breaks 
            .flowOn(testDispatcher)
//            .onEach {  } //uncommenting this line also breaks
            .stateIn(GlobalScope, SharingStarted.WhileSubscribed(), "init state")
        val results = mutableListOf<String>()
        val job = launch {
            flow.collect { results.add(it) }
        }
        assertEquals("heavy result", results[0])
        job.cancel()
    }init stateheavy resultmapLatestmapinit stateheavy resultonEachflowOninit stateheavy resultAsagald
11/13/2020, 9:22 AMGlobalScopestateInShalom Halbert
11/13/2020, 10:45 AMStateFlowSharedFlowFlowMichal Klimczak
11/13/2020, 11:28 AMMichal Klimczak
11/13/2020, 11:29 AMMichal Klimczak
11/13/2020, 11:32 AMShalom Halbert
11/13/2020, 12:33 PMGlobalScopeFlowCoroutineScoperunBlockingTestrunBlockingTestFlowCoroutineScopeFlowFlowStateFlowFlowexpectItem()cancelAndIgnoreRemainingEvents()Michal Klimczak
11/13/2020, 2:37 PMMichal Klimczak
11/13/2020, 2:52 PM@Test
    fun `stateFlow (turbine)`() = runBlockingTest {
        suspend fun makeHeavyRequest(): String {
            return "heavy result"
        }
        val flow = flow<Unit> {}
            .onStart { emit(Unit) }
            .map { makeHeavyRequest() }
            .onEach { logThread("before flowOn") }
            .flowOn(testDispatcher)
            .onEach { logThread("after flowOn") } //why this changes the dispatcher for the whole thing?
            .stateIn(this, SharingStarted.WhileSubscribed(), "init state")
        flow.test {
            assertEquals("heavy result", expectItem())
            cancelAndIgnoreRemainingEvents()
        }
    }kotlinx.coroutines.test.UncompletedCoroutinesError: Test finished with active jobs: ["coroutine#6":StandaloneCoroutine{Active}@409bf450]Michal Klimczak
11/13/2020, 3:23 PM