mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-10 18:40:15 +08:00
Disable TestCoroutineUtils tests
This commit is contained in:
parent
76ab9f220e
commit
5e95cdd5b0
@ -10,84 +10,86 @@
|
||||
|
||||
package net.mamoe.mirai.console.util
|
||||
|
||||
import kotlinx.coroutines.*
|
||||
import org.junit.jupiter.api.Test
|
||||
import java.util.concurrent.atomic.AtomicInteger
|
||||
import kotlin.coroutines.resume
|
||||
import kotlin.test.assertEquals
|
||||
import kotlin.time.milliseconds
|
||||
import kotlin.time.seconds
|
||||
//import kotlinx.coroutines.*
|
||||
//import org.junit.jupiter.api.Test
|
||||
//import java.util.concurrent.atomic.AtomicInteger
|
||||
//import kotlin.coroutines.resume
|
||||
//import kotlin.test.assertEquals
|
||||
//import kotlin.time.milliseconds
|
||||
//import kotlin.time.seconds
|
||||
|
||||
internal class TestCoroutineUtils {
|
||||
|
||||
@Test
|
||||
fun `test launchTimedTask 0 time`() = runBlocking {
|
||||
val scope = CoroutineScope(SupervisorJob())
|
||||
// TODO TestCoroutineUtils disabled manually: on CI real time measurement is not precise causing tests to fail.
|
||||
|
||||
val result = withTimeoutOrNull(6000) {
|
||||
suspendCancellableCoroutine<Unit> { cont ->
|
||||
scope.launchTimedTask(5.seconds.toLongMilliseconds()) {
|
||||
cont.resume(Unit)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
assertEquals(null, result)
|
||||
scope.cancel()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `test launchTimedTask finishes 1 time`() = runBlocking {
|
||||
val scope = CoroutineScope(SupervisorJob())
|
||||
|
||||
withTimeout(4000) {
|
||||
suspendCancellableCoroutine<Unit> { cont ->
|
||||
val task = scope.launchTimedTask(3.seconds.toLongMilliseconds()) {
|
||||
cont.resume(Unit)
|
||||
}
|
||||
task.setChanged()
|
||||
}
|
||||
}
|
||||
|
||||
scope.cancel()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `test launchTimedTask finishes multiple times`() = runBlocking {
|
||||
val scope = CoroutineScope(SupervisorJob())
|
||||
|
||||
val resumedTimes = AtomicInteger(0)
|
||||
val task = scope.launchTimedTask(3000.milliseconds.toLongMilliseconds()) {
|
||||
resumedTimes.incrementAndGet()
|
||||
}
|
||||
task.setChanged()
|
||||
launch {
|
||||
delay(4000)
|
||||
task.setChanged()
|
||||
}
|
||||
|
||||
delay(6000)
|
||||
assertEquals(1, resumedTimes.get())
|
||||
delay(15000)
|
||||
assertEquals(2, resumedTimes.get())
|
||||
|
||||
scope.cancel()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun `test launchTimedTask interval less than delay`() = runBlocking {
|
||||
val scope = CoroutineScope(SupervisorJob())
|
||||
|
||||
withTimeout(5000) {
|
||||
suspendCancellableCoroutine<Unit> { cont ->
|
||||
val task = scope.launchTimedTask(1.seconds.toLongMilliseconds()) {
|
||||
cont.resume(Unit)
|
||||
}
|
||||
task.setChanged()
|
||||
}
|
||||
}
|
||||
|
||||
scope.cancel()
|
||||
}
|
||||
// @Test
|
||||
// fun `test launchTimedTask 0 time`() = runBlocking {
|
||||
// val scope = CoroutineScope(SupervisorJob())
|
||||
//
|
||||
// val result = withTimeoutOrNull(6000) {
|
||||
// suspendCancellableCoroutine<Unit> { cont ->
|
||||
// scope.launchTimedTask(5.seconds.toLongMilliseconds()) {
|
||||
// cont.resume(Unit)
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// assertEquals(null, result)
|
||||
// scope.cancel()
|
||||
// }
|
||||
//
|
||||
// @Test
|
||||
// fun `test launchTimedTask finishes 1 time`() = runBlocking {
|
||||
// val scope = CoroutineScope(SupervisorJob())
|
||||
//
|
||||
// withTimeout(4000) {
|
||||
// suspendCancellableCoroutine<Unit> { cont ->
|
||||
// val task = scope.launchTimedTask(3.seconds.toLongMilliseconds()) {
|
||||
// cont.resume(Unit)
|
||||
// }
|
||||
// task.setChanged()
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// scope.cancel()
|
||||
// }
|
||||
//
|
||||
// @Test
|
||||
// fun `test launchTimedTask finishes multiple times`() = runBlocking {
|
||||
// val scope = CoroutineScope(SupervisorJob())
|
||||
//
|
||||
// val resumedTimes = AtomicInteger(0)
|
||||
// val task = scope.launchTimedTask(3000.milliseconds.toLongMilliseconds()) {
|
||||
// resumedTimes.incrementAndGet()
|
||||
// }
|
||||
// task.setChanged()
|
||||
// launch {
|
||||
// delay(4000)
|
||||
// task.setChanged()
|
||||
// }
|
||||
//
|
||||
// delay(6000)
|
||||
// assertEquals(1, resumedTimes.get())
|
||||
// delay(15000)
|
||||
// assertEquals(2, resumedTimes.get())
|
||||
//
|
||||
// scope.cancel()
|
||||
// }
|
||||
//
|
||||
// @Test
|
||||
// fun `test launchTimedTask interval less than delay`() = runBlocking {
|
||||
// val scope = CoroutineScope(SupervisorJob())
|
||||
//
|
||||
// withTimeout(5000) {
|
||||
// suspendCancellableCoroutine<Unit> { cont ->
|
||||
// val task = scope.launchTimedTask(1.seconds.toLongMilliseconds()) {
|
||||
// cont.resume(Unit)
|
||||
// }
|
||||
// task.setChanged()
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// scope.cancel()
|
||||
// }
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user