/******************************************************************************* * Copyright (c) 1998, 2015 Oracle and/or its affiliates. All rights reserved. * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * dclarke - Dynamic Persistence * http://wiki.eclipse.org/EclipseLink/Development/Dynamic * (https://bugs.eclipse.org/bugs/show_bug.cgi?id=200045) * mnorman - tweaks to work from Ant command-line, * get database properties from System, etc. * ******************************************************************************/ package org.eclipse.persistence.testing.tests.dynamic.simple.sequencing; //JUnit4 imports import org.junit.After; import org.junit.AfterClass; import org.junit.BeforeClass; //EclipseLink imports import org.eclipse.persistence.dynamic.DynamicClassLoader; import org.eclipse.persistence.dynamic.DynamicHelper; import org.eclipse.persistence.dynamic.DynamicTypeBuilder; import org.eclipse.persistence.internal.sessions.AbstractSession; import org.eclipse.persistence.sequencing.TableSequence; //domain-specific (testing) imports import static org.eclipse.persistence.testing.tests.dynamic.DynamicTestingHelper.createSession; public class TableSequencingTestSuite extends BaseSequencingTestSuite { @BeforeClass public static void setUp() { session = createSession(); dynamicHelper = new DynamicHelper(session); DynamicClassLoader dcl = dynamicHelper.getDynamicClassLoader(); Class<?> dynamicType = dcl.createDynamicClass("simple.sequencing." + ENTITY_TYPE); DynamicTypeBuilder typeBuilder = new DynamicTypeBuilder(dynamicType, null, TABLE_NAME); typeBuilder.setPrimaryKeyFields("SID"); typeBuilder.addDirectMapping("id", int.class, "SID"); typeBuilder.addDirectMapping("value1", String.class, "VAL_1"); // configureSequencing TableSequence sequence = new TableSequence(); sequence.setTableName(SEQ_TABLE_NAME); sequence.setCounterFieldName("SEQ_VALUE"); sequence.setNameFieldName("SEQ_NAME"); sequence.setPreallocationSize(5); ((AbstractSession)session).getProject().getLogin().setDefaultSequence(sequence); sequence.onConnect(session.getPlatform()); typeBuilder.configureSequencing(sequence, ENTITY_TYPE + "_SEQ", "SID"); dynamicHelper.addTypes(true, true, typeBuilder.getType()); } @AfterClass public static void tearDown() { session.executeNonSelectingSQL("DROP TABLE " + TABLE_NAME); session.executeNonSelectingSQL("DROP TABLE " + SEQ_TABLE_NAME); session.logout(); session = null; dynamicHelper = null; } @After public void clearSimpleTypeInstances() throws Exception { session.executeNonSelectingSQL("DELETE FROM " + TABLE_NAME); session.executeNonSelectingSQL("UPDATE " + SEQ_TABLE_NAME + " SET SEQ_VALUE = 0"); session.getSequencingControl().resetSequencing(); session.getSequencingControl().initializePreallocated(); } }