f624800b84
I was forced to manually do update the following files, because otherwise they would be ignored according .gitignore settings. Probably they should be deleted from repo. Interop/.idea/compiler.xml Interop/.idea/gradle.xml Interop/.idea/libraries/Gradle__org_jetbrains_kotlin_kotlin_runtime_1_0_3.xml Interop/.idea/libraries/Gradle__org_jetbrains_kotlin_kotlin_stdlib_1_0_3.xml Interop/.idea/modules.xml Interop/.idea/modules/Indexer/Indexer.iml Interop/.idea/modules/Runtime/Runtime.iml Interop/.idea/modules/StubGenerator/StubGenerator.iml backend.native/backend.native.iml backend.native/bc.frontend/bc.frontend.iml backend.native/cli.bc/cli.bc.iml backend.native/cli.bc/src/org/jetbrains/kotlin/cli/bc/K2Native.kt backend.native/cli.bc/src/org/jetbrains/kotlin/cli/bc/K2NativeCompilerArguments.kt backend.native/tests/link/lib/foo.kt backend.native/tests/link/lib/foo2.kt backend.native/tests/teamcity-test.property
47 lines
1.2 KiB
Kotlin
47 lines
1.2 KiB
Kotlin
package runtime.workers.mutableData1
|
|
|
|
import kotlin.native.concurrent.*
|
|
import kotlin.test.*
|
|
|
|
// See https://youtrack.jetbrains.com/issue/KT-39145
|
|
@Test
|
|
fun kt39145_1() = withWorker {
|
|
execute(TransferMode.SAFE, { "test" }) {
|
|
val data = MutableData(1_000)
|
|
val bytes = byteArrayOf(0, 10, 20, 30)
|
|
data.append(bytes, 0, 4)
|
|
assertEquals(4, data.size)
|
|
|
|
assertContentsEquals(bytes, data)
|
|
}.result
|
|
}
|
|
|
|
@Test
|
|
fun kt39145_2() = withWorker {
|
|
val externalData = MutableData(1_000)
|
|
execute(TransferMode.SAFE, { externalData }) {
|
|
val bytes = byteArrayOf(0, 10, 20, 30)
|
|
it.append(bytes, 0, 4)
|
|
assertEquals(4, it.size)
|
|
|
|
assertContentsEquals(bytes, it)
|
|
}.result
|
|
}
|
|
|
|
@Test
|
|
fun kt39145_3() {
|
|
val mainThreadData = MutableData(1_000)
|
|
val bytes = byteArrayOf(0, 10, 20, 30)
|
|
mainThreadData.append(bytes, 0, 4)
|
|
assertEquals(4, mainThreadData.size)
|
|
|
|
assertContentsEquals(bytes, mainThreadData)
|
|
}
|
|
|
|
private fun assertContentsEquals(expected: ByteArray, actual: MutableData) {
|
|
assertEquals(expected.size, actual.size)
|
|
|
|
expected.forEachIndexed { index, byte ->
|
|
assertEquals(byte, actual.get(index))
|
|
}
|
|
} |