jvmTest.AtomicCancellationTest.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlinx-coroutines-core-metadata Show documentation
Show all versions of kotlinx-coroutines-core-metadata Show documentation
Coroutines support libraries for Kotlin
/*
* Copyright 2016-2018 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
package kotlinx.coroutines
import kotlinx.coroutines.channels.*
import kotlinx.coroutines.selects.*
import kotlin.test.*
class AtomicCancellationTest : TestBase() {
@Test
fun testSendAtomicCancel() = runBlocking {
expect(1)
val channel = Channel()
val job = launch(start = CoroutineStart.UNDISPATCHED) {
expect(2)
channel.send(42) // suspends
expect(4) // should execute despite cancellation
}
expect(3)
assertEquals(42, channel.receive()) // will schedule sender for further execution
job.cancel() // cancel the job next
yield() // now yield
finish(5)
}
@Test
fun testSelectSendAtomicCancel() = runBlocking {
expect(1)
val channel = Channel()
val job = launch(start = CoroutineStart.UNDISPATCHED) {
expect(2)
val result = select { // suspends
channel.onSend(42) {
expect(4)
"OK"
}
}
assertEquals("OK", result)
expect(5) // should execute despite cancellation
}
expect(3)
assertEquals(42, channel.receive()) // will schedule sender for further execution
job.cancel() // cancel the job next
yield() // now yield
finish(6)
}
@Test
fun testReceiveAtomicCancel() = runBlocking {
expect(1)
val channel = Channel()
val job = launch(start = CoroutineStart.UNDISPATCHED) {
expect(2)
assertEquals(42, channel.receive()) // suspends
expect(4) // should execute despite cancellation
}
expect(3)
channel.send(42) // will schedule receiver for further execution
job.cancel() // cancel the job next
yield() // now yield
finish(5)
}
@Test
fun testSelectReceiveAtomicCancel() = runBlocking {
expect(1)
val channel = Channel()
val job = launch(start = CoroutineStart.UNDISPATCHED) {
expect(2)
val result = select { // suspends
channel.onReceive {
assertEquals(42, it)
expect(4)
"OK"
}
}
assertEquals("OK", result)
expect(5) // should execute despite cancellation
}
expect(3)
channel.send(42) // will schedule receiver for further execution
job.cancel() // cancel the job next
yield() // now yield
finish(6)
}
@Test
fun testSelectDeferredAwaitCancellable() = runBlocking {
expect(1)
val deferred = async { // deferred, not yet complete
expect(4)
"OK"
}
assertEquals(false, deferred.isCompleted)
var job: Job? = null
launch { // will cancel job as soon as deferred completes
expect(5)
assertEquals(true, deferred.isCompleted)
job!!.cancel()
}
job = launch(start = CoroutineStart.UNDISPATCHED) {
expect(2)
try {
select { // suspends
deferred.onAwait { expectUnreached() }
}
expectUnreached() // will not execute -- cancelled while dispatched
} finally {
finish(7) // but will execute finally blocks
}
}
expect(3) // continues to execute when the job suspends
yield() // to deferred & canceller
expect(6)
}
@Test
fun testSelectJobJoinCancellable() = runBlocking {
expect(1)
val jobToJoin = launch { // not yet complete
expect(4)
}
assertEquals(false, jobToJoin.isCompleted)
var job: Job? = null
launch { // will cancel job as soon as jobToJoin completes
expect(5)
assertEquals(true, jobToJoin.isCompleted)
job!!.cancel()
}
job = launch(start = CoroutineStart.UNDISPATCHED) {
expect(2)
try {
select { // suspends
jobToJoin.onJoin { expectUnreached() }
}
expectUnreached() // will not execute -- cancelled while dispatched
} finally {
finish(7) // but will execute finally blocks
}
}
expect(3) // continues to execute when the job suspends
yield() // to jobToJoin & canceller
expect(6)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy