summaryrefslogtreecommitdiff
path: root/opendc-simulator/opendc-simulator-compute/src/test
diff options
context:
space:
mode:
authorFabian Mastenbroek <mail.fabianm@gmail.com>2021-06-10 17:32:43 +0200
committerFabian Mastenbroek <mail.fabianm@gmail.com>2021-06-11 17:05:10 +0200
commit1768292251957da5ce6411ecc7d2dffebf8709c8 (patch)
treee79f01046233efbbc2c8ec5432e23789e7ca0346 /opendc-simulator/opendc-simulator-compute/src/test
parentf0c0c6d45165ad0ce398ec7300b11bf77c7ae5a6 (diff)
simulator: Integrate power subsystem with compute subsystem
This change integrates the power subsystem of the simulator with the compute subsystem by exposing a new field on a SimBareMetalMachine, psu, which provides access to the machine's PSU, which in turn can be connected to a SimPowerOutlet.
Diffstat (limited to 'opendc-simulator/opendc-simulator-compute/src/test')
-rw-r--r--opendc-simulator/opendc-simulator-compute/src/test/kotlin/org/opendc/simulator/compute/SimMachineTest.kt9
1 files changed, 7 insertions, 2 deletions
diff --git a/opendc-simulator/opendc-simulator-compute/src/test/kotlin/org/opendc/simulator/compute/SimMachineTest.kt b/opendc-simulator/opendc-simulator-compute/src/test/kotlin/org/opendc/simulator/compute/SimMachineTest.kt
index 0c686aa0..b9cfb06b 100644
--- a/opendc-simulator/opendc-simulator-compute/src/test/kotlin/org/opendc/simulator/compute/SimMachineTest.kt
+++ b/opendc-simulator/opendc-simulator-compute/src/test/kotlin/org/opendc/simulator/compute/SimMachineTest.kt
@@ -40,6 +40,7 @@ import org.opendc.simulator.compute.util.SimWorkloadLifecycle
import org.opendc.simulator.compute.workload.SimFlopsWorkload
import org.opendc.simulator.compute.workload.SimWorkload
import org.opendc.simulator.core.runBlockingSimulation
+import org.opendc.simulator.power.SimPowerSource
import org.opendc.simulator.resources.SimResourceInterpreter
import org.opendc.simulator.resources.consumer.SimWorkConsumer
@@ -142,16 +143,20 @@ class SimMachineTest {
@Test
fun testPower() = runBlockingSimulation {
+ val interpreter = SimResourceInterpreter(coroutineContext, clock)
val machine = SimBareMetalMachine(
- SimResourceInterpreter(coroutineContext, clock),
+ interpreter,
machineModel,
SimplePowerDriver(LinearPowerModel(100.0, 50.0))
)
+ val source = SimPowerSource(interpreter, capacity = 1000.0)
+ source.connect(machine.psu)
try {
coroutineScope {
launch { machine.run(SimFlopsWorkload(2_000, utilization = 1.0)) }
- assertEquals(100.0, machine.powerDraw)
+ assertEquals(100.0, machine.psu.powerDraw)
+ assertEquals(100.0, source.powerDraw)
}
} finally {
machine.close()