summaryrefslogtreecommitdiff
path: root/opendc-experiments/opendc-experiments-base/src
diff options
context:
space:
mode:
Diffstat (limited to 'opendc-experiments/opendc-experiments-base/src')
-rw-r--r--opendc-experiments/opendc-experiments-base/src/main/kotlin/org/opendc/experiments/base/experiment/specs/FailureModelSpec.kt12
-rw-r--r--opendc-experiments/opendc-experiments-base/src/test/kotlin/org/opendc/experiments/base/ScenarioIntegrationTest.kt8
2 files changed, 18 insertions, 2 deletions
diff --git a/opendc-experiments/opendc-experiments-base/src/main/kotlin/org/opendc/experiments/base/experiment/specs/FailureModelSpec.kt b/opendc-experiments/opendc-experiments-base/src/main/kotlin/org/opendc/experiments/base/experiment/specs/FailureModelSpec.kt
index 520d7e3d..4a1add59 100644
--- a/opendc-experiments/opendc-experiments-base/src/main/kotlin/org/opendc/experiments/base/experiment/specs/FailureModelSpec.kt
+++ b/opendc-experiments/opendc-experiments-base/src/main/kotlin/org/opendc/experiments/base/experiment/specs/FailureModelSpec.kt
@@ -78,6 +78,12 @@ public sealed interface FailureModelSpec {
public var name: String
}
+@Serializable
+@SerialName("no")
+public data class NoFailureModel(
+ override var name: String = "no failure model",
+) : FailureModelSpec
+
/**
* A failure model spec for failure models based on a failure trace.
*
@@ -87,11 +93,15 @@ public sealed interface FailureModelSpec {
@SerialName("trace-based")
public data class TraceBasedFailureModelSpec(
public val pathToFile: String,
+ public val startPoint: Double = 0.0,
+ public val repeat: Boolean = true,
) : FailureModelSpec {
override var name: String = File(pathToFile).nameWithoutExtension
init {
require(File(pathToFile).exists()) { "Path to file $pathToFile does not exist" }
+ require(startPoint < 1.0) { "Starting point must be smaller than 1.0" }
+ require(startPoint >= 0.0) { "Starting point must be equal or larger than 0.0" }
}
}
@@ -267,7 +277,7 @@ public fun createFailureModel(
random: java.util.random.RandomGenerator,
failureModel: TraceBasedFailureModelSpec,
): FailureModel {
- return TraceBasedFailureModel(context, clock, service, random, failureModel.pathToFile)
+ return TraceBasedFailureModel(context, clock, service, random, failureModel.pathToFile, failureModel.startPoint, failureModel.repeat)
}
/**
diff --git a/opendc-experiments/opendc-experiments-base/src/test/kotlin/org/opendc/experiments/base/ScenarioIntegrationTest.kt b/opendc-experiments/opendc-experiments-base/src/test/kotlin/org/opendc/experiments/base/ScenarioIntegrationTest.kt
index bffd9624..abf16fef 100644
--- a/opendc-experiments/opendc-experiments-base/src/test/kotlin/org/opendc/experiments/base/ScenarioIntegrationTest.kt
+++ b/opendc-experiments/opendc-experiments-base/src/test/kotlin/org/opendc/experiments/base/ScenarioIntegrationTest.kt
@@ -135,7 +135,11 @@ class ScenarioIntegrationTest {
val workload = createTestWorkload("single_task", 1.0, seed)
val topology = createTopology("single.json")
val monitor = monitor
- val failureModelSpec = TraceBasedFailureModelSpec("src/test/resources/failureTraces/single_failure.parquet")
+ val failureModelSpec =
+ TraceBasedFailureModelSpec(
+ "src/test/resources/failureTraces/single_failure.parquet",
+ repeat = false,
+ )
Provisioner(dispatcher, seed).use { provisioner ->
provisioner.runSteps(
@@ -145,6 +149,8 @@ class ScenarioIntegrationTest {
)
val service = provisioner.registry.resolve("compute.opendc.org", ComputeService::class.java)!!
+ service.setTasksExpected(workload.size)
+
service.replay(timeSource, workload, failureModelSpec = failureModelSpec, seed = seed)
}