Search in sources :

Example 1 with QueryResultsRow

use of org.drools.runtime.rule.QueryResultsRow 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 2 with QueryResultsRow

use of org.drools.runtime.rule.QueryResultsRow in project jBPM5-Developer-Guide by Salaboy.

the class AutoMappingVariablesTest method processVariablesAutoMappingTest.

@Test
public void processVariablesAutoMappingTest() throws InterruptedException {
    KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
    kbuilder.add(new ClassPathResource("evolution/mapping.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("evolution/scoring_processVariables.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("evolution/process-automapping-decision.bpmn"), ResourceType.BPMN2);
    if (kbuilder.hasErrors()) {
        for (KnowledgeBuilderError error : kbuilder.getErrors()) {
            System.out.println(">>> Error:" + error.getMessage());
        }
        fail(">>> Knowledge couldn't be parsed! ");
    }
    KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase();
    kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
    final StatefulKnowledgeSession ksession = kbase.newStatefulKnowledgeSession();
    KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
    Person person = new Person("Salaboy", 28);
    Map<String, Object> params = new HashMap<String, Object>();
    params.put("person", person);
    ProcessInstance processInstance = ksession.createProcessInstance("com.salaboy.process.SimpleDecision", params);
    System.out.println("Variables: " + ((WorkflowProcessInstanceImpl) processInstance).getVariables());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_PENDING);
    FactHandle processtHandle = ksession.insert(processInstance);
    ksession.fireAllRules();
    ksession.startProcessInstance(processInstance.getId());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_COMPLETED);
    QueryResults queryResults = ksession.getQueryResults("allProcessVariables", new Object[] {});
    Iterator<QueryResultsRow> iterator = queryResults.iterator();
    while (iterator.hasNext()) {
        QueryResultsRow next = iterator.next();
        assertEquals(person, ((ProcessVariable) next.get("$pv")).getValue());
    }
    ksession.retract(processtHandle);
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) HashMap(java.util.HashMap) FactHandle(org.drools.runtime.rule.FactHandle) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) WorkflowProcessInstanceImpl(org.jbpm.workflow.instance.impl.WorkflowProcessInstanceImpl) ClassPathResource(org.drools.io.impl.ClassPathResource) QueryResults(org.drools.runtime.rule.QueryResults) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) QueryResultsRow(org.drools.runtime.rule.QueryResultsRow) ProcessInstance(org.drools.runtime.process.ProcessInstance) Person(com.salaboy.model.Person)

Example 3 with QueryResultsRow

use of org.drools.runtime.rule.QueryResultsRow in project jBPM5-Developer-Guide by Salaboy.

the class AutoMappingVariablesTest method processVariablesAutoMappingWithListenerTest.

@Test
// Add data mappings and finish example
@Ignore
public void processVariablesAutoMappingWithListenerTest() throws InterruptedException {
    KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
    kbuilder.add(new ClassPathResource("evolution/mapping.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("evolution/scoring_processVariables.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("evolution/process-automapping-change-decision.bpmn"), ResourceType.BPMN2);
    if (kbuilder.hasErrors()) {
        for (KnowledgeBuilderError error : kbuilder.getErrors()) {
            System.out.println(">>> Error:" + error.getMessage());
        }
        fail(">>> Knowledge couldn't be parsed! ");
    }
    KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase();
    kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
    final StatefulKnowledgeSession ksession = kbase.newStatefulKnowledgeSession();
    ksession.addEventListener(new DefaultProcessEventListener() {

        @Override
        public void afterVariableChanged(ProcessVariableChangedEvent event) {
            System.out.println(" ### Variable has been changed  -> " + event.getVariableId());
            System.out.println(" ###\t  old -> " + event.getOldValue());
            System.out.println(" ###\t  new -> " + event.getNewValue());
        }

        @Override
        public void beforeVariableChanged(ProcessVariableChangedEvent event) {
            System.out.println(" ### Variable is going to change  -> " + event.getVariableId());
            System.out.println(" ###\t  old -> " + event.getOldValue());
            System.out.println(" ###\t  new -> " + event.getNewValue());
        }
    });
    KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
    new Thread(new Runnable() {

        public void run() {
            ksession.fireUntilHalt();
        }
    }).start();
    Person person = new Person("Salaboy", 28);
    Map<String, Object> params = new HashMap<String, Object>();
    params.put("person", person);
    ProcessInstance processInstance = ksession.createProcessInstance("com.salaboy.process.SimpleDecision", params);
    System.out.println("Variables: " + ((WorkflowProcessInstanceImpl) processInstance).getVariables());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_PENDING);
    FactHandle processtHandle = ksession.insert(processInstance);
    ksession.startProcessInstance(processInstance.getId());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_COMPLETED);
    QueryResults queryResults = ksession.getQueryResults("allProcessVariables", new Object[] {});
    Iterator<QueryResultsRow> iterator = queryResults.iterator();
    while (iterator.hasNext()) {
        QueryResultsRow next = iterator.next();
        assertEquals(person, ((ProcessVariable) next.get("$pv")).getValue());
    }
    ksession.retract(processtHandle);
}
Also used : ProcessVariableChangedEvent(org.drools.event.process.ProcessVariableChangedEvent) KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) HashMap(java.util.HashMap) FactHandle(org.drools.runtime.rule.FactHandle) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) WorkflowProcessInstanceImpl(org.jbpm.workflow.instance.impl.WorkflowProcessInstanceImpl) ClassPathResource(org.drools.io.impl.ClassPathResource) QueryResults(org.drools.runtime.rule.QueryResults) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) QueryResultsRow(org.drools.runtime.rule.QueryResultsRow) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessInstance(org.drools.runtime.process.ProcessInstance) Person(com.salaboy.model.Person)

Aggregations

KnowledgeBase (org.drools.KnowledgeBase)3 KnowledgeBuilder (org.drools.builder.KnowledgeBuilder)3 KnowledgeBuilderError (org.drools.builder.KnowledgeBuilderError)3 ClassPathResource (org.drools.io.impl.ClassPathResource)3 StatefulKnowledgeSession (org.drools.runtime.StatefulKnowledgeSession)3 QueryResultsRow (org.drools.runtime.rule.QueryResultsRow)3 Person (com.salaboy.model.Person)2 HashMap (java.util.HashMap)2 ProcessInstance (org.drools.runtime.process.ProcessInstance)2 FactHandle (org.drools.runtime.rule.FactHandle)2 QueryResults (org.drools.runtime.rule.QueryResults)2 WorkflowProcessInstanceImpl (org.jbpm.workflow.instance.impl.WorkflowProcessInstanceImpl)2 KnowledgeBaseConfiguration (org.drools.KnowledgeBaseConfiguration)1 KnowledgeBuilderErrors (org.drools.builder.KnowledgeBuilderErrors)1 DefaultProcessEventListener (org.drools.event.process.DefaultProcessEventListener)1 ProcessVariableChangedEvent (org.drools.event.process.ProcessVariableChangedEvent)1 KnowledgeSessionConfiguration (org.drools.runtime.KnowledgeSessionConfiguration)1 HornetQHTWorkItemHandler (org.jbpm.process.workitem.wsht.HornetQHTWorkItemHandler)1 Task (org.jbpm.task.Task)1 User (org.jbpm.task.User)1