blob: d0aa60517b92e2ac294ea6020d4ac81a371b7ed7 [file] [log] [blame]
/*
* Copyright 2016-2018 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
package kotlinx.coroutines.experimental.reactor
import kotlinx.coroutines.experimental.CommonPool
import kotlinx.coroutines.experimental.TestBase
import kotlinx.coroutines.experimental.reactive.consumeEach
import kotlinx.coroutines.experimental.runBlocking
import kotlinx.coroutines.experimental.withTimeout
import org.junit.Test
import java.util.Random
import kotlin.coroutines.experimental.CoroutineContext
class FluxCompletionStressTest : TestBase() {
val N_REPEATS = 10_000 * stressTestMultiplier
fun range(context: CoroutineContext, start: Int, count: Int) = flux(context) {
for (x in start until start + count) send(x)
}
@Test
fun testCompletion() {
val rnd = Random()
repeat(N_REPEATS) {
val count = rnd.nextInt(5)
runBlocking {
withTimeout(5000) {
var received = 0
range(CommonPool, 1, count).consumeEach { x ->
received++
if (x != received) error("$x != $received")
}
if (received != count) error("$received != $count")
}
}
}
}
}