Files
kotlin-fork/libraries/stdlib/test/time/MeasureTimeTest.kt
T
Ilya Gorbunov f889d25287 Introduce TestClock.plusAssign(Duration) and hide implementation details
TestClock.plusAssign(Duration) is for advancing TestClock time.
Hide reading value, do not allow to provide initial reading,
fix clock unit to nanoseconds at construction time.
2019-08-16 15:28:45 +03:00

71 lines
1.8 KiB
Kotlin

/*
* Copyright 2010-2019 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
@file:UseExperimental(ExperimentalTime::class)
package test.time
import kotlin.random.Random
import kotlin.test.*
import kotlin.time.*
class MeasureTimeTest {
private fun longRunningCalc(): String = buildString {
repeat(10) {
while (Random.nextDouble() >= 0.001);
append(('a'..'z').random())
}
}
@Test
fun measureTimeOfCalc() {
val someResult: String
val elapsed = measureTime {
someResult = longRunningCalc()
}
println("elapsed: $elapsed")
assertEquals(10, someResult.length)
assertTrue(elapsed > Duration.ZERO)
}
@Test
fun measureTimeAndResult() {
val someResult: String
val measured: TimedValue<String> = measureTimedValue { longRunningCalc().also { someResult = it } }
println("measured: $measured")
val (result, elapsed) = measured
assertEquals(someResult, result)
assertTrue(elapsed > Duration.ZERO)
}
@Test
fun measureTimeTestClock() {
val clock = TestClock()
val expectedNs = Random.nextLong(1_000_000_000L)
val elapsed = clock.measureTime {
clock += expectedNs.nanoseconds
}
assertEquals(expectedNs.nanoseconds, elapsed)
val expectedResult: Long
val (result, elapsed2) = clock.measureTimedValue {
clock += expectedNs.nanoseconds
expectedResult = expectedNs
expectedNs
}
assertEquals(expectedResult, result)
assertEquals(result.nanoseconds, elapsed2)
}
}