use of org.drools.runtime.KnowledgeSessionConfiguration in project jBPM5-Developer-Guide by Salaboy.
the class MyFirstDrools5FusionRulesTest method createKnowledgeSession.
private StatefulKnowledgeSession createKnowledgeSession() {
KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
kbuilder.add(new ClassPathResource("simpleEventAnalysis.drl"), ResourceType.DRL);
if (kbuilder.hasErrors()) {
for (KnowledgeBuilderError error : kbuilder.getErrors()) {
System.out.println(">>> Error:" + error.getMessage());
}
fail(">>> Knowledge couldn't be parsed! ");
}
KnowledgeBaseConfiguration config = KnowledgeBaseFactory.newKnowledgeBaseConfiguration();
config.setOption(EventProcessingOption.STREAM);
KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase(config);
kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
KnowledgeSessionConfiguration sessionConfig = KnowledgeBaseFactory.newKnowledgeSessionConfiguration();
sessionConfig.setOption(ClockTypeOption.get("pseudo"));
return kbase.newStatefulKnowledgeSession(sessionConfig, null);
}
use of org.drools.runtime.KnowledgeSessionConfiguration in project jBPM5-Developer-Guide by Salaboy.
the class HumanTasksAndRulesTest method simpleTest.
@Test
public void simpleTest() throws InterruptedException {
KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
// Adds resources to the builder
kbuilder.add(new ClassPathResource("rules/SimpleRulesAndTask.drl"), ResourceType.DRL);
KnowledgeBuilderErrors errors = kbuilder.getErrors();
// Checks for errors
if (errors.size() > 0) {
for (KnowledgeBuilderError error : errors) {
System.out.println(error.getMessage());
}
throw new IllegalStateException("Error building kbase!");
}
// Creates a new kbase and add all the packages from the builder
KnowledgeBaseConfiguration kbaseConf = KnowledgeBaseFactory.newKnowledgeBaseConfiguration();
kbaseConf.setOption(EventProcessingOption.STREAM);
KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase(kbaseConf);
kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
KnowledgeSessionConfiguration ksessionConf = KnowledgeBaseFactory.newKnowledgeSessionConfiguration();
ksessionConf.setOption(ClockTypeOption.get("pseudo"));
final StatefulKnowledgeSession ksession = kbase.newStatefulKnowledgeSession(ksessionConf, null);
HornetQHTWorkItemHandler hornetQHTWorkItemHandler = new HornetQHTWorkItemHandler(ksession);
ksession.getWorkItemManager().registerWorkItemHandler("Human Task", hornetQHTWorkItemHandler);
KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
// ksession.addEventListener(new DebugAgendaEventListener());
// Force Init
TaskClientHelper.getInstance();
Thread.sleep(3000);
Task task = createTask();
// new Thread(new Runnable() {
//
// public void run() {
// ksession.fireUntilHalt();
// }
// }).start();
// Insert Tasks
ksession.insert(task);
// Insert Average
ksession.insert(new Average(0.0));
// Create and Insert Threshold
Threshold avgThreshold = new Threshold("AverageThreshold", 2, -1);
ksession.insert(avgThreshold);
// Insert User
ksession.insert(new User("salaboy"));
clock = ksession.getSessionClock();
System.out.println(">>> Time " + clock.getCurrentTime());
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
System.out.println(">>> Time " + clock.getCurrentTime());
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(10.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
System.out.println(">>> Time " + clock.getCurrentTime());
org.drools.runtime.rule.QueryResults results = ksession.getQueryResults("getAverage", new Object[] {});
for (QueryResultsRow row : results) {
System.out.println(">>> Current Average: " + ((Average) row.get("$currentAverage")).getValue().toString());
assertEquals("10.0", ((Average) row.get("$currentAverage")).getValue().toString());
}
Thread.sleep(3000);
List<TaskSummary> tasks = TaskClientHelper.getInstance().getAssignedTasksByUser("salaboy");
assertEquals(1, tasks.size());
System.out.println(">>> Current Assigned Tasks: " + tasks.get(0).getName());
System.out.println(">>> Time " + clock.getCurrentTime());
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
System.out.println(">>> Time " + clock.getCurrentTime());
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
ksession.getWorkingMemoryEntryPoint("water-events").insert(new WaterFlowingEvent(1.0));
ksession.fireAllRules();
clock.advanceTime(1000, TimeUnit.MILLISECONDS);
System.out.println(">>> Time " + clock.getCurrentTime());
results = ksession.getQueryResults("getAverage", new Object[] {});
Thread.sleep(3000);
for (QueryResultsRow row : results) {
System.out.println(">>> Current Average: " + ((Average) row.get("$currentAverage")).getValue().toString());
assertEquals("1.0", ((Average) row.get("$currentAverage")).getValue().toString());
}
Thread.sleep(3000);
tasks = TaskClientHelper.getInstance().getAssignedTasksByUser("salaboy");
assertEquals(0, tasks.size());
System.out.println(">>> I don't have any task assigned now!");
Thread.sleep(3000);
}
use of org.drools.runtime.KnowledgeSessionConfiguration in project jBPM5-Developer-Guide by Salaboy.
the class EventsTesterJFrame method createKnowledgeSession.
private StatefulKnowledgeSession createKnowledgeSession() {
KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
kbuilder.add(new ClassPathResource("simpleEventAnalysis.drl"), ResourceType.DRL);
if (kbuilder.hasErrors()) {
for (KnowledgeBuilderError error : kbuilder.getErrors()) {
System.out.println(" >>> Error:" + error.getMessage() + "\n");
}
throw new IllegalStateException(">>> Knowledge couldn't be parsed! ");
}
KnowledgeBaseConfiguration config = KnowledgeBaseFactory.newKnowledgeBaseConfiguration();
config.setOption(EventProcessingOption.STREAM);
KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase(config);
kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
KnowledgeSessionConfiguration sessionConfig = KnowledgeBaseFactory.newKnowledgeSessionConfiguration();
sessionConfig.setOption(ClockTypeOption.get("realtime"));
return kbase.newStatefulKnowledgeSession(sessionConfig, null);
}
Aggregations