/**
* Copyright 2010 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.process.audit;
import static org.jbpm.persistence.util.PersistenceUtil.createEnvironment;
import static org.jbpm.process.audit.AbstractAuditLogServiceTest.createKieSession;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import org.jbpm.process.instance.impl.demo.SystemOutWorkItemHandler;
import org.junit.After;
import org.junit.Before;
import org.kie.api.KieBase;
import org.kie.api.runtime.Environment;
import org.kie.api.runtime.KieSession;
import org.kie.api.runtime.process.ProcessInstance;
/**
* This class tests the following classes:
* <ul>
* <li>WorkingMemoryDbLogger</li>
* </ul>
*/
public class WorkingMemoryDbLoggerWithSeparateLoggingEmfTest extends AbstractWorkingMemoryDbLoggerTest {
private KieSession ksession = null;
private EntityManagerFactory emf;
@Before
public void beforeThis() {
emf = Persistence.createEntityManagerFactory("org.jbpm.logging.jta");
logService = new JPAAuditLogService(emf);
}
@After
public void afterThis() {
if( emf != null && emf.isOpen() ) {
emf.close();
}
emf = null;
}
@Override
public ProcessInstance startProcess(String processName) {
if( ksession == null ) {
KieBase kbase = createKnowledgeBase();
Environment env = createEnvironment(context);
ksession = createKieSession(kbase, env);
ksession.addEventListener(new JPAWorkingMemoryDbLogger(emf));
ksession.getWorkItemManager().registerWorkItemHandler("Human Task", new SystemOutWorkItemHandler());
}
return ksession.startProcess(processName);
}
}