diff options
Diffstat (limited to 'opendc-compute/opendc-compute-failure')
| -rw-r--r-- | opendc-compute/opendc-compute-failure/src/main/kotlin/org/opendc/compute/failure/models/TraceBasedFailureModel.kt | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/opendc-compute/opendc-compute-failure/src/main/kotlin/org/opendc/compute/failure/models/TraceBasedFailureModel.kt b/opendc-compute/opendc-compute-failure/src/main/kotlin/org/opendc/compute/failure/models/TraceBasedFailureModel.kt index cab96cd8..3bd253da 100644 --- a/opendc-compute/opendc-compute-failure/src/main/kotlin/org/opendc/compute/failure/models/TraceBasedFailureModel.kt +++ b/opendc-compute/opendc-compute-failure/src/main/kotlin/org/opendc/compute/failure/models/TraceBasedFailureModel.kt @@ -33,6 +33,7 @@ import java.io.File import java.time.InstantSource import java.util.random.RandomGenerator import kotlin.coroutines.CoroutineContext +import kotlin.time.times /** * A definition of a Failure @@ -71,9 +72,10 @@ public class TraceBasedFailureModel( service: ComputeService, random: RandomGenerator, pathToTrace: String, - private val repeat: Boolean = false, + startPoint: Double, + private val repeat: Boolean = true, ) : FailureModel(context, clock, service, random) { - private val failureList = loadTrace(pathToTrace) + private val failureList = loadTrace(pathToTrace, startPoint) override suspend fun runInjector() { do { @@ -92,7 +94,10 @@ public class TraceBasedFailureModel( * * @param pathToFile */ - private fun loadTrace(pathToFile: String): List<Failure> { + private fun loadTrace( + pathToFile: String, + startPoint: Double, + ): List<Failure> { val trace = Trace.open(File(pathToFile), "failure") val reader = checkNotNull(trace.getTable(TABLE_FAILURES)).newReader() @@ -112,7 +117,8 @@ public class TraceBasedFailureModel( entries.add(Failure(failureStartTime, failureDuration, failureIntensity)) } - return entries + val startIndex: Int = (entries.size * startPoint).toInt() + return entries.subList(startIndex, entries.size) + entries.subList(0, startIndex) } catch (e: Exception) { e.printStackTrace() throw e |
