forked from boskworks/bosk
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
2 changed files
with
100 additions
and
0 deletions.
There are no files selected for viewing
90 changes: 90 additions & 0 deletions
90
bosk-testing/src/main/java/io/vena/bosk/drivers/JitterDriver.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
package io.vena.bosk.drivers; | ||
|
||
import io.vena.bosk.BoskDriver; | ||
import io.vena.bosk.DriverFactory; | ||
import io.vena.bosk.Identifier; | ||
import io.vena.bosk.Reference; | ||
import io.vena.bosk.StateTreeNode; | ||
import io.vena.bosk.exceptions.InvalidTypeException; | ||
import java.io.IOException; | ||
import java.lang.reflect.Type; | ||
import java.util.Random; | ||
import java.util.function.DoubleSupplier; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
|
||
public final class JitterDriver<R extends StateTreeNode> implements BoskDriver<R> { | ||
private final BoskDriver<R> downstream; | ||
private final DoubleSupplier jitter; | ||
|
||
public static <RR extends StateTreeNode> DriverFactory<RR> factory(double meanMillis, double limitMillis, long seed) { | ||
return (b,d) -> new JitterDriver<>(d, meanMillis, limitMillis, seed); | ||
} | ||
|
||
private JitterDriver(BoskDriver<R> downstream, double meanMillis, double limitMillis, long seed) { | ||
this.downstream = downstream; | ||
Random random = new Random(seed); | ||
|
||
https://en.wikipedia.org/wiki/Exponential_distribution#Random_variate_generation | ||
jitter = ()-> Double.min(limitMillis, | ||
-Math.log(random.nextDouble()) * meanMillis | ||
); | ||
} | ||
|
||
private void sleep() { | ||
try { | ||
long totalNanos = (long)(1e6 * jitter.getAsDouble()); | ||
long ms = totalNanos / 1_000_000; | ||
int nanos = (int) (totalNanos % 1_000_000); | ||
LOGGER.trace("Sleeping for {} ms", totalNanos/1e6); | ||
Thread.sleep(ms, nanos); | ||
LOGGER.trace("Done sleeping"); | ||
} catch (InterruptedException e) { | ||
LOGGER.debug("Sleep interrupted", e); | ||
} | ||
} | ||
|
||
@Override | ||
public R initialRoot(Type rootType) throws InvalidTypeException, IOException, InterruptedException { | ||
sleep(); | ||
return downstream.initialRoot(rootType); | ||
} | ||
|
||
@Override | ||
public <T> void submitReplacement(Reference<T> target, T newValue) { | ||
sleep(); | ||
downstream.submitReplacement(target, newValue); | ||
} | ||
|
||
@Override | ||
public <T> void submitConditionalReplacement(Reference<T> target, T newValue, Reference<Identifier> precondition, Identifier requiredValue) { | ||
sleep(); | ||
downstream.submitConditionalReplacement(target, newValue, precondition, requiredValue); | ||
} | ||
|
||
@Override | ||
public <T> void submitInitialization(Reference<T> target, T newValue) { | ||
sleep(); | ||
downstream.submitInitialization(target, newValue); | ||
} | ||
|
||
@Override | ||
public <T> void submitDeletion(Reference<T> target) { | ||
sleep(); | ||
downstream.submitDeletion(target); | ||
} | ||
|
||
@Override | ||
public <T> void submitConditionalDeletion(Reference<T> target, Reference<Identifier> precondition, Identifier requiredValue) { | ||
sleep(); | ||
downstream.submitConditionalDeletion(target, precondition, requiredValue); | ||
} | ||
|
||
@Override | ||
public void flush() throws IOException, InterruptedException { | ||
sleep(); | ||
downstream.flush(); | ||
} | ||
|
||
private static final Logger LOGGER = LoggerFactory.getLogger(JitterDriver.class); | ||
} |
10 changes: 10 additions & 0 deletions
10
bosk-testing/src/test/java/io/vena/bosk/drivers/JitterDriverConformanceTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
package io.vena.bosk.drivers; | ||
|
||
import org.junit.jupiter.api.BeforeEach; | ||
|
||
class JitterDriverConformanceTest extends DriverConformanceTest { | ||
@BeforeEach | ||
void setupDriverFactory() { | ||
driverFactory = JitterDriver.factory(0.1, 0.5, 123); | ||
} | ||
} |