use of org.drools.event.process.DefaultProcessEventListener 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);
}
}
use of org.drools.event.process.DefaultProcessEventListener 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);
}
}
use of org.drools.event.process.DefaultProcessEventListener in project jBPM5-Developer-Guide by Salaboy.
the class EmergencyBedRequestBaseTest method initializeSession.
/**
* Compiles the resources indicated by the concrete implementation of
* this class (using {@link #getResources()} abstract method.
* If there is any compilation error an {@link IllegalStateException} is
* thrown.
* After the resources are compiled, a kbase is created and populated with
* the resulting knowledge package/s.
* From this kbase, a new StatefulKnowledgeSession is created. The session
* is configured with 2 listeners:
* 1.- An Agenda event listener that will fireAllRules() every time an
* activation happens
* 2.- A Process event listener that will insert the process instance as
* a Fact once a process is started.
*/
private void initializeSession() {
KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
for (Map.Entry<Resource, ResourceType> entry : this.getResources().entrySet()) {
kbuilder.add(entry.getKey(), entry.getValue());
}
if (kbuilder.hasErrors()) {
KnowledgeBuilderErrors errors = kbuilder.getErrors();
for (KnowledgeBuilderError error : errors) {
System.out.println(">>> Error:" + error.getMessage());
}
throw new IllegalStateException(">>> Knowledge couldn't be parsed! ");
}
KnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase();
kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
session = kbase.newStatefulKnowledgeSession();
KnowledgeRuntimeLoggerFactory.newConsoleLogger(session);
session.addEventListener(new DefaultAgendaEventListener() {
@Override
public void afterRuleFlowGroupActivated(org.drools.event.rule.RuleFlowGroupActivatedEvent event) {
session.fireAllRules();
}
});
session.addEventListener(new DefaultProcessEventListener() {
@Override
public void beforeProcessStarted(ProcessStartedEvent event) {
session.insert(event.getProcessInstance());
}
});
}
Aggregations