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());
}
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);
}
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());
}
}
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);
}
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());
}
Aggregations