Search in sources :

Example 1 with KnowledgeSessionConfiguration

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);
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) KnowledgeBaseConfiguration(org.drools.KnowledgeBaseConfiguration) KnowledgeSessionConfiguration(org.drools.runtime.KnowledgeSessionConfiguration) ClassPathResource(org.drools.io.impl.ClassPathResource)

Example 2 with KnowledgeSessionConfiguration

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);
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) Task(org.jbpm.task.Task) User(org.jbpm.task.User) KnowledgeBuilderErrors(org.drools.builder.KnowledgeBuilderErrors) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ClassPathResource(org.drools.io.impl.ClassPathResource) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) HornetQHTWorkItemHandler(org.jbpm.process.workitem.wsht.HornetQHTWorkItemHandler) KnowledgeBase(org.drools.KnowledgeBase) KnowledgeBaseConfiguration(org.drools.KnowledgeBaseConfiguration) QueryResultsRow(org.drools.runtime.rule.QueryResultsRow) KnowledgeSessionConfiguration(org.drools.runtime.KnowledgeSessionConfiguration) TaskSummary(org.jbpm.task.query.TaskSummary) Test(org.junit.Test)

Example 3 with KnowledgeSessionConfiguration

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);
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) KnowledgeBaseConfiguration(org.drools.KnowledgeBaseConfiguration) KnowledgeSessionConfiguration(org.drools.runtime.KnowledgeSessionConfiguration) ClassPathResource(org.drools.io.impl.ClassPathResource)

Aggregations

KnowledgeBase (org.drools.KnowledgeBase)3 KnowledgeBaseConfiguration (org.drools.KnowledgeBaseConfiguration)3 KnowledgeBuilder (org.drools.builder.KnowledgeBuilder)3 KnowledgeBuilderError (org.drools.builder.KnowledgeBuilderError)3 ClassPathResource (org.drools.io.impl.ClassPathResource)3 KnowledgeSessionConfiguration (org.drools.runtime.KnowledgeSessionConfiguration)3 KnowledgeBuilderErrors (org.drools.builder.KnowledgeBuilderErrors)1 StatefulKnowledgeSession (org.drools.runtime.StatefulKnowledgeSession)1 QueryResultsRow (org.drools.runtime.rule.QueryResultsRow)1 HornetQHTWorkItemHandler (org.jbpm.process.workitem.wsht.HornetQHTWorkItemHandler)1 Task (org.jbpm.task.Task)1 User (org.jbpm.task.User)1 TaskSummary (org.jbpm.task.query.TaskSummary)1 Test (org.junit.Test)1