Search in sources :

Example 1 with SimpleActivity

use of io.nosqlbench.engine.api.activityimpl.SimpleActivity in project nosqlbench by nosqlbench.

the class ActivityExecutorTest method getActivityMotorFactory.

private MotorDispenser<?> getActivityMotorFactory(final ActivityDef ad, Action lc, final Input ls) {
    MotorDispenser<?> cmf = new MotorDispenser<>() {

        @Override
        public Motor getMotor(ActivityDef activityDef, int slotId) {
            Activity activity = new SimpleActivity(activityDef);
            Motor<?> cm = new CoreMotor(activity, slotId, ls);
            cm.setAction(lc);
            return cm;
        }
    };
    return cmf;
}
Also used : SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) CoreMotorDispenser(io.nosqlbench.engine.api.activityimpl.motor.CoreMotorDispenser) SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) ActivityDef(io.nosqlbench.engine.api.activityimpl.ActivityDef) CoreMotor(io.nosqlbench.engine.api.activityimpl.motor.CoreMotor)

Example 2 with SimpleActivity

use of io.nosqlbench.engine.api.activityimpl.SimpleActivity in project nosqlbench by nosqlbench.

the class CoreMotorTest method testIteratorStride.

@Test
public void testIteratorStride() {
    BlockingSegmentInput lockstepper = new BlockingSegmentInput();
    Motor cm1 = new CoreMotor(new SimpleActivity("stride=3"), 1L, lockstepper);
    AtomicLongArray ary = new AtomicLongArray(10);
    Action a1 = getTestArrayConsumer(ary);
    cm1.setAction(a1);
    cm1.getSlotStateTracker().enterState(RunState.Starting);
    Thread t1 = new Thread(cm1);
    t1.setName("cm1");
    t1.start();
    try {
        // allow action time to be waiting in monitor for test fixture
        Thread.sleep(500);
    } catch (InterruptedException ignored) {
    }
    lockstepper.publishSegment(11L, 12L, 13L);
    boolean result = awaitAryCondition(ala -> (ala.get(2) == 13L), ary, 5000, 100);
    assertThat(ary.get(0)).isEqualTo(11L);
    assertThat(ary.get(1)).isEqualTo(12L);
    assertThat(ary.get(2)).isEqualTo(13L);
    assertThat(ary.get(3)).isEqualTo(0L);
}
Also used : BlockingSegmentInput(io.nosqlbench.engine.core.fortesting.BlockingSegmentInput) CoreMotor(io.nosqlbench.engine.api.activityimpl.motor.CoreMotor) SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) AtomicLongArray(java.util.concurrent.atomic.AtomicLongArray) CoreMotor(io.nosqlbench.engine.api.activityimpl.motor.CoreMotor) Test(org.junit.jupiter.api.Test)

Example 3 with SimpleActivity

use of io.nosqlbench.engine.api.activityimpl.SimpleActivity in project nosqlbench by nosqlbench.

the class CoreMotorTest method testBasicActivityMotor.

@Test
public void testBasicActivityMotor() {
    BlockingSegmentInput lockstepper = new BlockingSegmentInput();
    Activity activity = new SimpleActivity(ActivityDef.parseActivityDef("alias=foo"));
    Motor cm = new CoreMotor(activity, 5L, lockstepper);
    AtomicLong observableAction = new AtomicLong(-3L);
    cm.setAction(getTestConsumer(observableAction));
    cm.getSlotStateTracker().enterState(RunState.Starting);
    Thread t = new Thread(cm);
    t.setName("TestMotor");
    t.start();
    try {
        // allow action time to be waiting in monitor for test fixture
        Thread.sleep(1000);
    } catch (InterruptedException ignored) {
    }
    lockstepper.publishSegment(5L);
    boolean result = awaitCondition(atomicInteger -> (atomicInteger.get() == 5L), observableAction, 5000, 100);
    assertThat(observableAction.get()).isEqualTo(5L);
}
Also used : AtomicLong(java.util.concurrent.atomic.AtomicLong) BlockingSegmentInput(io.nosqlbench.engine.core.fortesting.BlockingSegmentInput) CoreMotor(io.nosqlbench.engine.api.activityimpl.motor.CoreMotor) SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) CoreMotor(io.nosqlbench.engine.api.activityimpl.motor.CoreMotor) Test(org.junit.jupiter.api.Test)

Example 4 with SimpleActivity

use of io.nosqlbench.engine.api.activityimpl.SimpleActivity in project nosqlbench by nosqlbench.

the class ActivityExecutorTest method testNewActivityExecutor.

@Test
public void testNewActivityExecutor() {
    ActivityDef ad = ActivityDef.parseActivityDef("driver=diag;alias=test;cycles=1000;");
    Optional<ActivityType> activityType = new ActivityTypeLoader().load(ad);
    Input longSupplier = new AtomicInput(ad);
    MotorDispenser<?> cmf = getActivityMotorFactory(ad, motorActionDelay(999), longSupplier);
    Activity a = new SimpleActivity(ad);
    InputDispenser idisp = new CoreInputDispenser(a);
    ActionDispenser adisp = new CoreActionDispenser(a);
    OutputDispenser tdisp = CoreServices.getOutputDispenser(a).orElse(null);
    MotorDispenser<?> mdisp = new CoreMotorDispenser(a, idisp, adisp, tdisp);
    a.setActionDispenserDelegate(adisp);
    a.setInputDispenserDelegate(idisp);
    a.setMotorDispenserDelegate(mdisp);
    ActivityExecutor ae = new ActivityExecutor(a, "test-new-executor");
    ad.setThreads(5);
    ae.startActivity();
    int[] speeds = new int[] { 1, 2000, 5, 2000, 2, 2000 };
    for (int offset = 0; offset < speeds.length; offset += 2) {
        int threadTarget = speeds[offset];
        int threadTime = speeds[offset + 1];
        logger.info("Setting thread level to " + threadTarget + " for " + threadTime + " seconds.");
        ad.setThreads(threadTarget);
        try {
            Thread.sleep(threadTime);
        } catch (InterruptedException ignored) {
        }
    }
    ad.setThreads(0);
}
Also used : AtomicInput(io.nosqlbench.engine.api.activityimpl.input.AtomicInput) SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) CoreInputDispenser(io.nosqlbench.engine.api.activityimpl.input.CoreInputDispenser) ActivityDef(io.nosqlbench.engine.api.activityimpl.ActivityDef) CoreMotorDispenser(io.nosqlbench.engine.api.activityimpl.motor.CoreMotorDispenser) InputDispenser(io.nosqlbench.engine.api.activityapi.input.InputDispenser) CoreInputDispenser(io.nosqlbench.engine.api.activityimpl.input.CoreInputDispenser) CoreActionDispenser(io.nosqlbench.engine.api.activityimpl.action.CoreActionDispenser) AtomicInput(io.nosqlbench.engine.api.activityimpl.input.AtomicInput) Input(io.nosqlbench.engine.api.activityapi.input.Input) ActivityExecutor(io.nosqlbench.engine.core.lifecycle.ActivityExecutor) SimpleActivity(io.nosqlbench.engine.api.activityimpl.SimpleActivity) CoreActionDispenser(io.nosqlbench.engine.api.activityimpl.action.CoreActionDispenser) OutputDispenser(io.nosqlbench.engine.api.activityapi.output.OutputDispenser) ActivityTypeLoader(io.nosqlbench.engine.core.lifecycle.ActivityTypeLoader) Test(org.junit.jupiter.api.Test)

Aggregations

SimpleActivity (io.nosqlbench.engine.api.activityimpl.SimpleActivity)4 CoreMotor (io.nosqlbench.engine.api.activityimpl.motor.CoreMotor)3 Test (org.junit.jupiter.api.Test)3 ActivityDef (io.nosqlbench.engine.api.activityimpl.ActivityDef)2 CoreMotorDispenser (io.nosqlbench.engine.api.activityimpl.motor.CoreMotorDispenser)2 BlockingSegmentInput (io.nosqlbench.engine.core.fortesting.BlockingSegmentInput)2 Input (io.nosqlbench.engine.api.activityapi.input.Input)1 InputDispenser (io.nosqlbench.engine.api.activityapi.input.InputDispenser)1 OutputDispenser (io.nosqlbench.engine.api.activityapi.output.OutputDispenser)1 CoreActionDispenser (io.nosqlbench.engine.api.activityimpl.action.CoreActionDispenser)1 AtomicInput (io.nosqlbench.engine.api.activityimpl.input.AtomicInput)1 CoreInputDispenser (io.nosqlbench.engine.api.activityimpl.input.CoreInputDispenser)1 ActivityExecutor (io.nosqlbench.engine.core.lifecycle.ActivityExecutor)1 ActivityTypeLoader (io.nosqlbench.engine.core.lifecycle.ActivityTypeLoader)1 AtomicLong (java.util.concurrent.atomic.AtomicLong)1 AtomicLongArray (java.util.concurrent.atomic.AtomicLongArray)1