/* * Copyright 2016 Red Hat, Inc. and/or its affiliates. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jbpm.test.functional.workitem; import org.jbpm.process.workitem.AbstractLogOrThrowWorkItemHandler; import org.kie.api.runtime.process.WorkItem; import org.kie.api.runtime.process.WorkItemManager; public class ExceptionWorkItemHandler extends AbstractLogOrThrowWorkItemHandler { @Override public void executeWorkItem( WorkItem workItem, WorkItemManager manager ) { String exception = workItem.getParameter( "exception" ).toString(); try { if ( "no".equals( exception ) ) { manager.completeWorkItem( workItem.getId(), null ); } else { throwExceptionSoThatWorkItemIsNOTCompleted( workItem ); } } catch ( RuntimeException e ) { e.printStackTrace(); } } @Override public void abortWorkItem( WorkItem workItem, WorkItemManager manager ) { // TODO Auto-generated method stub } private void throwExceptionSoThatWorkItemIsNOTCompleted( WorkItem workItem ) { throw new RuntimeException( "Did not complete work item " + workItem.getName() + "/" + workItem.getId() + " from node " + ((org.drools.core.process.instance.WorkItem) workItem).getNodeId() ); } }