Skip to content

Commit

Permalink
fixup! Fix K/N EvenLoop.reschedule time conversion
Browse files Browse the repository at this point in the history
  • Loading branch information
qurbonzoda committed Oct 17, 2024
1 parent ed023f6 commit 7eaa68b
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 1 deletion.
18 changes: 18 additions & 0 deletions kotlinx-coroutines-core/concurrent/test/RunBlockingTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ import kotlinx.coroutines.testing.*
import kotlinx.coroutines.exceptions.*
import kotlin.coroutines.*
import kotlin.test.*
import kotlin.time.Duration.Companion.milliseconds
import kotlin.time.Duration.Companion.seconds

class RunBlockingTest : TestBase() {

Expand Down Expand Up @@ -176,4 +178,20 @@ class RunBlockingTest : TestBase() {
}
}
}

/** Tests that the delayed tasks scheduled on a closed `runBlocking` event loop get processed in reasonable time. */
@Test
fun testReschedulingDelayedTasks() {
val job = runBlocking {
val dispatcher = coroutineContext[ContinuationInterceptor]!!
GlobalScope.launch(dispatcher) {
delay(1.milliseconds)
}
}
runBlocking {
withTimeout(10.seconds) {
job.join()
}
}
}
}
2 changes: 1 addition & 1 deletion kotlinx-coroutines-core/native/src/EventLoop.kt
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ internal actual abstract class EventLoopImplPlatform : EventLoop() {
}

protected actual fun reschedule(now: Long, delayedTask: EventLoopImplBase.DelayedTask) {
val delayTimeMillis = delayNanosToMillis(nanoTime() - now)
val delayTimeMillis = delayNanosToMillis(delayedTask.nanoTime - now)
DefaultExecutor.invokeOnTimeout(delayTimeMillis, delayedTask, EmptyCoroutineContext)
}
}
Expand Down

0 comments on commit 7eaa68b

Please sign in to comment.