/*******************************************************************************
* 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.sequencing.TableSequence;
//domain-specific (testing) imports
import static org.eclipse.persistence.testing.tests.dynamic.DynamicTestingHelper.createSession;
public class DefaultSequencingTestSuite 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 defaultSequence = (TableSequence) session.getLogin().getDefaultSequence();
defaultSequence.setTableName(SEQ_TABLE_NAME);
typeBuilder.configureSequencing(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_COUNT = 0");
session.getSequencingControl().resetSequencing();
session.getSequencingControl().initializePreallocated();
}
}