/* * Copyright 2011 Red Hat Inc. * * 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.drools.persistence.command; import org.drools.compiler.command.SimpleBatchExecutionTest; import org.drools.persistence.util.DroolsPersistenceUtil; import org.junit.After; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; import org.kie.api.runtime.Environment; import org.kie.api.runtime.EnvironmentName; import org.kie.api.runtime.KieSessionConfiguration; import org.kie.internal.KnowledgeBase; import org.kie.internal.KnowledgeBaseFactory; import org.kie.internal.persistence.jpa.JPAKnowledgeService; import org.kie.internal.runtime.StatefulKnowledgeSession; import java.util.Arrays; import java.util.Collection; import java.util.Map; @RunWith(Parameterized.class) public class SimpleBatchExecutionPersistenceTest extends SimpleBatchExecutionTest { private Map<String, Object> context; private boolean locking; @Parameters(name="{0}") public static Collection<Object[]> persistence() { Object[][] locking = new Object[][] { { DroolsPersistenceUtil.OPTIMISTIC_LOCKING }, { DroolsPersistenceUtil.PESSIMISTIC_LOCKING } }; return Arrays.asList(locking); }; public SimpleBatchExecutionPersistenceTest(String locking) { this.locking = DroolsPersistenceUtil.PESSIMISTIC_LOCKING.equals(locking); }; @After public void cleanUpPersistence() throws Exception { disposeKSession(); DroolsPersistenceUtil.cleanUp(context); context = null; } protected StatefulKnowledgeSession createKnowledgeSession(KnowledgeBase kbase) { if( context == null ) { context = DroolsPersistenceUtil.setupWithPoolingDataSource(DroolsPersistenceUtil.DROOLS_PERSISTENCE_UNIT_NAME); } KieSessionConfiguration ksconf = KnowledgeBaseFactory.newKnowledgeSessionConfiguration(); Environment env = DroolsPersistenceUtil.createEnvironment(context); if( this.locking ) { env.set(EnvironmentName.USE_PESSIMISTIC_LOCKING, true); } return JPAKnowledgeService.newStatefulKnowledgeSession(kbase, ksconf, env); } }