use of org.drools.mvel.compiler.util.debug.DebugList in project drools by kiegroup.
the class ParallelEvaluationTest method testWithUpdates.
@Test(timeout = 40000L)
public void testWithUpdates() {
StringBuilder sb = new StringBuilder(400);
sb.append("global java.util.List list;\n");
for (int i = 0; i < 10; i++) {
sb.append(getRule(i, ""));
}
final KieModule kieModule = KieUtil.getKieModuleFromDrls("test", kieBaseTestConfiguration, sb.toString());
final KieBase kbase = KieBaseUtil.newKieBaseFromKieModuleWithAdditionalOptions(kieModule, kieBaseTestConfiguration, MultithreadEvaluationOption.YES);
KieSession ksession = kbase.newKieSession();
assertTrue(((InternalWorkingMemory) ksession).getAgenda().isParallelAgenda());
List<Integer> list = new DebugList<Integer>();
ksession.setGlobal("list", list);
FactHandle[] fhs = new FactHandle[10];
for (int i = 0; i < 10; i++) {
fhs[i] = ksession.insert(i);
ksession.insert("" + i);
}
ksession.fireAllRules();
assertEquals(10, list.size());
list.clear();
for (int i = 0; i < 10; i++) {
ksession.update(fhs[i], i);
}
ksession.fireAllRules();
assertEquals(10, list.size());
}
use of org.drools.mvel.compiler.util.debug.DebugList in project drools by kiegroup.
the class ParallelEvaluationTest method getMultipleParallelKieSessionsWithInsertionsCallable.
private Callable<Void> getMultipleParallelKieSessionsWithInsertionsCallable(KieBase kBase, int ruleNr) {
return new Callable<Void>() {
@Override
public Void call() {
KieSession ksession = kBase.newKieSession();
assertTrue(((InternalWorkingMemory) ksession).getAgenda().isParallelAgenda());
List<Integer> list = new DebugList<Integer>();
ksession.setGlobal("list", list);
insertFacts(ksession, 10);
ksession.fireAllRules();
assertEquals(ruleNr, list.size());
return null;
}
};
}
use of org.drools.mvel.compiler.util.debug.DebugList in project drools by kiegroup.
the class ParallelEvaluationTest method testDisableParallelismWithSalience.
@Test(timeout = 40000L)
public void testDisableParallelismWithSalience() {
StringBuilder sb = new StringBuilder(400);
sb.append("global java.util.List list;\n");
for (int i = 0; i < 10; i++) {
sb.append(getRule(i, "", "salience " + i));
}
final KieModule kieModule = KieUtil.getKieModuleFromDrls("test", kieBaseTestConfiguration, sb.toString());
final KieBase kbase = KieBaseUtil.newKieBaseFromKieModuleWithAdditionalOptions(kieModule, kieBaseTestConfiguration, MultithreadEvaluationOption.YES);
KieSession ksession = kbase.newKieSession();
// multithread evaluation is not allowed when using salience
assertFalse(((InternalWorkingMemory) ksession).getAgenda().isParallelAgenda());
List<Integer> list = new DebugList<Integer>();
ksession.setGlobal("list", list);
for (int i = 0; i < 10; i++) {
ksession.insert(i);
ksession.insert("" + i);
}
ksession.fireAllRules();
assertEquals(10, list.size());
assertEquals(list, Arrays.asList(9, 8, 7, 6, 5, 4, 3, 2, 1, 0));
}
use of org.drools.mvel.compiler.util.debug.DebugList in project drools by kiegroup.
the class ParallelEvaluationTest method testFireUntilHalt2.
@Test(timeout = 40000L)
@Ignore("this test is failing on Jenkins but not locally, we need to figure out why")
public void testFireUntilHalt2() {
int rulesNr = 4;
int factsNr = 1;
int fireNr = rulesNr * factsNr;
String drl = "import " + A.class.getCanonicalName() + ";\n" + "import " + B.class.getCanonicalName() + ";\n" + "global java.util.concurrent.atomic.AtomicInteger counter\n" + "global java.util.concurrent.CountDownLatch done\n" + "global java.util.List list;\n";
for (int i = 0; i < rulesNr; i++) {
drl += getFireUntilHaltRule(fireNr, i);
}
final KieModule kieModule = KieUtil.getKieModuleFromDrls("test", kieBaseTestConfiguration, drl);
final KieBase kbase = KieBaseUtil.newKieBaseFromKieModuleWithAdditionalOptions(kieModule, kieBaseTestConfiguration, MultithreadEvaluationOption.YES);
for (int loop = 0; loop < 10; loop++) {
System.out.println("Starting loop " + loop);
KieSession ksession = kbase.newKieSession();
assertTrue(((InternalWorkingMemory) ksession).getAgenda().isParallelAgenda());
CountDownLatch done = new CountDownLatch(1);
ksession.setGlobal("done", done);
AtomicInteger counter = new AtomicInteger(0);
ksession.setGlobal("counter", counter);
List<String> list = new DebugList<String>();
ksession.setGlobal("list", list);
new Thread(ksession::fireUntilHalt).start();
try {
A a = new A(rulesNr + 1);
ksession.insert(a);
for (int i = 0; i < factsNr; i++) {
ksession.insert(new B(rulesNr + i + 3));
}
try {
done.await();
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
assertEquals(fireNr, counter.get());
} finally {
ksession.halt();
ksession.dispose();
}
System.out.println("Loop " + loop + " terminated");
}
}
use of org.drools.mvel.compiler.util.debug.DebugList in project drools by kiegroup.
the class ParallelEvaluationTest method testFireUntilHalt.
@Test(timeout = 40000L)
public void testFireUntilHalt() {
StringBuilder sb = new StringBuilder(400);
sb.append("global java.util.List list;\n");
for (int i = 0; i < 10; i++) {
sb.append(getRule(i, ""));
}
final KieModule kieModule = KieUtil.getKieModuleFromDrls("test", kieBaseTestConfiguration, sb.toString());
final KieBase kbase = KieBaseUtil.newKieBaseFromKieModuleWithAdditionalOptions(kieModule, kieBaseTestConfiguration, MultithreadEvaluationOption.YES);
KieSession ksession = kbase.newKieSession();
assertTrue(((InternalWorkingMemory) ksession).getAgenda().isParallelAgenda());
CountDownLatch done = new CountDownLatch(1);
DebugList<Integer> list = new DebugList<Integer>();
list.onItemAdded = (l -> {
if (l.size() == 10) {
ksession.halt();
done.countDown();
}
});
ksession.setGlobal("list", list);
new Thread(ksession::fireUntilHalt).start();
try {
for (int i = 0; i < 10; i++) {
ksession.insert(i);
ksession.insert("" + i);
}
try {
done.await();
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
assertEquals(10, list.size());
} finally {
ksession.halt();
ksession.dispose();
}
}
Aggregations