Search in sources :

Example 6 with DefaultProcessEventListener

use of org.drools.event.process.DefaultProcessEventListener in project jBPM5-Developer-Guide by Salaboy.

the class AdvancedProcessAndRulesIntegrationTest method processEventsTest.

@Test
public void processEventsTest() throws InterruptedException {
    KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
    kbuilder.add(new ClassPathResource("evolution/mapping.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("evolution/scoring_processVariables_wider.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("evolution/process-events-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.getWorkItemManager().registerWorkItemHandler("Human Task", new WorkItemHandler() {

        public void executeWorkItem(WorkItem wi, WorkItemManager wim) {
            System.out.println(" >>> Completing Task! -> " + wi.getName() + " - id: " + wi.getId());
            wim.completeWorkItem(wi.getId(), null);
        }

        public void abortWorkItem(WorkItem wi, WorkItemManager wim) {
            throw new UnsupportedOperationException("Not supported yet.");
        }
    });
    KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
    ksession.addEventListener(new DefaultAgendaEventListener() {

        @Override
        public void activationCreated(ActivationCreatedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void afterRuleFlowGroupActivated(RuleFlowGroupActivatedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    Person person = new Person("Salaboy", 28);
    RatesToday ratesToday = new RatesToday(1, 100);
    Map<String, Object> params = new HashMap<String, Object>();
    params.put("person", person);
    params.put("ratesToday", ratesToday);
    ProcessInstance processInstance = ksession.createProcessInstance("com.salaboy.process.SimpleDecision", params);
    System.out.println("Variables: " + ((WorkflowProcessInstanceImpl) processInstance).getVariables());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_PENDING);
    final FactHandle processHandle = ksession.insert(processInstance);
    ((StatefulKnowledgeSessionImpl) ksession).addEventListener(new DefaultProcessEventListener() {

        @Override
        public void beforeProcessStarted(ProcessStartedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void afterProcessStarted(ProcessStartedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void afterProcessCompleted(ProcessCompletedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).retract(processHandle);
        }
    });
    ksession.startProcessInstance(processInstance.getId());
    Thread.sleep(1000);
    //        // If you want to query the process variables while the process Instance is running you can do: 
    //        QueryResults queryResults = ksession.getQueryResults("allProcessVariables", new Object[]{});
    //        Iterator<QueryResultsRow> iterator = queryResults.iterator();
    //
    //        QueryResultsRow ratesRow = iterator.next();
    //        assertEquals(ratesToday, ((ProcessVariable) ratesRow.get("$pv")).getValue());
    //
    //        QueryResultsRow personRow = iterator.next();
    //        assertEquals(person, ((ProcessVariable) personRow.get("$pv")).getValue());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_COMPLETED);
    QueryResults queryResults = ksession.getQueryResults("allProcessVariables", new Object[] {});
    // The Process Variables are automatically retracted when the Process Instance is Completed
    assertEquals(0, queryResults.size());
}
Also used : HashMap(java.util.HashMap) FactHandle(org.drools.runtime.rule.FactHandle) WorkflowProcessInstanceImpl(org.jbpm.workflow.instance.impl.WorkflowProcessInstanceImpl) DefaultAgendaEventListener(org.drools.event.rule.DefaultAgendaEventListener) WorkItem(org.drools.runtime.process.WorkItem) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) ActivationCreatedEvent(org.drools.event.rule.ActivationCreatedEvent) WorkItemManager(org.drools.runtime.process.WorkItemManager) KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ProcessStartedEvent(org.drools.event.process.ProcessStartedEvent) RatesToday(com.salaboy.model.RatesToday) ProcessCompletedEvent(org.drools.event.process.ProcessCompletedEvent) ClassPathResource(org.drools.io.impl.ClassPathResource) QueryResults(org.drools.runtime.rule.QueryResults) WorkItemHandler(org.drools.process.instance.WorkItemHandler) RuleFlowGroupActivatedEvent(org.drools.event.rule.RuleFlowGroupActivatedEvent) StatefulKnowledgeSessionImpl(org.drools.impl.StatefulKnowledgeSessionImpl) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessInstance(org.drools.runtime.process.ProcessInstance) Person(com.salaboy.model.Person)

Example 7 with DefaultProcessEventListener

use of org.drools.event.process.DefaultProcessEventListener 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)

Example 8 with DefaultProcessEventListener

use of org.drools.event.process.DefaultProcessEventListener in project jBPM5-Developer-Guide by Salaboy.

the class MultiProcessEvaluationTest method testProcessCreationDelegation.

@Test
public void testProcessCreationDelegation() {
    KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
    kbuilder.add(new ClassPathResource("multi_process_evaluation/resources.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("multi_process_evaluation/simple-process-trigger.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("multi_process_evaluation/multi-process-decision-customer.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();
    // Uncomment to see all the logs
    //KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
    ksession.addEventListener(new DefaultAgendaEventListener() {

        @Override
        public void activationCreated(ActivationCreatedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    ksession.addEventListener(new DefaultWorkingMemoryEventListener() {

        @Override
        public void objectInserted(ObjectInsertedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void objectUpdated(ObjectUpdatedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    ksession.addEventListener(new DefaultProcessEventListener() {

        @Override
        public void afterNodeLeft(ProcessNodeLeftEvent event) {
            //System.out.println(">>> Firing All the Rules on afterNodeLeft! " + event);
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    QueryResults queryResults = null;
    try {
        ksession.insert(new Resources(10));
        ksession.insert(new Customer("salaboy", Customer.CustomerType.GOLD));
        queryResults = ksession.getQueryResults("getResources", (Object[]) null);
        assertEquals(7, ((Resources) queryResults.iterator().next().get("$r")).getAvailable());
        ksession.insert(new Customer("platinum-customer", Customer.CustomerType.PLATINUM));
        queryResults = ksession.getQueryResults("getResources", (Object[]) null);
        assertEquals(2, ((Resources) queryResults.iterator().next().get("$r")).getAvailable());
        ksession.insert(new Customer("starter", Customer.CustomerType.STARTER));
    } catch (ConsequenceException e) {
        assertEquals(true, e.getCause().getMessage().contains("No More Resources Available = "));
        queryResults = ksession.getQueryResults("getResources", (Object[]) null);
        // In this case, because the rules are starting the process, the Global Rule that checks
        // the Resources Object will kick in just after the process ends.
        // This is usually not a problem due to we will usually have long-running processes
        // which will include a lot of wait states where the queued activations can kick in.
        assertEquals(-1, ((Resources) queryResults.iterator().next().get("$r")).getAvailable());
    }
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) Customer(com.salaboy.model.Customer) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ClassPathResource(org.drools.io.impl.ClassPathResource) QueryResults(org.drools.runtime.rule.QueryResults) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) Resources(com.salaboy.model.Resources) ProcessNodeLeftEvent(org.drools.event.process.ProcessNodeLeftEvent) ConsequenceException(org.drools.runtime.rule.ConsequenceException) Test(org.junit.Test)

Example 9 with DefaultProcessEventListener

use of org.drools.event.process.DefaultProcessEventListener in project jBPM5-Developer-Guide by Salaboy.

the class NewCommonIntegrationPatternsTest method testSimpleDecisionWithReactiveRulesUsingListener.

@Test
public void testSimpleDecisionWithReactiveRulesUsingListener() {
    KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
    kbuilder.add(new ClassPathResource("new_common/scoring.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("new_common/process-drl-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();
    // Uncomment to see all the logs
    // KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
    ksession.addEventListener(new DefaultAgendaEventListener() {

        @Override
        public void activationCreated(ActivationCreatedEvent event) {
            System.out.println(">>> Firing All the Rules after activation created! " + event);
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    ksession.addEventListener(new DefaultProcessEventListener() {

        @Override
        public void afterProcessStarted(ProcessStartedEvent event) {
            System.out.println(">>> Firing All the Rules after process started! " + event);
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    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);
    ksession.insert(processInstance);
    ksession.insert(person);
    ksession.insert(new RatesToday(3, 5));
    assertEquals(processInstance.getState(), ProcessInstance.STATE_PENDING);
    ksession.startProcessInstance(processInstance.getId());
    assertEquals(84, person.getScore());
    assertEquals(processInstance.getState(), ProcessInstance.STATE_COMPLETED);
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) HashMap(java.util.HashMap) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ProcessStartedEvent(org.drools.event.process.ProcessStartedEvent) DefaultAgendaEventListener(org.drools.event.rule.DefaultAgendaEventListener) RatesToday(com.salaboy.model.RatesToday) ClassPathResource(org.drools.io.impl.ClassPathResource) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessInstance(org.drools.runtime.process.ProcessInstance) Person(com.salaboy.model.Person) Test(org.junit.Test)

Example 10 with DefaultProcessEventListener

use of org.drools.event.process.DefaultProcessEventListener in project jBPM5-Developer-Guide by Salaboy.

the class RuleBasedProcessSelectionTest method processSelectionNotEnoughResourcesPlusResourceInjection.

@Test
public void processSelectionNotEnoughResourcesPlusResourceInjection() {
    KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
    kbuilder.add(new ClassPathResource("rule_based_process_selection/smart-process-selection.drl"), ResourceType.DRL);
    kbuilder.add(new ClassPathResource("rule_based_process_selection/platinum-customer-process.bpmn"), ResourceType.BPMN2);
    kbuilder.add(new ClassPathResource("rule_based_process_selection/regular-customer-process.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();
    // Uncomment to see all the logs
    //KnowledgeRuntimeLoggerFactory.newConsoleLogger(ksession);
    ksession.addEventListener(new DefaultWorkingMemoryEventListener() {

        @Override
        public void objectInserted(ObjectInsertedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void objectUpdated(ObjectUpdatedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    ksession.addEventListener(new DefaultAgendaEventListener() {

        @Override
        public void activationCreated(ActivationCreatedEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    ksession.addEventListener(new DefaultProcessEventListener() {

        @Override
        public void beforeNodeTriggered(ProcessNodeTriggeredEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void beforeNodeLeft(ProcessNodeLeftEvent event) {
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    Resources resources = new Resources(2);
    FactHandle resourcesHandle = ksession.insert(resources);
    Customer platinumCustomer = new Customer("Customer One", Customer.CustomerType.PLATINUM);
    ksession.insert(platinumCustomer);
    QueryResults queryResults = ksession.getQueryResults("getResources", (Object[]) null);
    // No Process Was Started
    assertEquals(2, ((Resources) queryResults.iterator().next().get("$r")).getAvailable());
    queryResults = ksession.getQueryResults("getProcessByCustomer", platinumCustomer);
    assertEquals(0, queryResults.size());
    resources.setAvailable(6);
    ksession.update(resourcesHandle, resources);
    queryResults = ksession.getQueryResults("getResources", (Object[]) null);
    assertEquals(1, ((Resources) queryResults.iterator().next().get("$r")).getAvailable());
    queryResults = ksession.getQueryResults("getProcessByCustomer", platinumCustomer);
    assertEquals(1, queryResults.size());
    assertEquals("Platinum Customer Process", ((WorkflowProcessInstanceImpl) queryResults.iterator().next().get("$w")).getProcessName());
}
Also used : KnowledgeBuilderError(org.drools.builder.KnowledgeBuilderError) FactHandle(org.drools.runtime.rule.FactHandle) Customer(com.salaboy.model.Customer) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ClassPathResource(org.drools.io.impl.ClassPathResource) QueryResults(org.drools.runtime.rule.QueryResults) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) KnowledgeBase(org.drools.KnowledgeBase) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessNodeTriggeredEvent(org.drools.event.process.ProcessNodeTriggeredEvent) Resources(com.salaboy.model.Resources) ProcessNodeLeftEvent(org.drools.event.process.ProcessNodeLeftEvent) Test(org.junit.Test)

Aggregations

DefaultProcessEventListener (org.drools.event.process.DefaultProcessEventListener)13 StatefulKnowledgeSession (org.drools.runtime.StatefulKnowledgeSession)12 KnowledgeBase (org.drools.KnowledgeBase)11 KnowledgeBuilder (org.drools.builder.KnowledgeBuilder)11 KnowledgeBuilderError (org.drools.builder.KnowledgeBuilderError)11 ClassPathResource (org.drools.io.impl.ClassPathResource)10 QueryResults (org.drools.runtime.rule.QueryResults)8 HashMap (java.util.HashMap)7 ProcessInstance (org.drools.runtime.process.ProcessInstance)7 Test (org.junit.Test)7 Person (com.salaboy.model.Person)6 Resources (com.salaboy.model.Resources)6 ProcessNodeLeftEvent (org.drools.event.process.ProcessNodeLeftEvent)6 ProcessStartedEvent (org.drools.event.process.ProcessStartedEvent)6 FactHandle (org.drools.runtime.rule.FactHandle)6 Customer (com.salaboy.model.Customer)5 ProcessNodeTriggeredEvent (org.drools.event.process.ProcessNodeTriggeredEvent)5 ProcessCompletedEvent (org.drools.event.process.ProcessCompletedEvent)4 DefaultAgendaEventListener (org.drools.event.rule.DefaultAgendaEventListener)4 RatesToday (com.salaboy.model.RatesToday)3