Search in sources :

Example 1 with ProcessStartedEvent

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

the class AdvancedProcessAndRulesIntegrationTest method processVariablesAutoMappingPlusCastNoSafeCheckTest.

@Test
public void processVariablesAutoMappingPlusCastNoSafeCheckTest() 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-variables-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);
    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);
    ksession.addEventListener(new DefaultAgendaEventListener() {

        @Override
        public void activationCreated(ActivationCreatedEvent event) {
            System.out.println("Firing All the Rules! " + event);
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }

        @Override
        public void afterRuleFlowGroupActivated(RuleFlowGroupActivatedEvent event) {
            System.out.println("Firing All the Rules! " + event);
            ((StatefulKnowledgeSession) event.getKnowledgeRuntime()).fireAllRules();
        }
    });
    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());
    //        // If you want to query the process variables while the process Instance is running you can do: 
    //        //  But remember that the activities inside the process are all sync. 
    //        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 : 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) ProcessStartedEvent(org.drools.event.process.ProcessStartedEvent) DefaultAgendaEventListener(org.drools.event.rule.DefaultAgendaEventListener) RatesToday(com.salaboy.model.RatesToday) ProcessCompletedEvent(org.drools.event.process.ProcessCompletedEvent) ClassPathResource(org.drools.io.impl.ClassPathResource) QueryResults(org.drools.runtime.rule.QueryResults) KnowledgeBuilder(org.drools.builder.KnowledgeBuilder) RuleFlowGroupActivatedEvent(org.drools.event.rule.RuleFlowGroupActivatedEvent) KnowledgeBase(org.drools.KnowledgeBase) ActivationCreatedEvent(org.drools.event.rule.ActivationCreatedEvent) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessInstance(org.drools.runtime.process.ProcessInstance) Person(com.salaboy.model.Person)

Example 2 with ProcessStartedEvent

use of org.drools.event.process.ProcessStartedEvent 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 3 with ProcessStartedEvent

use of org.drools.event.process.ProcessStartedEvent 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 4 with ProcessStartedEvent

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

the class ProcessAndEventIntegrationTest method processEventsWithListenerTest.

@Test
public void processEventsWithListenerTest() throws InterruptedException {
    // Let's create a kbuilder, kbase and ksession for running the process
    final StatefulKnowledgeSession processKsession = createProcessSession();
    // Let's create a kbuilder, kbase and ksession for analyzing the process events
    final StatefulKnowledgeSession eventsKsession = createEventsSession();
    final TaskSpeed taskSpeed = new TaskSpeed(1000L);
    eventsKsession.setGlobal("taskSpeed", taskSpeed);
    processKsession.getWorkItemManager().registerWorkItemHandler("Human Task", new WorkItemHandler() {

        public void executeWorkItem(WorkItem wi, WorkItemManager wim) {
            try {
                System.out.println(" >>> Working on Task! it will take: " + taskSpeed.getAmount() / 1000 + " seconds.");
                Thread.sleep(taskSpeed.getAmount());
            } catch (InterruptedException ex) {
                Logger.getLogger(ProcessAndEventIntegrationTest.class.getName()).log(Level.SEVERE, null, ex);
            }
            System.out.println(" >>> Completing Task! -> " + wi.getName() + " - id: " + wi.getId());
            wim.completeWorkItem(wi.getId(), null);
        }

        public void abortWorkItem(WorkItem wi, WorkItemManager wim) {
        // do nothing
        }
    });
    processKsession.addEventListener(new DefaultProcessEventListener() {

        @Override
        public void beforeProcessStarted(ProcessStartedEvent event) {
            System.out.println(" >>> Before Process Started: " + event.getProcessInstance().getProcessName());
            eventsKsession.insert(event);
        }

        @Override
        public void afterProcessCompleted(ProcessCompletedEvent event) {
            System.out.println(" >>> After Process Completed: " + event.getProcessInstance().getProcessName());
            eventsKsession.insert(event);
        }

        @Override
        public void beforeNodeLeft(org.drools.event.process.ProcessNodeLeftEvent event) {
            System.out.println(" >>> Before Node Left: " + event.getNodeInstance().getNodeName());
            eventsKsession.insert(event);
        }
    });
    for (int i = 0; i < 20; i++) {
        final int id = i;
        Person person = new Person("Salaboy-" + id, id);
        Map<String, Object> params = new HashMap<String, Object>();
        params.put("person", person);
        ProcessInstance processInstance = processKsession.createProcessInstance("com.salaboy.process.SimpleProcess", params);
        assertEquals(processInstance.getState(), ProcessInstance.STATE_PENDING);
        FactHandle processtHandle = processKsession.insert(processInstance);
        System.out.println("Starting Process Instance: " + processInstance.getId());
        processKsession.startProcessInstance(processInstance.getId());
        assertEquals(processInstance.getState(), ProcessInstance.STATE_COMPLETED);
        processKsession.retract(processtHandle);
    }
}
Also used : HashMap(java.util.HashMap) FactHandle(org.drools.runtime.rule.FactHandle) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ProcessStartedEvent(org.drools.event.process.ProcessStartedEvent) TaskSpeed(com.salaboy.model.TaskSpeed) WorkItem(org.drools.runtime.process.WorkItem) ProcessCompletedEvent(org.drools.event.process.ProcessCompletedEvent) WorkItemHandler(org.drools.process.instance.WorkItemHandler) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessInstance(org.drools.runtime.process.ProcessInstance) WorkItemManager(org.drools.runtime.process.WorkItemManager) Person(com.salaboy.model.Person)

Example 5 with ProcessStartedEvent

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

the class ProcessAndEventMultiThreadIntegrationTest method processEventsWithListenerTest.

@Test
public void processEventsWithListenerTest() throws InterruptedException {
    // Let's create a kbuilder, kbase and ksession for running the process
    final StatefulKnowledgeSession processKsession = createProcessSession();
    // Let's create a kbuilder, kbase and ksession for analyzing the process events
    final StatefulKnowledgeSession eventsKsession = createEventsSession();
    final TaskSpeed taskSpeed = new TaskSpeed(1000L);
    eventsKsession.setGlobal("taskSpeed", taskSpeed);
    processKsession.getWorkItemManager().registerWorkItemHandler("Human Task", new WorkItemHandler() {

        public void executeWorkItem(WorkItem wi, WorkItemManager wim) {
            try {
                System.out.println(" >>> Working on Task! it will take: " + taskSpeed.getAmount() / 1000 + " seconds.");
                Thread.sleep(taskSpeed.getAmount());
            } catch (InterruptedException ex) {
                Logger.getLogger(ProcessAndEventMultiThreadIntegrationTest.class.getName()).log(Level.SEVERE, null, ex);
            }
            System.out.println(" >>> Completing Task! -> " + wi.getName() + " - id: " + wi.getId());
            wim.completeWorkItem(wi.getId(), null);
        }

        public void abortWorkItem(WorkItem wi, WorkItemManager wim) {
        // do nothing
        }
    });
    ((StatefulKnowledgeSessionImpl) processKsession).addEventListener(new DefaultProcessEventListener() {

        @Override
        public void beforeProcessStarted(ProcessStartedEvent event) {
            System.out.println(" >>> Before Process Started: " + event.getProcessInstance().getProcessName());
            eventsKsession.insert(event);
        }

        @Override
        public void afterProcessCompleted(ProcessCompletedEvent event) {
            System.out.println(" >>> After Process Completed: " + event.getProcessInstance().getProcessName());
            eventsKsession.insert(event);
        }

        @Override
        public void beforeNodeLeft(org.drools.event.process.ProcessNodeLeftEvent event) {
            System.out.println(" >>> Before Node Left: " + event.getNodeInstance().getNodeName());
            eventsKsession.insert(event);
        }
    });
    for (int i = 0; i < 5; i++) {
        for (int j = 0; j < 5; j++) {
            final int id1 = i;
            final int id2 = j;
            new Thread(new Runnable() {

                public void run() {
                    Person person = new Person("Salaboy-" + id1 + "_" + id2, id2);
                    Map<String, Object> params = new HashMap<String, Object>();
                    params.put("person", person);
                    ProcessInstance processInstance = processKsession.createProcessInstance("com.salaboy.process.SimpleProcess", params);
                    assertEquals(processInstance.getState(), ProcessInstance.STATE_PENDING);
                    FactHandle processtHandle = processKsession.insert(processInstance);
                    System.out.println("Starting Process Instance: " + processInstance.getId());
                    processKsession.startProcessInstance(processInstance.getId());
                    assertEquals(processInstance.getState(), ProcessInstance.STATE_COMPLETED);
                    processKsession.retract(processtHandle);
                }
            }).start();
        }
        Thread.sleep(3000);
    }
}
Also used : HashMap(java.util.HashMap) FactHandle(org.drools.runtime.rule.FactHandle) StatefulKnowledgeSession(org.drools.runtime.StatefulKnowledgeSession) ProcessStartedEvent(org.drools.event.process.ProcessStartedEvent) TaskSpeed(com.salaboy.model.TaskSpeed) WorkItem(org.drools.runtime.process.WorkItem) ProcessCompletedEvent(org.drools.event.process.ProcessCompletedEvent) WorkItemHandler(org.drools.process.instance.WorkItemHandler) StatefulKnowledgeSessionImpl(org.drools.impl.StatefulKnowledgeSessionImpl) DefaultProcessEventListener(org.drools.event.process.DefaultProcessEventListener) ProcessInstance(org.drools.runtime.process.ProcessInstance) WorkItemManager(org.drools.runtime.process.WorkItemManager) Person(com.salaboy.model.Person)

Aggregations

DefaultProcessEventListener (org.drools.event.process.DefaultProcessEventListener)6 ProcessStartedEvent (org.drools.event.process.ProcessStartedEvent)6 Person (com.salaboy.model.Person)5 HashMap (java.util.HashMap)5 StatefulKnowledgeSession (org.drools.runtime.StatefulKnowledgeSession)5 ProcessInstance (org.drools.runtime.process.ProcessInstance)5 KnowledgeBase (org.drools.KnowledgeBase)4 KnowledgeBuilder (org.drools.builder.KnowledgeBuilder)4 KnowledgeBuilderError (org.drools.builder.KnowledgeBuilderError)4 ProcessCompletedEvent (org.drools.event.process.ProcessCompletedEvent)4 DefaultAgendaEventListener (org.drools.event.rule.DefaultAgendaEventListener)4 FactHandle (org.drools.runtime.rule.FactHandle)4 RatesToday (com.salaboy.model.RatesToday)3 ClassPathResource (org.drools.io.impl.ClassPathResource)3 WorkItemHandler (org.drools.process.instance.WorkItemHandler)3 WorkItem (org.drools.runtime.process.WorkItem)3 WorkItemManager (org.drools.runtime.process.WorkItemManager)3 TaskSpeed (com.salaboy.model.TaskSpeed)2 ActivationCreatedEvent (org.drools.event.rule.ActivationCreatedEvent)2 RuleFlowGroupActivatedEvent (org.drools.event.rule.RuleFlowGroupActivatedEvent)2