diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000000..54db2c4f4b --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "asciidoc.antora.enableAntoraSupport": false +} \ No newline at end of file diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/pom.xml b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/pom.xml new file mode 100644 index 0000000000..fb282882bc --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/pom.xml @@ -0,0 +1,121 @@ + + + + 4.0.0 + + + org.eclipse.ee4j + project + 1.0.9 + + + jakarta.tck + persistence-tck-arquillian-extension + 3.2.0 + jar + Extension for running Persistence TCK in GlassFish + + + + + org.jboss.arquillian + arquillian-bom + 1.8.0.Final + import + pom + + + + + + + org.junit.jupiter + junit-jupiter + 5.9.1 + + + org.junit.platform + junit-platform-reporting + 1.10.2 + + + org.jboss.arquillian.container + arquillian-container-test-spi + + + org.jboss.shrinkwrap.resolver + shrinkwrap-resolver-depchain + 3.3.0 + pom + + + jakarta.persistence + jakarta.persistence-api + 3.2.0 + provided + + + jakarta.enterprise + jakarta.enterprise.cdi-api + 4.1.0 + provided + + + jakarta.tck + persistence-tck-common + 3.2.0 + + + + + + + + maven-enforcer-plugin + 3.4.1 + + + enforce-maven + + enforce + + + + + 3.8.6 + + + + + + + + + + maven-compiler-plugin + 3.13.0 + + 17 + + + + + + diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/ArquillianExtension.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/ArquillianExtension.java new file mode 100644 index 0000000000..ec606d7f02 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/ArquillianExtension.java @@ -0,0 +1,37 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +import org.jboss.arquillian.container.test.spi.client.deployment.ApplicationArchiveProcessor; +import org.jboss.arquillian.container.test.spi.client.deployment.DeploymentScenarioGenerator; +import org.jboss.arquillian.container.test.spi.client.deployment.ProtocolArchiveProcessor; +import org.jboss.arquillian.core.spi.LoadableExtension; +import org.jboss.arquillian.core.spi.LoadableExtension.ExtensionBuilder; + +public class ArquillianExtension implements LoadableExtension { + + public static final String PROPERTY_PREFIX = "arquillian.extension."; + + @Override + public void register(ExtensionBuilder builder) { + builder.service(DeploymentScenarioGenerator.class, MavenTestDependenciesDeploymentPackager.class); + builder.service(ApplicationArchiveProcessor.class, SystemPropertiesArchiveProcessor.class); + builder.service(ProtocolArchiveProcessor.class, RemoveClassesArchiveProcessor.class); + } +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/DeploymentPackageType.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/DeploymentPackageType.java new file mode 100644 index 0000000000..9521eedd0f --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/DeploymentPackageType.java @@ -0,0 +1,125 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +import java.io.File; +import org.jboss.shrinkwrap.api.Archive; +import org.jboss.shrinkwrap.api.ShrinkWrap; +import org.jboss.shrinkwrap.api.asset.Asset; +import org.jboss.shrinkwrap.api.spec.EnterpriseArchive; +import org.jboss.shrinkwrap.api.spec.JavaArchive; +import org.jboss.shrinkwrap.api.spec.WebArchive; + +/** + * + * @author omihalyi + */ +public enum DeploymentPackageType { + WAR { + @Override + protected PackageBuilder getPackageBuilder(Archive archive) { + return new WarPackageBuilder(archive); + } + }, EAR { + @Override + protected PackageBuilder getPackageBuilder(Archive archive) { + throw new UnsupportedOperationException("Not supported yet."); + } + }; + + public static DeploymentPackageType fromString(String value) { + if (value == null || value.isEmpty()) { + return null; + } + String upperCaseValue = value.toUpperCase(); + // remove special chars, e.g. ejb-jar is turned into EJBJAR + upperCaseValue = upperCaseValue.replaceAll("-|_|\\.| ", ""); + return DeploymentPackageType.valueOf(upperCaseValue); + } + + public static DeploymentPackageType fromArchive(Archive archive) { + if (archive == null) { + return null; + } + if (archive instanceof WebArchive) { + return WAR; + } else if (archive instanceof EnterpriseArchive) { + return EAR; + } else { + throw new RuntimeException("Unsupported archive type: " + archive.getClass()); + } + } + + protected PackageBuilder getPackageBuilder() { + return getPackageBuilder(null); + } + + // create builder from an existing archive - modifies the existing archive + protected abstract PackageBuilder getPackageBuilder(Archive archive); + + interface PackageBuilder { + + PackageBuilder addArtifact(File artifactFile); + + PackageBuilder addResource(Asset resourceAsset, String resourceName); + + PackageBuilder addClass(Class cls); + + Archive build(); + } + + class WarPackageBuilder implements PackageBuilder { + + WebArchive archive; + + public WarPackageBuilder(Archive archive) { + if (archive == null) { + this.archive = ShrinkWrap.create(WebArchive.class, "package.war").as(WebArchive.class); + } else { + this.archive = archive.as(WebArchive.class); + } + } + + @Override + public WarPackageBuilder addArtifact(File artifactFile) { + final JavaArchive artifactArchive = ShrinkWrap.createFromZipFile(JavaArchive.class, artifactFile); + artifactArchive.delete("/com/sun/ts/tests/jms/commonee/MDB_Q_TestEJB.class"); + artifactArchive.delete("/com/sun/ts/tests/jms/commonee/MDB_T_TestEJB.class"); + archive.addAsLibrary(artifactArchive); + return this; + } + + @Override + public WarPackageBuilder addResource(Asset resourceAsset, String resourceName) { + archive.addAsResource(resourceAsset, resourceName); + return this; + } + + public WarPackageBuilder addClass(Class cls) { + archive.addClass(cls); + return this; + } + + @Override + public Archive build() { + return archive; + } + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/JakartaEeExecutionInterceptor.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/JakartaEeExecutionInterceptor.java new file mode 100644 index 0000000000..c80625421f --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/JakartaEeExecutionInterceptor.java @@ -0,0 +1,133 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ +package org.glassfish.persistence.tck; + +import com.sun.ts.tests.common.vehicle.ejb3share.UseEntityManager; +import com.sun.ts.tests.common.vehicle.ejb3share.UseEntityManagerFactory; +import jakarta.persistence.EntityManager; +import jakarta.persistence.EntityManagerFactory; +import jakarta.persistence.Persistence; +import jakarta.persistence.PersistenceContext; +import jakarta.persistence.PersistenceUnit; +import jakarta.transaction.UserTransaction; +import java.lang.reflect.Method; +import java.util.Properties; +import java.util.logging.Level; +import java.util.logging.Logger; +import javax.naming.Context; +import javax.naming.InitialContext; +import javax.naming.NamingException; +import org.junit.jupiter.api.extension.ExtensionContext; +import org.junit.jupiter.api.extension.InvocationInterceptor; +import org.junit.jupiter.api.extension.ReflectiveInvocationContext; + +/** + * + * @author Ondro Mihalyi + */ +public class JakartaEeExecutionInterceptor implements InvocationInterceptor { + + private Properties props; + + public JakartaEeExecutionInterceptor(Properties props) { + this.props = props; + } + + public void interceptBeforeEachMethod(Invocation invocation, ReflectiveInvocationContext invocationContext, ExtensionContext extensionContext) throws Throwable { + interceptTestMethod(invocation, invocationContext, extensionContext); + } + + @Override + public void interceptTestTemplateMethod(Invocation invocation, + ReflectiveInvocationContext invocationContext, + ExtensionContext extensionContext) throws Throwable { + interceptTestMethod(invocation, invocationContext, extensionContext); + } + + @Override + public void interceptTestMethod(Invocation invocation, + ReflectiveInvocationContext invocationContext, + ExtensionContext extensionContext) throws Throwable { + Reporter.logTrace("Invoking test method " + invocationContext.getExecutable().getName() + " in a Jakarta EE container."); + invocationContext.getTarget().ifPresent(newTestObject -> { + setEntityManager(newTestObject); + setEntityManagerFactory(newTestObject); + setEntityTransaction(newTestObject); + }); + invocation.proceed(); + Reporter.logTrace("...finished test method " + invocationContext.getExecutable().getName() + " in a Jakarts EE container."); + } + + private void setEntityManager(T testObject) { + if (testObject instanceof UseEntityManager) { + UseEntityManager useEm = (UseEntityManager) testObject; + String unitName = System.getProperty(PropertyKeys.DEFAULT_PERSISTENCE_UNIT); + PersistenceContext persistenceContextAnnotation = null; + try { + persistenceContextAnnotation = useEm.getClass().getMethod("setEntityManager", EntityManager.class) + .getAnnotation(PersistenceContext.class); + } catch (NoSuchMethodException | SecurityException ex) { + } + if (persistenceContextAnnotation != null) { + if (persistenceContextAnnotation.unitName() != null) { + unitName = persistenceContextAnnotation.unitName(); + } + } + useEm.setEntityManager(getEM(unitName)); + } + } + + private void setEntityManagerFactory(T testObject) { + if (testObject instanceof UseEntityManagerFactory) { + UseEntityManagerFactory useEmf = (UseEntityManagerFactory) testObject; + String unitName = System.getProperty(PropertyKeys.DEFAULT_PERSISTENCE_UNIT); + PersistenceUnit persistenceUnitAnnotation = null; + try { + persistenceUnitAnnotation = useEmf.getClass().getMethod("setEntityManagerFactory", EntityManagerFactory.class) + .getAnnotation(PersistenceUnit.class); + } catch (NoSuchMethodException | SecurityException ex) { + } + if (persistenceUnitAnnotation != null) { + if (persistenceUnitAnnotation.unitName() != null) { + unitName = persistenceUnitAnnotation.unitName(); + } + } + useEmf.setEntityManagerFactory(getEMF(unitName)); + } + } + + private void setEntityTransaction(Object testObject) { + if (testObject instanceof UseEntityManager) { + try { + UseEntityManager useEm = (UseEntityManager) testObject; + Context namingContext = new InitialContext(); + UserTransaction userTx = (UserTransaction) namingContext.lookup("java:comp/UserTransaction"); + useEm.setEntityTransaction(new UserTransactionWrapper(userTx)); + } catch (NamingException ex) { + Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, null, ex); + } + } + } + + private EntityManager getEM(String unitName) { + return getEMF(unitName).createEntityManager(); + } + + private EntityManagerFactory getEMF(String unitName) { + return Persistence.createEntityManagerFactory(unitName); + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/MavenTestDependenciesDeploymentPackager.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/MavenTestDependenciesDeploymentPackager.java new file mode 100644 index 0000000000..27d112e21f --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/MavenTestDependenciesDeploymentPackager.java @@ -0,0 +1,128 @@ +/* + * Copyright (c) 2022,2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collections; +import java.util.List; +import java.util.stream.Stream; +import org.jboss.arquillian.container.spi.client.deployment.DeploymentDescription; +import org.jboss.arquillian.container.test.spi.client.deployment.*; +import org.jboss.arquillian.test.spi.TestClass; +import org.jboss.shrinkwrap.api.Archive; +import org.jboss.shrinkwrap.resolver.api.maven.*; + +public class MavenTestDependenciesDeploymentPackager implements DeploymentScenarioGenerator { + + private List coordinatePrefixesToIgnore = null; + + private DeploymentPackageType deploymentPackageType = DeploymentPackageType.WAR; + + public MavenTestDependenciesDeploymentPackager() { + initListOfIgnoredArtifactPrefixes(); + initDeploymentPackage(); + } + + public List getGroupPrefixesToIgnore() { + return coordinatePrefixesToIgnore; + } + + public void setGroupPrefixesToIgnore(List groupPrefixesToIgnore) { + this.coordinatePrefixesToIgnore = groupPrefixesToIgnore; + } + + public DeploymentPackageType getDeploymentPackageType() { + return deploymentPackageType; + } + + public void setDeploymentPackageType(DeploymentPackageType deploymentPackageType) { + this.deploymentPackageType = deploymentPackageType; + } + + private Archive generateDeployment() { + String[] activeMavenProfiles = getListOfActiveMavenProfiles(); + + MavenResolvedArtifact[] resolvedArtifacts = Maven.resolver().loadPomFromFile("pom.xml", activeMavenProfiles) + .importDependencies(ScopeType.COMPILE, ScopeType.TEST) + .resolve().withTransitivity().asResolvedArtifact(); + + DeploymentPackageType.PackageBuilder packageBuilder = deploymentPackageType.getPackageBuilder(); + + Stream.of(resolvedArtifacts) + .filter(this::artifactShouldntBeIgnored) + .filter(artifact -> { + return "jar".equals(artifact.getExtension()); + }) + .map(MavenResolvedArtifact::asFile) + .forEach(packageBuilder::addArtifact); + + return packageBuilder.build(); + } + + private String[] getListOfActiveMavenProfiles() { + String activeMavenProfilesRawValue = System.getProperty(PropertyKeys.ACTIVE_MAVEN_PROFILES); + if (activeMavenProfilesRawValue != null) { + return activeMavenProfilesRawValue.split("\\s*,\\s*"); + } else { + return new String[] {}; + } + } + + private boolean artifactShouldntBeIgnored(MavenResolvedArtifact artifact) { + String groupId = artifact.getCoordinate().getGroupId(); + String artifactId = artifact.getCoordinate().getArtifactId(); + String coordinates = groupId + ":" + artifactId; + final boolean forceGroupInclude = coordinatePrefixesToIgnore.stream() + .anyMatch(prefix -> ("!" + coordinates).startsWith(prefix)); + if (forceGroupInclude) { + return true; + } + final boolean groupMatchesAPrefix = coordinatePrefixesToIgnore.stream() + .anyMatch(prefix -> coordinates.startsWith(prefix)); + return !groupMatchesAPrefix; + } + + @Override + public List generate(TestClass testClass) { + final DeploymentDescription defaultDeployment = new DeploymentDescription("persistence-" + + testClass.getName(),generateDeployment()); + return Collections.singletonList(defaultDeployment); + } + + private void initListOfIgnoredArtifactPrefixes() { + coordinatePrefixesToIgnore = new ArrayList<>(Arrays.asList( + "org.jboss.shrinkwrap", // ShrinkWrap - creates a deployment, not needed in the deployment itself + "org.codehaus.plexus", // Maven classes - not needed in the deployment itself + "org.apache.maven")); // Maven classes - not needed in the deployment itself + String additionalPrefixesFromProperties = System.getProperty(PropertyKeys.GROUP_PREFIXES_TO_IGNORE); + if (additionalPrefixesFromProperties != null) { + List prefixesFromPropertiesList = Arrays.asList(additionalPrefixesFromProperties.split("\\s*,\\s*")); + coordinatePrefixesToIgnore.addAll(prefixesFromPropertiesList); + } + } + + private void initDeploymentPackage() { + String packageValue = System.getProperty(PropertyKeys.PACKAGE); + if (packageValue != null) { + deploymentPackageType = DeploymentPackageType.fromString(packageValue); + } + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/MyTestExecutionListener.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/MyTestExecutionListener.java new file mode 100644 index 0000000000..5575c2786f --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/MyTestExecutionListener.java @@ -0,0 +1,78 @@ +/* + * Copyright (c) 2021-2022 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ + +package org.glassfish.persistence.tck; + +import java.util.logging.Level; +import java.util.logging.LogManager; +import java.util.logging.Logger; +import java.util.stream.Stream; +import org.junit.platform.engine.TestExecutionResult; +import org.junit.platform.engine.reporting.ReportEntry; +import org.junit.platform.launcher.TestExecutionListener; +import org.junit.platform.launcher.TestIdentifier; +import org.junit.platform.launcher.TestPlan; +import org.junit.platform.launcher.listeners.LoggingListener; + +public class MyTestExecutionListener implements TestExecutionListener { + + private final LoggingListener loggingListener = LoggingListener.forJavaUtilLogging(Level.INFO); + private final TestExecutionListener[] delegates = new TestExecutionListener[] {loggingListener}; + + @Override + public void reportingEntryPublished(TestIdentifier testIdentifier, ReportEntry entry) { + Stream.of(delegates).forEach( l -> l.reportingEntryPublished(testIdentifier, entry)); + Logger logger = Logger.getLogger(LoggingListener.class.getName()); + logger.info(entry.getKeyValuePairs().get("value")); + } + + @Override + public void executionFinished(TestIdentifier testIdentifier, TestExecutionResult testExecutionResult) { + Stream.of(delegates).forEach( l -> l.executionFinished(testIdentifier, testExecutionResult)); + } + + @Override + public void executionStarted(TestIdentifier testIdentifier) { + Logger logger = Logger.getLogger(LoggingListener.class.getName()); + Stream.of(delegates).forEach( l -> l.executionStarted(testIdentifier)); + } + + @Override + public void executionSkipped(TestIdentifier testIdentifier, String reason) { + Stream.of(delegates).forEach( l -> l.executionSkipped(testIdentifier, reason)); + } + + @Override + public void dynamicTestRegistered(TestIdentifier testIdentifier) { + Stream.of(delegates).forEach( l -> l.dynamicTestRegistered(testIdentifier)); + } + + @Override + public void testPlanExecutionFinished(TestPlan testPlan) { + Stream.of(delegates).forEach( l -> l.testPlanExecutionFinished(testPlan)); + } + + @Override + public void testPlanExecutionStarted(TestPlan testPlan) { + LogManager.getLogManager().getLogger(LoggingListener.class.getName()).setLevel(Level.INFO); + + Stream.of(delegates).forEach( l -> l.testPlanExecutionStarted(testPlan)); + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/PropertyKeys.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/PropertyKeys.java new file mode 100644 index 0000000000..3a0c8d7a24 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/PropertyKeys.java @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +/** + * + * @author Ondro Mihalyi + */ +public interface PropertyKeys { + + final String SYSTEM_PROPERTIES_FILE_NAME = "test.properties"; + + final String PLATFORM_MODE = "platform.mode"; + + final String PLATFORM_MODE_JAKARTAEE = "jakartaEE"; + + final String ACTIVE_MAVEN_PROFILES = ArquillianExtension.PROPERTY_PREFIX + "activeMavenProfiles"; + + final String IN_CONTAINER = ArquillianExtension.PROPERTY_PREFIX + "inContainer"; + + // Artifacts with a group matching one of these prefixes will not be added to the package. + // Expects a comma-separated list of prefixes. + final String GROUP_PREFIXES_TO_IGNORE = ArquillianExtension.PROPERTY_PREFIX + "coordinatePrefixesToIgnore"; + + // package type, e.g. EAR, EJBJAR, WAR. Default is WAR + final String PACKAGE = ArquillianExtension.PROPERTY_PREFIX + "packageType"; + + final String DEFAULT_PERSISTENCE_UNIT = "persistence.unit.name"; + + final String JUNIT_AUTO_EXTENSIONS_ENABLED = "junit.jupiter.extensions.autodetection.enabled"; +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/RemoveClassesArchiveProcessor.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/RemoveClassesArchiveProcessor.java new file mode 100644 index 0000000000..ee51d529c4 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/RemoveClassesArchiveProcessor.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ +package org.glassfish.persistence.tck; + +import java.util.ArrayList; +import java.util.List; +import java.util.Set; +import org.jboss.arquillian.container.test.spi.TestDeployment; +import org.jboss.arquillian.container.test.spi.client.deployment.ProtocolArchiveProcessor; +import org.jboss.shrinkwrap.api.Archive; +import org.jboss.shrinkwrap.api.Node; + +/** + * We need to remove the test class and related classes added by Arquillian automatically. They were causing issues with Shrinkwrap used in the TCK tests. Those classes are already in a JAR in WEB-INF/lib. + * @author Ondro Mihalyi + */ +public class RemoveClassesArchiveProcessor implements ProtocolArchiveProcessor { + + public void process(TestDeployment td, Archive archive) { + final Node toDelete = archive.get("/WEB-INF/classes/ee"); + if (toDelete != null) { + deleteChildren(toDelete, archive); + } + } + + private void deleteChildren(Node node, Archive archive) { + final Set children = node.getChildren(); + if (!children.isEmpty()) { + List nodesToDelete = new ArrayList<>(children); + nodesToDelete.forEach(childNode -> { + deleteChildren(childNode, archive); + }); + } + archive.delete(node.getPath()); + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/Reporter.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/Reporter.java new file mode 100644 index 0000000000..45a353b5a1 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/Reporter.java @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +import java.util.logging.Logger; +import org.junit.jupiter.api.TestReporter; + +public class Reporter { + + public static ThreadLocal reporterRef = new ThreadLocal<>(); + + public static void log(String message) { + TestReporter reporter = reporterRef.get(); + if (reporter != null) { + reporter.publishEntry(message); + } else { + Logger.getLogger(Reporter.class.getName()).info(message); + } + } + + public static void logTrace(String message) { + // TODO: log using the TRACE log level. Now we log using the default INFO level with the TRACE: prefix + log("TRACE: " + message); + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/SigTestArgumentsModifier.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/SigTestArgumentsModifier.java new file mode 100644 index 0000000000..368e48d328 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/SigTestArgumentsModifier.java @@ -0,0 +1,51 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ +package org.glassfish.persistence.tck; + +import com.sun.tdk.signaturetest.core.Exclude; +import com.sun.tdk.signaturetest.core.ExcludeException; +import com.sun.tdk.signaturetest.model.ClassDescription; +import com.sun.tdk.signaturetest.model.MemberDescription; +import java.util.ArrayList; +import java.util.List; + +/** + * + * @author Ondro Mihalyi + */ +public class SigTestArgumentsModifier implements Exclude { + + private static final String BOOT_CP_ARG = "-BootCp"; + + public String[] parseParameters(String[] args) { + for (String arg : args) { + if (arg.equals(BOOT_CP_ARG)) { + return args; + } + } + final List argsList = new ArrayList(List.of(args)); + argsList.add(BOOT_CP_ARG); + return argsList.toArray(new String[] {}); + } + + public void check(ClassDescription testedClass, MemberDescription signature) throws ExcludeException { + } + + public String report() { + return null; + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/SystemPropertiesArchiveProcessor.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/SystemPropertiesArchiveProcessor.java new file mode 100644 index 0000000000..3de37fea0e --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/SystemPropertiesArchiveProcessor.java @@ -0,0 +1,61 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +import java.io.IOException; +import java.io.StringWriter; +import java.util.Properties; +import org.jboss.arquillian.container.test.spi.client.deployment.ApplicationArchiveProcessor; +import org.jboss.arquillian.test.spi.TestClass; +import org.jboss.shrinkwrap.api.Archive; +import org.jboss.shrinkwrap.api.asset.StringAsset; + +/** + * Copies the system properties into a properties file inside the test deployment package. + * + * The TestInvocationInterceptor JUnit extension can then read the properties file from the classpath + * and set system properties for tests running in a Jakarta EE container. + * + * @author omihalyi + */ +public class SystemPropertiesArchiveProcessor implements ApplicationArchiveProcessor { + + @Override + public void process(Archive archive, TestClass arg1) { + Properties props = new Properties(); + props.putAll(System.getProperties()); + String propertiesContent = propertiesToStringContent(props); + DeploymentPackageType deploymentpackage + = DeploymentPackageType.fromArchive(archive); + deploymentpackage.getPackageBuilder(archive) + // store properties into a properties file + .addResource(new StringAsset(propertiesContent), PropertyKeys.SYSTEM_PROPERTIES_FILE_NAME) + .build(); + } + + private String propertiesToStringContent(Properties props) { + try ( StringWriter propertiesWriter = new StringWriter()) { + props.store(propertiesWriter, null); + return propertiesWriter.toString(); + } catch (IOException ex) { // can't happen from StringWriter + throw new RuntimeException(ex); + } + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/TestInitializerInContainer.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/TestInitializerInContainer.java new file mode 100644 index 0000000000..5aa09c4c62 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/TestInitializerInContainer.java @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ +package org.glassfish.persistence.tck; + +import jakarta.enterprise.context.ApplicationScoped; +import jakarta.enterprise.context.Initialized; +import jakarta.enterprise.event.Observes; + +/** + * + * @author Ondro Mihalyi + */ +@ApplicationScoped +public class TestInitializerInContainer { + public void init(@Observes @Initialized(ApplicationScoped.class) Object init) { + System.setProperty(PropertyKeys.JUNIT_AUTO_EXTENSIONS_ENABLED, "true"); + } +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/TestInvocationInterceptor.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/TestInvocationInterceptor.java new file mode 100644 index 0000000000..ab06f8ad82 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/TestInvocationInterceptor.java @@ -0,0 +1,139 @@ +/* + * Copyright (c) 2022,2024 Contributors to the Eclipse Foundation + * + * See the NOTICE file distributed with this work for additional information + * regarding copyright ownership. 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. + * + * SPDX-License-Identifier: Apache-2.0 + */ +package org.glassfish.persistence.tck; + +import com.sun.ts.lib.util.TestUtil; +import java.io.IOException; +import java.io.InputStream; +import java.io.PrintWriter; +import java.lang.reflect.Method; +import java.util.Properties; +import java.util.logging.Level; +import java.util.logging.Logger; +import org.junit.jupiter.api.extension.ExtensionContext; +import org.junit.jupiter.api.extension.InvocationInterceptor; +import org.junit.jupiter.api.extension.ReflectiveInvocationContext; + +/** + * JUnit5 interceptor that wraps test execution within a container. It's supposed to run within the Jakarta EE container + * (Arquillian). It requires that the container adapter (Arquillian extension) adds configuration properties into a + * properties file inside the test application. Configuration properties are read from system properties and the + * properties file. + * + * If executed outside of container (platform.mode is standalone or undefined), it executes tests normally. + * + * If executed inside a container, it reads the properties to find out which platform.mode to use and to set System + * prooeries. + * + */ +public class TestInvocationInterceptor implements InvocationInterceptor { + + private final Properties props; + + private final InvocationInterceptor testInterceptor; + + public TestInvocationInterceptor() { + this.props = loadProperties(); + testInterceptor = createInterceptor(); + } + + public static boolean isInContainer(Properties properties) { + return Boolean.parseBoolean(properties.getProperty(PropertyKeys.IN_CONTAINER)); + } + + public void interceptBeforeEachMethod(Invocation invocation, ReflectiveInvocationContext invocationContext, ExtensionContext extensionContext) throws Throwable { + initTestUtil(invocationContext); + final Properties oldSysProps = new Properties(); + oldSysProps.putAll(System.getProperties()); + System.getProperties().putAll(props); + try { + testInterceptor.interceptBeforeEachMethod(invocation, invocationContext, extensionContext); + } catch (Throwable ex) { + System.setProperties(oldSysProps); + throw new RuntimeException(ex); + } + } + + @Override + public void interceptTestTemplateMethod(Invocation invocation, + ReflectiveInvocationContext invocationContext, + ExtensionContext extensionContext) throws Throwable { + initTestUtil(invocationContext); + final Properties oldSysProps = new Properties(); + oldSysProps.putAll(System.getProperties()); + System.getProperties().putAll(props); + try { + testInterceptor.interceptTestTemplateMethod(invocation, invocationContext, extensionContext); + } catch (Throwable ex) { + System.setProperties(oldSysProps); + throw new RuntimeException(ex); + } + } + + @Override + public void interceptTestMethod(Invocation invocation, + ReflectiveInvocationContext invocationContext, + ExtensionContext extensionContext) throws Throwable { + initTestUtil(invocationContext); + final Properties oldSysProps = new Properties(); + oldSysProps.putAll(System.getProperties()); + System.getProperties().putAll(props); + try { + testInterceptor.interceptTestMethod(invocation, invocationContext, extensionContext); + } catch (Throwable ex) { + System.setProperties(oldSysProps); + throw new RuntimeException(ex); + } + } + + private void initTestUtil(ReflectiveInvocationContext invocationContext) { + TestUtil.initNoLogging(System.getProperties()); + final String testName = invocationContext.getTargetClass() + "#" + invocationContext.getExecutable().getName(); + final PrintWriter toReporterPrintWriter = new PrintWriter(new WriterToReporterBridge(), false); + TestUtil.setCurrentTest(testName, toReporterPrintWriter, toReporterPrintWriter); + } + + private Properties loadProperties() { + Properties props = new Properties(System.getProperties()); + try (InputStream propertiesInputStream = this.getClass().getClassLoader() + .getResourceAsStream(PropertyKeys.SYSTEM_PROPERTIES_FILE_NAME)) { + if (propertiesInputStream != null) { + props.load(propertiesInputStream); + props.setProperty(PropertyKeys.IN_CONTAINER, Boolean.TRUE.toString()); + } + } catch (IOException ex) { + Logger.getLogger(this.getClass().getName()).log(Level.WARNING, ex, + () -> "Couldn't find resource " + PropertyKeys.SYSTEM_PROPERTIES_FILE_NAME + + " on the classpath or read properties from it. Properties from it won't be applied"); + } + return props; + } + + private InvocationInterceptor createInterceptor() { + if (isInContainer(props)) { + String platformMode = props.getProperty(PropertyKeys.PLATFORM_MODE, ""); + + if (platformMode.equals(PropertyKeys.PLATFORM_MODE_JAKARTAEE)) { + return new JakartaEeExecutionInterceptor(props); + } + } + return new InvocationInterceptor() { + }; + } +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/UserTransactionWrapper.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/UserTransactionWrapper.java new file mode 100644 index 0000000000..97f75b633f --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/UserTransactionWrapper.java @@ -0,0 +1,100 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ +package org.glassfish.persistence.tck; + +import jakarta.persistence.EntityTransaction; +import jakarta.persistence.PersistenceException; +import jakarta.transaction.NotSupportedException; +import jakarta.transaction.Status; +import jakarta.transaction.SystemException; +import jakarta.transaction.UserTransaction; +import java.util.logging.Level; +import java.util.logging.Logger; + +/** + * + * @author Ondro Mihalyi + */ +public class UserTransactionWrapper implements EntityTransaction { + + UserTransaction userTx; + + public UserTransactionWrapper(UserTransaction userTx) { + this.userTx = userTx; + } + + public void begin() { + try { + userTx.begin(); + } catch (NotSupportedException | SystemException ex) { + Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, null, ex); + throw new RuntimeException(ex); + } + } + + @FunctionalInterface + public interface RunnableWithException { + + void run() throws Exception; + } + + private void withHandledException(RunnableWithException runnable) { + try { + runnable.run(); + } catch (Exception ex) { + Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, null, ex); + throw new PersistenceException(ex); + }; + } + + public void commit() { + withHandledException(userTx::commit); + } + + public void rollback() { + withHandledException(userTx::rollback); + } + + public void setRollbackOnly() { + withHandledException(userTx::setRollbackOnly); + } + + public boolean getRollbackOnly() { + try { + return userTx.getStatus() == Status.STATUS_MARKED_ROLLBACK; + } catch (SystemException e) { + throw new PersistenceException(e); + } + } + + public boolean isActive() { + try { + int txStatus = userTx.getStatus(); + return ((txStatus == Status.STATUS_ACTIVE) + || (txStatus == Status.STATUS_MARKED_ROLLBACK)); + } catch (SystemException e) { + throw new PersistenceException(e); + } + } + + public void setTimeout(Integer timeout) { + } + + public Integer getTimeout() { + return null; + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/WriterToReporterBridge.java b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/WriterToReporterBridge.java new file mode 100644 index 0000000000..6675f963af --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/java/org/glassfish/persistence/tck/WriterToReporterBridge.java @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ +package org.glassfish.persistence.tck; + +import java.io.IOException; +import java.io.Writer; + +/** + * + * @author Ondro Mihalyi + */ +class WriterToReporterBridge extends Writer { + + StringBuilder buffer = new StringBuilder(); + + @Override + public void write(char[] cbuf, int off, int len) throws IOException { + buffer.append(cbuf, off, len); + } + + @Override + public void flush() throws IOException { + if (!buffer.isEmpty()) { + Reporter.log(buffer.toString()); + buffer = new StringBuilder(); + } + } + + @Override + public void close() throws IOException { + flush(); + } + +} diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension new file mode 100644 index 0000000000..759d4f28f8 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.jboss.arquillian.core.spi.LoadableExtension @@ -0,0 +1 @@ +org.glassfish.persistence.tck.ArquillianExtension \ No newline at end of file diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.junit.jupiter.api.extension.Extension b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.junit.jupiter.api.extension.Extension new file mode 100644 index 0000000000..c766120c10 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.junit.jupiter.api.extension.Extension @@ -0,0 +1,2 @@ +org.jboss.arquillian.junit5.ArquillianExtension +org.glassfish.persistence.tck.TestInvocationInterceptor \ No newline at end of file diff --git a/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.junit.platform.launcher.TestExecutionListener b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.junit.platform.launcher.TestExecutionListener new file mode 100644 index 0000000000..4440e4aa58 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-arquillian-extension/src/main/resources/META-INF/services/org.junit.platform.launcher.TestExecutionListener @@ -0,0 +1 @@ +org.glassfish.persistence.tck.MyTestExecutionListener \ No newline at end of file diff --git a/glassfish-runner/persistence-tck/persistence-tck-run-ee/pom.xml b/glassfish-runner/persistence-tck/persistence-tck-run-ee/pom.xml new file mode 100644 index 0000000000..c2278ba9b7 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-run-ee/pom.xml @@ -0,0 +1,621 @@ + + + + 4.0.0 + + + org.eclipse.ee4j + project + 1.0.9 + + + jakarta.tck + persistence-tck-run-ee + 3.2.0 + pom + + + + 8.0.0-JDK17-M6 + ${project.build.directory}/glassfish8 + ${glassfish.home}/glassfish/modules + + + + ${glassfish.module.dir}/jakarta.persistence-api.jar,${glassfish.module.dir}/org.eclipse.persistence.jpa.jar,${glassfish.module.dir}/jakarta.servlet-api.jar,${glassfish.module.dir}/jakarta.transaction-api.jar,${glassfish.module.dir}/jakarta.ejb-api.jar,${glassfish.module.dir}/org.eclipse.persistence.antlr.jar,${glassfish.module.dir}/org.eclipse.persistence.asm.jar,${glassfish.module.dir}/org.eclipse.persistence.core.jar,${glassfish.module.dir}/org.eclipse.persistence.dbws.jar,${glassfish.module.dir}/org.eclipse.persistence.jpa.jpql.jar,${glassfish.module.dir}/org.eclipse.persistence.jpa.modelgen.processor.jar,${glassfish.module.dir}/org.eclipse.persistence.moxy.jar,${glassfish.module.dir}/org.eclipse.persistence.oracle.jar,${glassfish.module.dir}/jboss-logging.jar,${glassfish.module.dir}/jakarta.el-api.jar,${glassfish.module.dir}/expressly.jar,${glassfish.module.dir}/classmate.jar,${glassfish.module.dir}/jakarta.validation-api.jar + ${glassfish.module.dir}/jakarta.validation-api.jar,${glassfish.module.dir}/hibernate-validator-cdi.jar,${glassfish.module.dir}/hibernate-validator.jar + ${javadb.lib}/derbyclient.jar,${javadb.lib}/derbyshared.jar,${javadb.lib}/derbytools.jar + ${javadb.lib}/derbyclient.jar:${javadb.lib}/derbyshared.jar:${javadb.lib}/derbytools.jar + derby + org.eclipse.persistence.jpa.PersistenceProvider + org.apache.derby.jdbc.ClientDriver + jdbc:derby://localhost:1527/derbyDB;create=true + cts1 + cts1 + + + true + true + + + + 5.10.2 + 11.0.0-M1 + 3.2.0 + 3.2.0 + + + + ${glassfish.home}/bin/asadmin + ${glassfish.home}/javadb/lib + ./sql + ; + + + + + + org.junit + junit-bom + 5.10.2 + pom + import + + + org.jboss.arquillian + arquillian-bom + 1.8.0.Final + import + pom + + + org.slf4j + slf4j-jdk14 + 2.0.13 + + + jakarta.tck + persistence-tck-arquillian-extension + 3.2.0 + + + + + + + jakarta.persistence + jakarta.persistence-api + ${persistence.api.version} + test + + + + jakarta.tck + persistence-tck-common + ${project.version} + test + + + jakarta.persistence + jakarta.persistence-api + + + + + + jakarta.tck + persistence-tck-spec-tests + ${project.version} + test + + + jakarta.persistence + jakarta.persistence-api + + + + + + jakarta.tck + dbprocedures + ${persistence.tck.version} + test + + + jakarta.persistence + jakarta.persistence-api + + + + + + jakarta.tck + common + ${jakarta.ee.version} + test + + + + org.junit.jupiter + junit-jupiter + test + + + + jakarta.tck + persistence-tck-arquillian-extension + + + org.jboss.arquillian.container + arquillian-container-test-spi + + + org.jboss.arquillian.junit5 + arquillian-junit5-core + test + + + org.jboss.arquillian.junit5 + arquillian-junit5-container + test + + + org.slf4j + slf4j-jdk14 + + + org.omnifaces.arquillian + arquillian-glassfish-server-managed + 1.5 + + + org.glassfish.hk2 + hk2-locator + 3.0.2 + + + org.glassfish.jersey.inject + jersey-hk2 + 3.0.2 + + + org.glassfish.jersey.core + jersey-client + 3.0.2 + + + org.glassfish.jersey.core + jersey-common + 3.0.2 + + + org.glassfish.jersey.media + jersey-media-multipart + 3.0.2 + + + + + + + + src/test/resources + true + + + + + + org.apache.maven.plugins + maven-resources-plugin + 3.3.1 + + + org.apache.maven.plugins + maven-antrun-plugin + 3.1.0 + + + org.apache.maven.plugins + maven-dependency-plugin + 3.6.1 + + + org.apache.maven.plugins + maven-failsafe-plugin + 3.2.5 + + + org.apache.maven.plugins + maven-surefire-report-plugin + 3.2.5 + + + org.codehaus.mojo + exec-maven-plugin + 3.3.0 + + + + + + + org.apache.maven.plugins + maven-resources-plugin + + + testResources + + testResources + + process-test-resources + + + + + maven-enforcer-plugin + + + enforce-maven + + enforce + + + + + 3.8.6 + + + + + + + + + org.apache.maven.plugins + maven-dependency-plugin + + + unpack + pre-integration-test + + unpack + + + + + org.glassfish.main.distributions + ${glassfish-artifact-id} + ${glassfish.version} + zip + true + ${project.build.directory} + + + + + + + copy-lib + pre-integration-test + + copy + + + + + jakarta.tck + dbprocedures + true + ${project.build.directory} + dbprocedures.jar + + + jakarta.persistence + jakarta.persistence-api + ${glassfish.module.dir} + true + jakarta.persistence-api.jar + + + + + + + + + org.apache.maven.plugins + maven-antrun-plugin + + + initdb + pre-integration-test + + run + + + + + + + + + + + + + + + + + + + org.apache.maven.plugins + maven-failsafe-plugin + 3.2.5 + + + persistence-tests-1 + + integration-test + verify + + + -Xmx8192m + ${project.groupId}:persistence-tck-spec-tests + + **/*Client*.* + **/*JPASigTest*.* + + + true + glassfish + !org.jboss.shrinkwrap,org.glassfish,org.apache.derby,org.eclipse.persistence,jakarta,!jakarta.tck,org.javassis,aopalliance,eu.maveniverse,javax,org.eclipse.sisu,org.apache.ant + standalone + standalone + JPATCK + JPATCK2 + ${jakarta.persistence.provider} + ${jakarta.persistence.jdbc.driver} + ${jakarta.persistence.jdbc.url} + ${jakarta.persistence.jdbc.user} + ${jakarta.persistence.jdbc.password} + ${jpa.provider.implementation.specific.properties} + ${persistence.second.level.caching.supported} + + /tmp + /tmp + + ${db.supports.sequence} + INSERT INTO PURCHASE_ORDER(ID, TOTAL, DESCRIPTION) VALUES(?, ?, null) + SELECT ID, TOTAL FROM PURCHASE_ORDER WHERE ID=? + + + delete-jvm-options '-Xmx512m' + create-jvm-options '-Xmx1024m' + restart-domain + + + ${jdbc.db} + ${glassfish.module.dir}/jakarta.persistence-api.jar:${glassfish.module.dir}/org.eclipse.persistence.jpa.jar:${glassfish.module.dir}/jakarta.servlet-api.jar:${glassfish.module.dir}/jakarta.transaction-api.jar:${glassfish.module.dir}/jakarta.ejb-api.jar:${glassfish.module.dir}/org.eclipse.persistence.antlr.jar:${glassfish.module.dir}/org.eclipse.persistence.asm.jar:${glassfish.module.dir}/org.eclipse.persistence.core.jar:${glassfish.module.dir}/org.eclipse.persistence.dbws.jar:${glassfish.module.dir}/org.eclipse.persistence.jpa.jpql.jar:${glassfish.module.dir}/org.eclipse.persistence.jpa.modelgen.processor.jar:${glassfish.module.dir}/org.eclipse.persistence.moxy.jar:${glassfish.module.dir}/org.eclipse.persistence.oracle.jar:${glassfish.module.dir}/jboss-logging.jar:${glassfish.module.dir}/jakarta.el-api.jar:${glassfish.module.dir}/expressly.jar:${glassfish.module.dir}/classmate.jar:${glassfish.module.dir}/jakarta.validation-api.jar + org.glassfish.persistence.tck.SigTestArgumentsModifier + + + + + + persistence-tests-2 + + integration-test + verify + + + -Xmx8192m + true + ${project.groupId}:persistence-tck-spec-tests + **/ee/jakarta/tck/persistence/se/entityManagerFactory/Client2#createEntityManagerFactoryNoBeanValidatorTest + + ${jpa.classes} + ${jdbc.lib.classpath} + + + + standalone + standalone + + JPATCK + JPATCK2 + ${jakarta.persistence.provider} + ${jakarta.persistence.jdbc.driver} + ${jakarta.persistence.jdbc.url} + ${jakarta.persistence.jdbc.user} + ${jakarta.persistence.jdbc.password} + ${jpa.provider.implementation.specific.properties} + ${persistence.second.level.caching.supported} + + /tmp + /tmp + + + delete-jvm-options '-Xmx512m' + create-jvm-options '-Xmx4096m' + restart-domain + + + ${db.supports.sequence} + INSERT INTO PURCHASE_ORDER(ID, TOTAL, DESCRIPTION) VALUES(?, ?, null) + SELECT ID, TOTAL FROM PURCHASE_ORDER WHERE ID=? + + ${jdbc.db} + + + + + + + + org.apache.maven.plugins + maven-surefire-report-plugin + + false + + + + generate-failsafe-html-report + post-integration-test + + failsafe-report-only + + + ${project.build.directory}/test-reports + + + + + + + + + + full + + true + + + glassfish + + + + web + + web + + + + + derby + + true + + + + 10.15.2.0 + derby + org.apache.derby.jdbc.ClientDriver + + + + + org.apache.derby + derbyclient + ${derby.jdbc.version} + + + org.apache.derby + derbytools + ${derby.jdbc.version} + + + + + + + org.codehaus.mojo + exec-maven-plugin + + + stop-database-init + pre-integration-test + + exec + + + ${exec.asadmin} + + stop-database + + + 0 + 1 + + + + + start-database + pre-integration-test + + exec + + + ${exec.asadmin} + + start-database + + + + + stop-database-final + post-integration-test + + exec + + + ${exec.asadmin} + + stop-database + + + 0 + 1 + + + + + + + org.apache.maven.plugins + maven-antrun-plugin + + + install_java_procedures + pre-integration-test + + run + + + + + + + + CALL sqlj.remove_jar('APP.dbprocedures', 0); + CALL sqlj.install_jar('${project.build.directory}/dbprocedures.jar', 'APP.dbprocedures', 0); + CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY('derby.database.classpath', 'APP.dbprocedures'); + + + + + + + + + + + diff --git a/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.ddl.persistence.sprocs.sql b/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.ddl.persistence.sprocs.sql new file mode 100644 index 0000000000..92b5d49c2e --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.ddl.persistence.sprocs.sql @@ -0,0 +1,26 @@ +DROP PROCEDURE GetEmpOneFirstNameFromOut; +CREATE PROCEDURE GetEmpOneFirstNameFromOut (out OUT_PARAM VARCHAR(255)) language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.GetEmpOneFirstNameFromOut' parameter style java; + +DROP PROCEDURE GetEmpFirstNameFromOut; +CREATE PROCEDURE GetEmpFirstNameFromOut (in IN_PARAM INTEGER, out OUT_PARAM VARCHAR(255)) language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.GetEmpFirstNameFromOut' parameter style java; + +DROP PROCEDURE GetEmpLastNameFromInOut; +CREATE PROCEDURE GetEmpLastNameFromInOut (inout INOUT_PARAM VARCHAR(255)) language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.GetEmpLastNameFromInOut' parameter style java; + +DROP PROCEDURE GetEmpASCFromRS; +CREATE PROCEDURE GetEmpASCFromRS() language java dynamic result sets 1 external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.GetEmpASCFromRS' parameter style java; + +DROP PROCEDURE GetEmpIdFNameLNameFromRS; +CREATE PROCEDURE GetEmpIdFNameLNameFromRS (in IN_PARAM INTEGER) language java dynamic result sets 1 external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.GetEmpIdFNameLNameFromRS' parameter style java; + +DROP PROCEDURE GetEmpIdUsingHireDateFromOut; +CREATE PROCEDURE GetEmpIdUsingHireDateFromOut (in IN_PARAM DATE, out OUT_PARAM INTEGER) language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.GetEmpIdUsingHireDateFromOut' parameter style java; + +DROP PROCEDURE UpdateEmpSalaryColumn; +CREATE PROCEDURE UpdateEmpSalaryColumn() language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.UpdateEmpSalaryColumn' parameter style java; + +DROP PROCEDURE DeleteAllEmp; +CREATE PROCEDURE DeleteAllEmp() language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.DeleteAllEmp' parameter style java; + +DROP FUNCTION REPLACE; +CREATE FUNCTION REPLACE (origin_string VARCHAR(255), old_string VARCHAR(255), new_string VARCHAR(255)) RETURNS VARCHAR(255) language java external name 'ee.jakarta.tck.persistence.storedprocedures.CS_Procs.ReplaceString' parameter style java; diff --git a/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.ddl.persistence.sql b/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.ddl.persistence.sql new file mode 100644 index 0000000000..2f8cbe5491 --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.ddl.persistence.sql @@ -0,0 +1,934 @@ +ALTER TABLE PHONE_TABLE DROP CONSTRAINT FK_FOR_ADDRESS ; +ALTER TABLE CUSTOMER_TABLE DROP CONSTRAINT FK5_FOR_CUST ; +ALTER TABLE CUSTOMER_TABLE DROP CONSTRAINT FK6_FOR_CUST ; +ALTER TABLE ORDER_TABLE DROP CONSTRAINT FK4_FOR_CUST ; +ALTER TABLE ORDER_TABLE DROP CONSTRAINT FK0_FOR_LINEITEM ; +ALTER TABLE LINEITEM_TABLE DROP CONSTRAINT FK1_FOR_ORDER ; +ALTER TABLE LINEITEM_TABLE DROP CONSTRAINT FK_FOR_PRODUCT ; +ALTER TABLE SPOUSE_TABLE DROP CONSTRAINT FK_INFOTAB ; +ALTER TABLE SPOUSE_TABLE DROP CONSTRAINT FK7_CUSTOMERTAB ; +ALTER TABLE INFO_TABLE DROP CONSTRAINT FK_SPOUSETAB ; +ALTER TABLE FKS_ANOOP_CNOOP DROP CONSTRAINT FK2_ALIAS ; +ALTER TABLE FKS_ANOOP_CNOOP DROP CONSTRAINT FK8_CUSTOMER ; +ALTER TABLE FKS_ALIAS_CUSTOMER DROP CONSTRAINT FK_FOR_CUSTOMER ; +ALTER TABLE FKS_ALIAS_CUSTOMER DROP CONSTRAINT FK_FOR_ALIAS ; +ALTER TABLE ALIAS_TABLE DROP CONSTRAINT FK1_FOR_CUSTOMER ; +ALTER TABLE ALIAS_TABLE DROP CONSTRAINT FK2_FOR_CUSTOMER ; +ALTER TABLE CREDITCARD_TABLE DROP CONSTRAINT FK3_FOR_CUST ; +ALTER TABLE CREDITCARD_TABLE DROP CONSTRAINT FK_FOR_ORDER ; +ALTER TABLE EMPLOYEE DROP CONSTRAINT FK_MGR ; +ALTER TABLE EMPLOYEE DROP CONSTRAINT FK_DEPT ; +ALTER TABLE EMPLOYEE DROP CONSTRAINT FK_PROJECT ; +ALTER TABLE EMPLOYEE DROP CONSTRAINT FK_INS ; + +ALTER TABLE STUDENT_COURSE DROP CONSTRAINT STDNTCOURSEStdntID ; +ALTER TABLE STUDENT_COURSE DROP CONSTRAINT STDNTCOURSEcrsesID ; +ALTER TABLE ENROLLMENTS DROP CONSTRAINT ENROLLMENTSSTUDENT ; +ALTER TABLE ENROLLMENTS DROP CONSTRAINT NROLLMENTSSEMESTER ; +ALTER TABLE COURSE_STUDENT DROP CONSTRAINT CRSESTUDENTCurseID ; +ALTER TABLE COURSE_STUDENT DROP CONSTRAINT CRSSTUDENTstdntsID ; + +ALTER TABLE PARTTIMEEMPLOYEE DROP CONSTRAINT FK_ADDR ; +ALTER TABLE PARTTIMEEMPLOYEE DROP CONSTRAINT FK_DEPT2 ; +ALTER TABLE TEAM DROP CONSTRAINT COMPANY_COMPANYID ; +ALTER TABLE COMPANY DROP CONSTRAINT FK_ADDRESS ; +ALTER TABLE PERSON DROP CONSTRAINT INSURANCE_INSID ; +ALTER TABLE PERSON DROP CONSTRAINT TEAM_TEAMID ; +ALTER TABLE PERSON DROP CONSTRAINT PROJECT_PROJID ; +ALTER TABLE PERSON_ANNUALREVIEW DROP CONSTRAINT ANNUALREVIEWS_AID ; +ALTER TABLE PERSON_ANNUALREVIEW DROP CONSTRAINT PERSON_PERSONID; +ALTER TABLE PROJECT_PERSON DROP CONSTRAINT PROJ_PROJID; +ALTER TABLE PROJECT_PERSON DROP CONSTRAINT PERSONS_PERSONID; +ALTER TABLE PERSON_INSURANCE DROP CONSTRAINT P_PERSONID ; +ALTER TABLE PERSON_INSURANCE DROP CONSTRAINT INS_INSID ; +ALTER TABLE ORDER1 DROP CONSTRAINT FK1_FOR_ITEM ; +ALTER TABLE ORDER2 DROP CONSTRAINT FK2_FOR_ITEM ; +ALTER TABLE ORDER3 DROP CONSTRAINT FK3_FOR_ITEM ; +ALTER TABLE RETAILORDER2 DROP CONSTRAINT FK_FOR_CUST; +ALTER TABLE EMP_MAPKEYCOL DROP CONSTRAINT FK_DEPT1 ; +ALTER TABLE EMP_MAPKEYCOL DROP CONSTRAINT FK_DEPT3 ; +ALTER TABLE EMP_MAPKEYCOL DROP CONSTRAINT FK_DEPT4 ; +ALTER TABLE EMP_MAPKEYCOL2 DROP CONSTRAINT FK_DEPT5 ; + +DROP TABLE PHONE_TABLE; +CREATE TABLE PHONE_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, AREA VARCHAR(255) , PHONE_NUMBER VARCHAR(255) , FK_FOR_ADDRESS VARCHAR(255) ); + +DROP TABLE ADDRESS; +CREATE TABLE ADDRESS ( ID VARCHAR(255) PRIMARY KEY NOT NULL, STREET VARCHAR(255) , CITY VARCHAR(255) , STATE VARCHAR(255) , ZIP VARCHAR(255) ); + +DROP TABLE CUSTOMER_TABLE; +CREATE TABLE CUSTOMER_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255), COUNTRY VARCHAR(255), CODE VARCHAR(255), FK5_FOR_CUSTOMER_TABLE VARCHAR(255) , FK6_FOR_CUSTOMER_TABLE VARCHAR(255)); + +ALTER TABLE PHONES DROP CONSTRAINT FK_FOR_PHONES ; +ALTER TABLE EMPLOYEES DROP CONSTRAINT FK_FOR_EMPLOYEES ; + +DROP TABLE CUST_TABLE; +CREATE TABLE CUST_TABLE ( CUST_ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255), COUNTRY VARCHAR(255), CODE VARCHAR(255)); + +DROP TABLE PHONES; +CREATE TABLE PHONES (ID VARCHAR(255), PHONE_NUMBER VARCHAR(255), FK_FOR_PHONES VARCHAR(255)); +ALTER TABLE PHONES ADD CONSTRAINT FK_FOR_PHONES FOREIGN KEY (FK_FOR_PHONES) REFERENCES CUST_TABLE (CUST_ID) ; + +DROP TABLE EMPLOYEES ; +CREATE TABLE EMPLOYEES (ID VARCHAR(255), LASTNAMEEMPLOYEES VARCHAR(255), FK_FOR_EMPLOYEES VARCHAR(255)); +ALTER TABLE EMPLOYEES ADD CONSTRAINT FK_FOR_EMPLOYEES FOREIGN KEY (FK_FOR_EMPLOYEES) REFERENCES CUST_TABLE (CUST_ID) ; + +DROP TABLE TRIM_TABLE; +CREATE TABLE TRIM_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME CHAR(30) NOT NULL); + +DROP TABLE ALIAS_TABLE; +CREATE TABLE ALIAS_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, ALIAS VARCHAR(255) , FK1_FOR_CUSTOMER_TABLE VARCHAR(255) , FK2_FOR_CUSTOMER_TABLE VARCHAR(255) ); + +DROP TABLE FKS_ALIAS_CUSTOMER; +CREATE TABLE FKS_ALIAS_CUSTOMER ( FK_FOR_CUSTOMER_TABLE VARCHAR(255) NOT NULL, FK_FOR_ALIAS_TABLE VARCHAR(255) ); + +DROP table FKS_ANOOP_CNOOP ; +CREATE TABLE FKS_ANOOP_CNOOP( FK8_FOR_CUSTOMER_TABLE VARCHAR(255) , FK2_FOR_ALIAS_TABLE VARCHAR(255)); + +DROP TABLE CREDITCARD_TABLE; +CREATE TABLE CREDITCARD_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, TYPE VARCHAR(255) , EXPIRES VARCHAR(255) , APPROVED DECIMAL(18,0) , CREDITCARD_NUMBER VARCHAR(255) , BALANCE DOUBLE, FK3_FOR_CUSTOMER_TABLE VARCHAR(255) , FK_FOR_ORDER_TABLE VARCHAR(255) ); + +DROP TABLE ORDER_TABLE; +CREATE TABLE ORDER_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, TOTALPRICE DOUBLE , FK4_FOR_CUSTOMER_TABLE VARCHAR(255) , FK0_FOR_LINEITEM_TABLE VARCHAR(255) ); + +DROP TABLE PRODUCT_DETAILS; +CREATE TABLE PRODUCT_DETAILS ( ID VARCHAR(255) PRIMARY KEY NOT NULL, WHOUSE VARCHAR(255) , LICENSE_KEY INT); + +DROP TABLE PRODUCT_TABLE; +CREATE TABLE PRODUCT_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , PRICE DOUBLE, QUANTITY INT, PNUM INT, PRODUCT_TYPE VARCHAR(255), INCEPTION DATE, SOLD DATE, MODEL INT, REV DOUBLE); + +DROP TABLE PRODUCT_TABLE_DISCRIMINATOR; +CREATE TABLE PRODUCT_TABLE_DISCRIMINATOR ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255), QUANTITY INT, PNUM INT, PRICE DOUBLE, PRODUCT_TYPE INT); + +DROP TABLE PRICED_PRODUCT_TABLE ; +CREATE TABLE PRICED_PRODUCT_TABLE (ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255), PRICE DOUBLE, QUANTITY INT, PNUM INT) ; + +DROP table INFO_TABLE ; +CREATE TABLE INFO_TABLE (ID VARCHAR(255) PRIMARY KEY NOT NULL, INFOSTREET VARCHAR(255), INFOCITY VARCHAR(255), INFOSTATE VARCHAR(255), INFOZIP VARCHAR(255), FK_FOR_SPOUSE_TABLE VARCHAR(255) ) ; + +DROP table SPOUSE_TABLE ; +CREATE TABLE SPOUSE_TABLE (ID VARCHAR(255) PRIMARY KEY NOT NULL, FIRSTNAME VARCHAR(255), MAIDENNAME VARCHAR(255), LASTNAME VARCHAR(255), SOCSECNUM VARCHAR(255), FK7_FOR_CUSTOMER_TABLE VARCHAR(255), FK_FOR_INFO_TABLE VARCHAR(255) ); + +DROP TABLE LINEITEM_TABLE; +CREATE TABLE LINEITEM_TABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, QUANTITY INT , FK_FOR_PRODUCT_TABLE VARCHAR(255) , FK1_FOR_ORDER_TABLE VARCHAR(255) ); + +ALTER TABLE PHONE_TABLE ADD CONSTRAINT FK_FOR_ADDRESS FOREIGN KEY (FK_FOR_ADDRESS) REFERENCES ADDRESS (ID) ; + +ALTER TABLE ALIAS_TABLE ADD CONSTRAINT FK1_FOR_CUSTOMER FOREIGN KEY (FK1_FOR_CUSTOMER_TABLE) REFERENCES CUSTOMER_TABLE (ID) ; + +ALTER TABLE ALIAS_TABLE ADD CONSTRAINT FK2_FOR_CUSTOMER FOREIGN KEY (FK2_FOR_CUSTOMER_TABLE) REFERENCES CUSTOMER_TABLE (ID) ; + +ALTER TABLE CUSTOMER_TABLE ADD CONSTRAINT FK5_FOR_CUST FOREIGN KEY (FK5_FOR_CUSTOMER_TABLE) REFERENCES ADDRESS (ID) ; + +ALTER TABLE CUSTOMER_TABLE ADD CONSTRAINT FK6_FOR_CUST FOREIGN KEY (FK6_FOR_CUSTOMER_TABLE) REFERENCES ADDRESS (ID) ; + +ALTER TABLE FKS_ALIAS_CUSTOMER ADD CONSTRAINT FK_FOR_CUSTOMER FOREIGN KEY (FK_FOR_CUSTOMER_TABLE) REFERENCES CUSTOMER_TABLE (ID) ; + +ALTER TABLE FKS_ALIAS_CUSTOMER ADD CONSTRAINT FK_FOR_ALIAS FOREIGN KEY (FK_FOR_ALIAS_TABLE) REFERENCES ALIAS_TABLE (ID) ; + +ALTER TABLE FKS_ANOOP_CNOOP add constraint FK2_ALIAS Foreign Key (FK2_FOR_ALIAS_TABLE) references ALIAS_TABLE(id) ; + +ALTER TABLE FKS_ANOOP_CNOOP add constraint FK8_CUSTOMER Foreign Key (FK8_FOR_CUSTOMER_TABLE) references CUSTOMER_TABLE(id) ; + +ALTER TABLE CREDITCARD_TABLE ADD CONSTRAINT FK3_FOR_CUST FOREIGN KEY (FK3_FOR_CUSTOMER_TABLE) REFERENCES CUSTOMER_TABLE (ID) ; + +ALTER TABLE CREDITCARD_TABLE ADD CONSTRAINT FK_FOR_ORDER FOREIGN KEY (FK_FOR_ORDER_TABLE) REFERENCES ORDER_TABLE (ID) ; + +ALTER TABLE ORDER_TABLE ADD CONSTRAINT FK4_FOR_CUST FOREIGN KEY (FK4_FOR_CUSTOMER_TABLE) REFERENCES CUSTOMER_TABLE (ID) ; + +ALTER TABLE ORDER_TABLE ADD CONSTRAINT FK0_FOR_LINEITEM FOREIGN KEY (FK0_FOR_LINEITEM_TABLE) REFERENCES LINEITEM_TABLE (ID) ; + +ALTER TABLE LINEITEM_TABLE ADD CONSTRAINT FK_FOR_PRODUCT FOREIGN KEY (FK_FOR_PRODUCT_TABLE) REFERENCES PRODUCT_TABLE (ID) ; + +ALTER TABLE LINEITEM_TABLE ADD CONSTRAINT FK1_FOR_ORDER FOREIGN KEY (FK1_FOR_ORDER_TABLE) REFERENCES ORDER_TABLE (ID) ; + +ALTER TABLE SPOUSE_TABLE add constraint FK7_CUSTOMERTAB Foreign Key (FK7_FOR_CUSTOMER_TABLE) references CUSTOMER_TABLE(ID) ; + +ALTER TABLE SPOUSE_TABLE add constraint FK_INFOTAB Foreign Key (FK_FOR_INFO_TABLE) references INFO_TABLE(ID) ; + +ALTER TABLE INFO_TABLE add constraint FK_SPOUSETAB Foreign Key (FK_FOR_SPOUSE_TABLE) references SPOUSE_TABLE(ID) ; + +DROP TABLE EMPLOYEE; +CREATE TABLE EMPLOYEE (ID INT NOT NULL, FIRSTNAME VARCHAR(255) , LASTNAME VARCHAR(255), HIREDATE DATE, SALARY REAL NOT NULL, STATUS VARCHAR(255), THEORDERCOLUMN INT, EMPLOYEES_ORDER INT, FK_MGR INT, FK_DEPT INT, FK_PROJECT INT , FK_INS INT, CONSTRAINT PK_EMPLOYEE PRIMARY KEY (ID)) ; + +DROP TABLE DEPARTMENT ; +CREATE TABLE DEPARTMENT (NAME VARCHAR(255) , ID INT NOT NULL, COMPANY_COMPANYID INT, CONSTRAINT PK_DEPARTMENT PRIMARY KEY (ID)) ; + +DROP TABLE PARTTIMEEMPLOYEE; +CREATE TABLE PARTTIMEEMPLOYEE (ID INT NOT NULL, FIRSTNAME VARCHAR(255) , LASTNAME VARCHAR(255), HIREDATE DATE, SALARY REAL NOT NULL, ADDRESS_ID VARCHAR(255), STATUS VARCHAR(255), FK_DEPT2 INT , FK_PROJECT INT, CONSTRAINT PK_PARTTIMEEMPLOYEE PRIMARY KEY (ID)) ; +ALTER TABLE PARTTIMEEMPLOYEE ADD CONSTRAINT FK_ADDR FOREIGN KEY (ADDRESS_ID) REFERENCES ADDRESS (ID) ; + +ALTER TABLE PARTTIMEEMPLOYEE ADD CONSTRAINT FK_DEPT2 FOREIGN KEY (FK_DEPT2) REFERENCES DEPARTMENT (ID) ; + +DROP TABLE INSURANCE ; +CREATE TABLE INSURANCE (INSID INT NOT NULL, CARRIER VARCHAR(255) , CONSTRAINT PK_INSURANCE PRIMARY KEY (INSID)) ; + +DROP TABLE COFFEE; +CREATE TABLE COFFEE (ID INT NOT NULL, BRANDNAME VARCHAR(25), PRICE REAL, CONSTRAINT PK_COFFEE PRIMARY KEY (ID)); + +DROP TABLE COMPANY; +CREATE TABLE COMPANY (COMPANYID INT NOT NULL, NAME VARCHAR(25), ADDRESS_ID VARCHAR(255), CONSTRAINT PK_COMPANY PRIMARY KEY (COMPANYID)); + +ALTER TABLE COMPANY ADD CONSTRAINT FK_ADDRESS FOREIGN KEY (ADDRESS_ID) REFERENCES ADDRESS (ID) ; + +ALTER TABLE DEPARTMENT ADD CONSTRAINT FK_COMPANY FOREIGN KEY (COMPANY_COMPANYID) REFERENCES COMPANY (COMPANYID) ; + +DROP TABLE DEPARTMENT2 ; +CREATE TABLE DEPARTMENT2 (ID INT NOT NULL, NAME VARCHAR(255), CONSTRAINT PK_DEPARTMENT2 PRIMARY KEY (ID)) ; + +DROP TABLE TEAM; +CREATE TABLE TEAM (NAME VARCHAR(255) NOT NULL, TEAMID INT NOT NULL, COMPANY_COMPANYID INT, CONSTRAINT PK_TEAM PRIMARY KEY (TEAMID)); + +ALTER TABLE TEAM ADD CONSTRAINT COMPANY_COMPANYID FOREIGN KEY (COMPANY_COMPANYID) REFERENCES COMPANY(COMPANYID); + +DROP TABLE ANNUALREVIEW ; +CREATE TABLE ANNUALREVIEW (AID INT NOT NULL, SERVICE INT, CONSTRAINT PK_ANNUAL PRIMARY KEY (AID)); + +DROP TABLE PERSON ; +CREATE TABLE PERSON (PERSONID INT NOT NULL, FIRSTNAME VARCHAR(255) , LASTNAME VARCHAR(255) , PROJECT_PROJID INT , INSURANCE_INSID INT , TEAM_TEAMID INT , CONSTRAINT PK_PERSON PRIMARY KEY (PERSONID)) ; + +DROP TABLE PROJECT; +CREATE TABLE PROJECT (PROJID INT NOT NULL, NAME VARCHAR(25), BUDGET DECIMAL(18,0), CONSTRAINT PK_PROJECT PRIMARY KEY (PROJID)); + +DROP TABLE PROJECT_PERSON; +CREATE TABLE PROJECT_PERSON (PROJECTS_PROJID INT , PERSONS_PERSONID INT ); + +DROP TABLE PERSON_INSURANCE; +CREATE TABLE PERSON_INSURANCE (PERSON_PERSONID INT, INSURANCE_INSID INT ); + +DROP TABLE PERSON_ANNUALREVIEW; +CREATE TABLE PERSON_ANNUALREVIEW (PERSON_PERSONID INT, ANNUALREVIEWS_AID INT ); + +ALTER TABLE EMPLOYEE ADD CONSTRAINT FK_MGR FOREIGN KEY (FK_MGR) REFERENCES EMPLOYEE (ID) ; +ALTER TABLE EMPLOYEE ADD CONSTRAINT FK_DEPT FOREIGN KEY (FK_DEPT) REFERENCES DEPARTMENT (ID) ; +ALTER TABLE EMPLOYEE ADD CONSTRAINT FK_PROJECT FOREIGN KEY (FK_PROJECT) REFERENCES PROJECT (PROJID) ; +ALTER TABLE EMPLOYEE ADD CONSTRAINT FK_INS FOREIGN KEY (FK_INS) REFERENCES INSURANCE (INSID) ; + +ALTER TABLE PERSON ADD CONSTRAINT TEAM_TEAMID FOREIGN KEY (TEAM_TEAMID) REFERENCES TEAM(TEAMID); +ALTER TABLE PERSON ADD CONSTRAINT PROJECT_PROJID FOREIGN KEY (PROJECT_PROJID) REFERENCES PROJECT(PROJID); +ALTER TABLE PERSON ADD CONSTRAINT INSURANCE_INSID FOREIGN KEY (INSURANCE_INSID) REFERENCES INSURANCE(INSID); + +ALTER TABLE PROJECT_PERSON ADD CONSTRAINT PROJ_PROJID Foreign Key (PROJECTS_PROJID) references PROJECT(PROJID); +ALTER TABLE PROJECT_PERSON ADD CONSTRAINT PERSONS_PERSONID Foreign Key (PERSONS_PERSONID) references PERSON(PERSONID); + + +ALTER TABLE PERSON_ANNUALREVIEW ADD CONSTRAINT ANNUALREVIEWS_AID Foreign Key (ANNUALREVIEWS_AID) references ANNUALREVIEW(AID); +ALTER TABLE PERSON_ANNUALREVIEW ADD CONSTRAINT PERSON_PERSONID Foreign Key (PERSON_PERSONID) references PERSON(PERSONID); + +ALTER TABLE PERSON_INSURANCE ADD CONSTRAINT P_PERSONID Foreign Key (PERSON_PERSONID) references PERSON(PERSONID); +ALTER TABLE PERSON_INSURANCE ADD CONSTRAINT INS_INSID Foreign Key (INSURANCE_INSID) references INSURANCE(INSID); + +DROP TABLE BEANEJB_1X1_BI_BTOB; +CREATE TABLE BEANEJB_1X1_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1X1_BI_BTOB VARCHAR(255) , FK2_FOR_AEJB_1X1_BI_BTOB VARCHAR(255) , FK1_FOR_BEJB_1X1_BI_BTOB VARCHAR(255) , FK2_FOR_BEJB_1X1_BI_BTOB VARCHAR(255) ); + +DROP TABLE BEJB_1X1_BI_BTOB; +CREATE TABLE BEJB_1X1_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1X1_BI_BTOB VARCHAR(255) ); + +DROP TABLE AEJB_1X1_BI_BTOB; +CREATE TABLE AEJB_1X1_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE DATES_TABLE DROP CONSTRAINT FK_FOR_DATES_TABLE ; + +DROP TABLE A_BASIC; +CREATE TABLE A_BASIC ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE INT, BASICINTEGER INT, BASICSHORT SMALLINT, BASICBIGSHORT SMALLINT, BASICFLOAT FLOAT, BASICBIGFLOAT FLOAT, BASICLONG BIGINT, BASICBIGLONG BIGINT, BASICDOUBLE DOUBLE, BASICBIGDOUBLE DOUBLE, BASICCHAR CHAR, BASICCHARARRAY VARCHAR(448), BASICBIGCHARARRAY VARCHAR(448), BASICBYTEARRAY LONG VARCHAR FOR BIT DATA, BASICBIGBYTEARRAY LONG VARCHAR FOR BIT DATA, BASICBIGINTEGER DECIMAL(18,0), BASICBIGDECIMAL DECIMAL(18,0), BASICDATE DATE, BASICTIME TIME, BASICCALENDAR DATE, BASICTIMESTAMP TIMESTAMP ); + +DROP TABLE DATES_TABLE; +CREATE TABLE DATES_TABLE (ID VARCHAR(255), DATES VARCHAR(255), FK_FOR_DATES_TABLE VARCHAR(255)); +ALTER TABLE DATES_TABLE ADD CONSTRAINT FK_FOR_DATES_TABLE FOREIGN KEY (FK_FOR_DATES_TABLE) REFERENCES A_BASIC (ID) ; + +DROP TABLE DATE_TABLE ; +CREATE TABLE DATE_TABLE (ID DATE, STRINGVERSION VARCHAR(255)) ; + +DROP TABLE A_BIGINTEGER; +CREATE TABLE A_BIGINTEGER ( ID VARCHAR(255), NAME VARCHAR(255) , VALUE INT, BASICINTEGER INT, BASICSHORT SMALLINT, BASICBIGSHORT SMALLINT, BASICFLOAT FLOAT, BASICBIGFLOAT FLOAT, BASICLONG BIGINT, BASICBIGLONG BIGINT, BASICDOUBLE DOUBLE, BASICBIGDOUBLE DOUBLE, BASICCHAR CHAR, BASICCHARARRAY VARCHAR(448), BASICBIGCHARARRAY VARCHAR(448), BASICBYTEARRAY LONG VARCHAR FOR BIT DATA, BASICBIGBYTEARRAY LONG VARCHAR FOR BIT DATA, BASICBIGINTEGER DECIMAL(18,0) PRIMARY KEY NOT NULL, BASICBIGDECIMAL DECIMAL(18,0), BASICDATE DATE, BASICTIME TIME, BASICCALENDAR DATE, BASICTIMESTAMP TIMESTAMP ); + +DROP TABLE A_BIGDECIMAL; +CREATE TABLE A_BIGDECIMAL ( ID VARCHAR(255), NAME VARCHAR(255) , VALUE INT, BASICINTEGER INT, BASICSHORT SMALLINT, BASICBIGSHORT SMALLINT, BASICFLOAT FLOAT, BASICBIGFLOAT FLOAT, BASICLONG BIGINT, BASICBIGLONG BIGINT, BASICDOUBLE DOUBLE, BASICBIGDOUBLE DOUBLE, BASICCHAR CHAR, BASICCHARARRAY VARCHAR(448), BASICBIGCHARARRAY VARCHAR(448), BASICBYTEARRAY LONG VARCHAR FOR BIT DATA, BASICBIGBYTEARRAY LONG VARCHAR FOR BIT DATA, BASICBIGINTEGER DECIMAL(18,0), BASICBIGDECIMAL DECIMAL(18,0) PRIMARY KEY NOT NULL, BASICDATE DATE, BASICTIME TIME, BASICCALENDAR DATE, BASICTIMESTAMP TIMESTAMP ); + +ALTER TABLE BEANEJB_1X1_BI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_1X1_B FOREIGN KEY (FK1_FOR_AEJB_1X1_BI_BTOB) REFERENCES AEJB_1X1_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1X1_BI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_1X1_B FOREIGN KEY (FK2_FOR_AEJB_1X1_BI_BTOB) REFERENCES AEJB_1X1_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1X1_BI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_1X1_B FOREIGN KEY (FK1_FOR_BEJB_1X1_BI_BTOB) REFERENCES BEJB_1X1_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1X1_BI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_1X1_B FOREIGN KEY (FK2_FOR_BEJB_1X1_BI_BTOB) REFERENCES BEJB_1X1_BI_BTOB (ID) ; + +ALTER TABLE BEJB_1X1_BI_BTOB ADD CONSTRAINT FK_FOR_AEJB_1X1_BI FOREIGN KEY (FK_FOR_AEJB_1X1_BI_BTOB) REFERENCES AEJB_1X1_BI_BTOB (ID) ; + +DROP TABLE BEANEJB_1X1_BI_CASCADE; +CREATE TABLE BEANEJB_1X1_BI_CASCADE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1X1_BI_CASCADE VARCHAR(255) , FK2_FOR_AEJB_1X1_BI_CASCADE VARCHAR(255) , FK1_FOR_BEJB_1X1_BI_CASCADE VARCHAR(255) , FK2_FOR_BEJB_1X1_BI_CASCADE VARCHAR(255) ); + +DROP TABLE BEJB_1X1_BI_CASCADE; +CREATE TABLE BEJB_1X1_BI_CASCADE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1X1_BI_CASCADE VARCHAR(255) ); + +DROP TABLE AEJB_1X1_BI_CASCADE; +CREATE TABLE AEJB_1X1_BI_CASCADE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_1X1_BI_CASCADE ADD CONSTRAINT FK1_FOR_AEJB_1X1_1 FOREIGN KEY (FK1_FOR_AEJB_1X1_BI_CASCADE) REFERENCES AEJB_1X1_BI_CASCADE (ID) ; + +ALTER TABLE BEANEJB_1X1_BI_CASCADE ADD CONSTRAINT FK2_FOR_AEJB_1X1_1 FOREIGN KEY (FK2_FOR_AEJB_1X1_BI_CASCADE) REFERENCES AEJB_1X1_BI_CASCADE (ID) ; + +ALTER TABLE BEANEJB_1X1_BI_CASCADE ADD CONSTRAINT FK1_FOR_BEJB_1X1_1 FOREIGN KEY (FK1_FOR_BEJB_1X1_BI_CASCADE) REFERENCES BEJB_1X1_BI_CASCADE (ID) ; + +ALTER TABLE BEANEJB_1X1_BI_CASCADE ADD CONSTRAINT FK2_FOR_BEJB_1X1_1 FOREIGN KEY (FK2_FOR_BEJB_1X1_BI_CASCADE) REFERENCES BEJB_1X1_BI_CASCADE (ID) ; + +ALTER TABLE BEJB_1X1_BI_CASCADE ADD CONSTRAINT FK_FOR_AEJB_1X1_B1 FOREIGN KEY (FK_FOR_AEJB_1X1_BI_CASCADE) REFERENCES AEJB_1X1_BI_CASCADE (ID) ; + +DROP TABLE BEANEJB_1X1_UNI_BTOB; +CREATE TABLE BEANEJB_1X1_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1X1_UNI_BTOB VARCHAR(255) , FK2_FOR_AEJB_1X1_UNI_BTOB VARCHAR(255) , FK1_FOR_BEJB_1X1_UNI_BTOB VARCHAR(255) , FK2_FOR_BEJB_1X1_UNI_BTOB VARCHAR(255) ); + +DROP TABLE BEJB_1X1_UNI_BTOB; +CREATE TABLE BEJB_1X1_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1X1_UNI_BTOB VARCHAR(255) ); + +DROP TABLE AEJB_1X1_UNI_BTOB; +CREATE TABLE AEJB_1X1_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_1X1_UNI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_1X1_U FOREIGN KEY (FK1_FOR_AEJB_1X1_UNI_BTOB) REFERENCES AEJB_1X1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1X1_UNI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_1X1_U FOREIGN KEY (FK2_FOR_AEJB_1X1_UNI_BTOB) REFERENCES AEJB_1X1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1X1_UNI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_1X1_U FOREIGN KEY (FK1_FOR_BEJB_1X1_UNI_BTOB) REFERENCES BEJB_1X1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1X1_UNI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_1X1_U FOREIGN KEY (FK2_FOR_BEJB_1X1_UNI_BTOB) REFERENCES BEJB_1X1_UNI_BTOB (ID) ; + +ALTER TABLE BEJB_1X1_UNI_BTOB ADD CONSTRAINT FK_FOR_AEJB_1X1_UN FOREIGN KEY (FK_FOR_AEJB_1X1_UNI_BTOB) REFERENCES AEJB_1X1_UNI_BTOB (ID) ; + +DROP TABLE BEANEJB_1XM_BI_BTOB; +CREATE TABLE BEANEJB_1XM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1XM_BI_BTOB VARCHAR(255) , FK2_FOR_AEJB_1XM_BI_BTOB VARCHAR(255) , FK1_FOR_BEJB_1XM_BI_BTOB VARCHAR(255) , FK2_FOR_BEJB_1XM_BI_BTOB VARCHAR(255) , FK3_FOR_BEJB_1XM_BI_BTOB VARCHAR(255) , FK4_FOR_BEJB_1XM_BI_BTOB VARCHAR(255) ); + +DROP TABLE BEJB_1XM_BI_BTOB; +CREATE TABLE BEJB_1XM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1XM_BI_BTOB VARCHAR(255) ); + +DROP TABLE BNE_1XM_BI_BTOB; +CREATE TABLE BNE_1XM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, STREET VARCHAR(255), CITY VARCHAR(255), STATE VARCHAR(255), ZIP VARCHAR(255), PLUSFOUR VARCHAR(255), FK_FOR_ANE_1XM_BI_BTOB VARCHAR(255) ); + +DROP TABLE B_EMBEDDABLE; +CREATE TABLE B_EMBEDDABLE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, STREET VARCHAR(255), CITY VARCHAR(255), STATE VARCHAR(255), ZIP VARCHAR(255), PLUSFOUR VARCHAR(255)); + +DROP TABLE AEJB_1XM_BI_BTOB; +CREATE TABLE AEJB_1XM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +DROP TABLE ANE_1XM_BI_BTOB; +CREATE TABLE ANE_1XM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL ); + +DROP TABLE A_ADDRESS; +CREATE TABLE A_ADDRESS ( A_ID VARCHAR(255) NOT NULL, STREET VARCHAR(30), CITY VARCHAR(30), STATE VARCHAR(2), ZIP VARCHAR(10) ); + +DROP TABLE COLTAB_ADDRESS; +CREATE TABLE COLTAB_ADDRESS ( A_ID VARCHAR(255) NOT NULL, STREET VARCHAR(30), CITY VARCHAR(30), STATE VARCHAR(2), ZIP VARCHAR(10) ); + +DROP TABLE AEC; +CREATE TABLE AEC ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) ); + +DROP TABLE COLTAB; +CREATE TABLE COLTAB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) ); + + +ALTER TABLE BEANEJB_1XM_BI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_1XM_B FOREIGN KEY (FK1_FOR_AEJB_1XM_BI_BTOB) REFERENCES AEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_1XM_B FOREIGN KEY (FK2_FOR_AEJB_1XM_BI_BTOB) REFERENCES AEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_1XM_B FOREIGN KEY (FK1_FOR_BEJB_1XM_BI_BTOB) REFERENCES BEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_1XM_B FOREIGN KEY (FK2_FOR_BEJB_1XM_BI_BTOB) REFERENCES BEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_BTOB ADD CONSTRAINT FK3_FOR_BEJB_1XM_B FOREIGN KEY (FK3_FOR_BEJB_1XM_BI_BTOB) REFERENCES BEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_BTOB ADD CONSTRAINT FK4_FOR_BEJB_1XM_B FOREIGN KEY (FK4_FOR_BEJB_1XM_BI_BTOB) REFERENCES BEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BEJB_1XM_BI_BTOB ADD CONSTRAINT FK_FOR_AEJB_1XM_BI FOREIGN KEY (FK_FOR_AEJB_1XM_BI_BTOB) REFERENCES AEJB_1XM_BI_BTOB (ID) ; + +ALTER TABLE BNE_1XM_BI_BTOB ADD CONSTRAINT FK_FOR_ANE_1XM_BI FOREIGN KEY (FK_FOR_ANE_1XM_BI_BTOB) REFERENCES ANE_1XM_BI_BTOB (ID) ; + +DROP TABLE BEANEJB_1XM_BI_CASCADE; +CREATE TABLE BEANEJB_1XM_BI_CASCADE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1XM_BI_CASCADE VARCHAR(255) , FK2_FOR_AEJB_1XM_BI_CASCADE VARCHAR(255) , FK1_FOR_BEJB_1XM_BI_CASCADE VARCHAR(255) , FK2_FOR_BEJB_1XM_BI_CASCADE VARCHAR(255) ); + +DROP TABLE BEJB_1XM_BI_CASCADE; +CREATE TABLE BEJB_1XM_BI_CASCADE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1XM_BI_CASCADE VARCHAR(255) ); + +DROP TABLE AEJB_1XM_BI_CASCADE; +CREATE TABLE AEJB_1XM_BI_CASCADE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_1XM_BI_CASCADE ADD CONSTRAINT FK1_FOR_AEJB_1XM_1 FOREIGN KEY (FK1_FOR_AEJB_1XM_BI_CASCADE) REFERENCES AEJB_1XM_BI_CASCADE (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_CASCADE ADD CONSTRAINT FK2_FOR_AEJB_1XM_1 FOREIGN KEY (FK2_FOR_AEJB_1XM_BI_CASCADE) REFERENCES AEJB_1XM_BI_CASCADE (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_CASCADE ADD CONSTRAINT FK1_FOR_BEJB_1XM_1 FOREIGN KEY (FK1_FOR_BEJB_1XM_BI_CASCADE) REFERENCES BEJB_1XM_BI_CASCADE (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_CASCADE ADD CONSTRAINT FK2_FOR_BEJB_1XM_1 FOREIGN KEY (FK2_FOR_BEJB_1XM_BI_CASCADE) REFERENCES BEJB_1XM_BI_CASCADE (ID) ; + +ALTER TABLE BEJB_1XM_BI_CASCADE ADD CONSTRAINT FK_FOR_AEJB_1XM_B1 FOREIGN KEY (FK_FOR_AEJB_1XM_BI_CASCADE) REFERENCES AEJB_1XM_BI_CASCADE (ID) ; + +DROP TABLE BEANEJB_1XM_BI_DELETE; +CREATE TABLE BEANEJB_1XM_BI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1XM_BI_DELETE VARCHAR(255) , FK2_FOR_AEJB_1XM_BI_DELETE VARCHAR(255) , FK1_FOR_BEJB_1XM_BI_DELETE VARCHAR(255) , FK2_FOR_BEJB_1XM_BI_DELETE VARCHAR(255) ); + +DROP TABLE BEJB_1XM_BI_DELETE; +CREATE TABLE BEJB_1XM_BI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1XM_BI_DELETE VARCHAR(255) ); + +DROP TABLE AEJB_1XM_BI_DELETE; +CREATE TABLE AEJB_1XM_BI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_1XM_BI_DELETE ADD CONSTRAINT FK1_FOR_AEJB_1XM_2 FOREIGN KEY (FK1_FOR_AEJB_1XM_BI_DELETE) REFERENCES AEJB_1XM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_DELETE ADD CONSTRAINT FK2_FOR_AEJB_1XM_2 FOREIGN KEY (FK2_FOR_AEJB_1XM_BI_DELETE) REFERENCES AEJB_1XM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_DELETE ADD CONSTRAINT FK1_FOR_BEJB_1XM_2 FOREIGN KEY (FK1_FOR_BEJB_1XM_BI_DELETE) REFERENCES BEJB_1XM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_1XM_BI_DELETE ADD CONSTRAINT FK2_FOR_BEJB_1XM_2 FOREIGN KEY (FK2_FOR_BEJB_1XM_BI_DELETE) REFERENCES BEJB_1XM_BI_DELETE (ID) ; + +ALTER TABLE BEJB_1XM_BI_DELETE ADD CONSTRAINT FK_FOR_AEJB_1XM_B2 FOREIGN KEY (FK_FOR_AEJB_1XM_BI_DELETE) REFERENCES AEJB_1XM_BI_DELETE (ID) ; + +DROP TABLE BEANEJB_1XM_UNI_BTOB; +CREATE TABLE BEANEJB_1XM_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_1XM_UNI_BTOB VARCHAR(255) , FK2_FOR_AEJB_1XM_UNI_BTOB VARCHAR(255) , FK1_FOR_BEJB_1XM_UNI_BTOB VARCHAR(255) , FK2_FOR_BEJB_1XM_UNI_BTOB VARCHAR(255), FK3_FOR_BEJB_1XM_UNI_BTOB VARCHAR(255) , FK4_FOR_BEJB_1XM_UNI_BTOB VARCHAR(255) ); + +DROP TABLE BEJB_1XM_UNI_BTOB; +CREATE TABLE BEJB_1XM_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_1XM_UNI_BTOB VARCHAR(255) ); + +DROP TABLE AEJB_1XM_UNI_BTOB; +CREATE TABLE AEJB_1XM_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_1XM_UNI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_1XM_U FOREIGN KEY (FK1_FOR_AEJB_1XM_UNI_BTOB) REFERENCES AEJB_1XM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_UNI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_1XM_U FOREIGN KEY (FK2_FOR_AEJB_1XM_UNI_BTOB) REFERENCES AEJB_1XM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_UNI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_1XM_U FOREIGN KEY (FK1_FOR_BEJB_1XM_UNI_BTOB) REFERENCES BEJB_1XM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_UNI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_1XM_U FOREIGN KEY (FK2_FOR_BEJB_1XM_UNI_BTOB) REFERENCES BEJB_1XM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_UNI_BTOB ADD CONSTRAINT FK3_FOR_BEJB_1XM_U FOREIGN KEY (FK3_FOR_BEJB_1XM_UNI_BTOB) REFERENCES BEJB_1XM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_1XM_UNI_BTOB ADD CONSTRAINT FK4_FOR_BEJB_1XM_U FOREIGN KEY (FK4_FOR_BEJB_1XM_UNI_BTOB) REFERENCES BEJB_1XM_UNI_BTOB (ID) ; + +DROP TABLE BEANEJB_MX1_UNI_BTOB; +CREATE TABLE BEANEJB_MX1_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_MX1_UNI_BTOB VARCHAR(255) , FK2_FOR_AEJB_MX1_UNI_BTOB VARCHAR(255) , FK1_FOR_BEJB_MX1_UNI_BTOB VARCHAR(255) , FK2_FOR_BEJB_MX1_UNI_BTOB VARCHAR(255) , +FK3_FOR_BEJB_MX1_UNI_BTOB VARCHAR(255) , FK4_FOR_BEJB_MX1_UNI_BTOB VARCHAR(255) ); + +DROP TABLE BEJB_MX1_UNI_BTOB; +CREATE TABLE BEJB_MX1_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_MX1_UNI_BTOB VARCHAR(255) ); + +DROP TABLE AEJB_MX1_UNI_BTOB; +CREATE TABLE AEJB_MX1_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_MX1_UNI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_MX1_U FOREIGN KEY (FK1_FOR_AEJB_MX1_UNI_BTOB) REFERENCES AEJB_MX1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_MX1_U FOREIGN KEY (FK2_FOR_AEJB_MX1_UNI_BTOB) REFERENCES AEJB_MX1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_MX1_U FOREIGN KEY (FK1_FOR_BEJB_MX1_UNI_BTOB) REFERENCES BEJB_MX1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_MX1_U FOREIGN KEY (FK2_FOR_BEJB_MX1_UNI_BTOB) REFERENCES BEJB_MX1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_BTOB ADD CONSTRAINT FK3_FOR_BEJB_MX1_U FOREIGN KEY (FK3_FOR_BEJB_MX1_UNI_BTOB) REFERENCES BEJB_MX1_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_BTOB ADD CONSTRAINT FK4_FOR_BEJB_MX1_U FOREIGN KEY (FK4_FOR_BEJB_MX1_UNI_BTOB) REFERENCES BEJB_MX1_UNI_BTOB (ID) ; + +ALTER TABLE BEJB_MX1_UNI_BTOB ADD CONSTRAINT FK_FOR_AEJB_MX1_UN FOREIGN KEY (FK_FOR_AEJB_MX1_UNI_BTOB) REFERENCES AEJB_MX1_UNI_BTOB (ID) ; + +DROP TABLE BEANEJB_MX1_UNI_DELETE; +CREATE TABLE BEANEJB_MX1_UNI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_MX1_UNI_DELETE VARCHAR(255) , FK2_FOR_AEJB_MX1_UNI_DELETE VARCHAR(255) , FK1_FOR_BEJB_MX1_UNI_DELETE VARCHAR(255) , FK2_FOR_BEJB_MX1_UNI_DELETE VARCHAR(255) , FK3_FOR_BEJB_MX1_UNI_DELETE VARCHAR(255) , FK4_FOR_BEJB_MX1_UNI_DELETE VARCHAR(255) ); + +DROP TABLE BEJB_MX1_UNI_DELETE; +CREATE TABLE BEJB_MX1_UNI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK_FOR_AEJB_MX1_UNI_DELETE VARCHAR(255) ); + +DROP TABLE AEJB_MX1_UNI_DELETE; +CREATE TABLE AEJB_MX1_UNI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_MX1_UNI_DELETE ADD CONSTRAINT FK1_FOR_AEJB_MX1_1 FOREIGN KEY (FK1_FOR_AEJB_MX1_UNI_DELETE) REFERENCES AEJB_MX1_UNI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_DELETE ADD CONSTRAINT FK2_FOR_AEJB_MX1_1 FOREIGN KEY (FK2_FOR_AEJB_MX1_UNI_DELETE) REFERENCES AEJB_MX1_UNI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_DELETE ADD CONSTRAINT FK1_FOR_BEJB_MX1_1 FOREIGN KEY (FK1_FOR_BEJB_MX1_UNI_DELETE) REFERENCES BEJB_MX1_UNI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_DELETE ADD CONSTRAINT FK2_FOR_BEJB_MX1_1 FOREIGN KEY (FK2_FOR_BEJB_MX1_UNI_DELETE) REFERENCES BEJB_MX1_UNI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_DELETE ADD CONSTRAINT FK3_FOR_BEJB_MX1_1 FOREIGN KEY (FK3_FOR_BEJB_MX1_UNI_DELETE) REFERENCES BEJB_MX1_UNI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MX1_UNI_DELETE ADD CONSTRAINT FK4_FOR_BEJB_MX1_1 FOREIGN KEY (FK4_FOR_BEJB_MX1_UNI_DELETE) REFERENCES BEJB_MX1_UNI_DELETE (ID) ; + +ALTER TABLE BEJB_MX1_UNI_DELETE ADD CONSTRAINT FK_FOR_AEJB_MX1_U1 FOREIGN KEY (FK_FOR_AEJB_MX1_UNI_DELETE) REFERENCES AEJB_MX1_UNI_DELETE (ID) ; + +DROP TABLE FKEYS_MXM_BI_BTOB; +CREATE TABLE FKEYS_MXM_BI_BTOB ( FK_FOR_AEJB_MXM_BI_BTOB VARCHAR(255) NOT NULL, FK_FOR_BEJB_MXM_BI_BTOB VARCHAR(255) ); + +DROP TABLE BEANEJB_MXM_BI_BTOB; +CREATE TABLE BEANEJB_MXM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_MXM_BI_BTOB VARCHAR(255) , FK2_FOR_AEJB_MXM_BI_BTOB VARCHAR(255) , FK3_FOR_AEJB_MXM_BI_BTOB VARCHAR(255) , FK4_FOR_AEJB_MXM_BI_BTOB VARCHAR(255) , FK1_FOR_BEJB_MXM_BI_BTOB VARCHAR(255) , FK2_FOR_BEJB_MXM_BI_BTOB VARCHAR(255) , FK3_FOR_BEJB_MXM_BI_BTOB VARCHAR(255) , FK4_FOR_BEJB_MXM_BI_BTOB VARCHAR(255) ); + +DROP TABLE AEJB_MXM_BI_BTOB; +CREATE TABLE AEJB_MXM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +DROP TABLE BEJB_MXM_BI_BTOB; +CREATE TABLE BEJB_MXM_BI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_MXM_B FOREIGN KEY (FK1_FOR_AEJB_MXM_BI_BTOB) REFERENCES AEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_MXM_B FOREIGN KEY (FK2_FOR_AEJB_MXM_BI_BTOB) REFERENCES AEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK3_FOR_AEJB_MXM_B FOREIGN KEY (FK3_FOR_AEJB_MXM_BI_BTOB) REFERENCES AEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK4_FOR_AEJB_MXM_B FOREIGN KEY (FK4_FOR_AEJB_MXM_BI_BTOB) REFERENCES AEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_MXM_B FOREIGN KEY (FK1_FOR_BEJB_MXM_BI_BTOB) REFERENCES BEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_MXM_B FOREIGN KEY (FK2_FOR_BEJB_MXM_BI_BTOB) REFERENCES BEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK3_FOR_BEJB_MXM_B FOREIGN KEY (FK3_FOR_BEJB_MXM_BI_BTOB) REFERENCES BEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_BTOB ADD CONSTRAINT FK4_FOR_BEJB_MXM_B FOREIGN KEY (FK4_FOR_BEJB_MXM_BI_BTOB) REFERENCES BEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE FKEYS_MXM_BI_BTOB ADD CONSTRAINT FK_FOR_AEJB_MXM_BI FOREIGN KEY (FK_FOR_AEJB_MXM_BI_BTOB) REFERENCES AEJB_MXM_BI_BTOB (ID) ; + +ALTER TABLE FKEYS_MXM_BI_BTOB ADD CONSTRAINT FK_FOR_BEJB_MXM_BI FOREIGN KEY (FK_FOR_BEJB_MXM_BI_BTOB) REFERENCES BEJB_MXM_BI_BTOB (ID) ; + +DROP TABLE BEANEJB_MXM_BI_DELETE; +CREATE TABLE BEANEJB_MXM_BI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_MXM_BI_DELETE VARCHAR(255) , FK2_FOR_AEJB_MXM_BI_DELETE VARCHAR(255) , FK3_FOR_AEJB_MXM_BI_DELETE VARCHAR(255) , FK4_FOR_AEJB_MXM_BI_DELETE VARCHAR(255) , FK1_FOR_BEJB_MXM_BI_DELETE VARCHAR(255) , FK2_FOR_BEJB_MXM_BI_DELETE VARCHAR(255) , FK3_FOR_BEJB_MXM_BI_DELETE VARCHAR(255) , FK4_FOR_BEJB_MXM_BI_DELETE VARCHAR(255) ); + +DROP TABLE FKEYS_MXM_BI_DELETE; +CREATE TABLE FKEYS_MXM_BI_DELETE ( FK_FOR_AEJB_MXM_BI_DELETE VARCHAR(255) NOT NULL, FK_FOR_BEJB_MXM_BI_DELETE VARCHAR(255) ); + +DROP TABLE AEJB_MXM_BI_DELETE; +CREATE TABLE AEJB_MXM_BI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +DROP TABLE BEJB_MXM_BI_DELETE; +CREATE TABLE BEJB_MXM_BI_DELETE ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK1_FOR_AEJB_MXM_1 FOREIGN KEY (FK1_FOR_AEJB_MXM_BI_DELETE) REFERENCES AEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK2_FOR_AEJB_MXM_1 FOREIGN KEY (FK2_FOR_AEJB_MXM_BI_DELETE) REFERENCES AEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK3_FOR_AEJB_MXM_1 FOREIGN KEY (FK3_FOR_AEJB_MXM_BI_DELETE) REFERENCES AEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK4_FOR_AEJB_MXM_1 FOREIGN KEY (FK4_FOR_AEJB_MXM_BI_DELETE) REFERENCES AEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK1_FOR_BEJB_MXM_1 FOREIGN KEY (FK1_FOR_BEJB_MXM_BI_DELETE) REFERENCES BEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK2_FOR_BEJB_MXM_1 FOREIGN KEY (FK2_FOR_BEJB_MXM_BI_DELETE) REFERENCES BEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK3_FOR_BEJB_MXM_1 FOREIGN KEY (FK3_FOR_BEJB_MXM_BI_DELETE) REFERENCES BEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE BEANEJB_MXM_BI_DELETE ADD CONSTRAINT FK4_FOR_BEJB_MXM_1 FOREIGN KEY (FK4_FOR_BEJB_MXM_BI_DELETE) REFERENCES BEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE FKEYS_MXM_BI_DELETE ADD CONSTRAINT FK_FOR_AEJB_MXM_B1 FOREIGN KEY (FK_FOR_AEJB_MXM_BI_DELETE) REFERENCES AEJB_MXM_BI_DELETE (ID) ; + +ALTER TABLE FKEYS_MXM_BI_DELETE ADD CONSTRAINT FK_FOR_BEJB_MXM_B1 FOREIGN KEY (FK_FOR_BEJB_MXM_BI_DELETE) REFERENCES BEJB_MXM_BI_DELETE (ID) ; + +DROP TABLE FKEYS_MXM_UNI_BTOB; +CREATE TABLE FKEYS_MXM_UNI_BTOB ( FK_FOR_AEJB_MXM_UNI_BTOB VARCHAR(255) NOT NULL, FK_FOR_BEJB_MXM_UNI_BTOB VARCHAR(255) ); + +DROP TABLE BEANEJB_MXM_UNI_BTOB; +CREATE TABLE BEANEJB_MXM_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL, FK1_FOR_AEJB_MXM_UNI_BTOB VARCHAR(255) , FK2_FOR_AEJB_MXM_UNI_BTOB VARCHAR(255) , FK3_FOR_AEJB_MXM_UNI_BTOB VARCHAR(255) , FK4_FOR_AEJB_MXM_UNI_BTOB VARCHAR(255) , FK1_FOR_BEJB_MXM_UNI_BTOB VARCHAR(255) , FK2_FOR_BEJB_MXM_UNI_BTOB VARCHAR(255) , FK3_FOR_BEJB_MXM_UNI_BTOB VARCHAR(255) , FK4_FOR_BEJB_MXM_UNI_BTOB VARCHAR(255) ); + +DROP TABLE AEJB_MXM_UNI_BTOB; +CREATE TABLE AEJB_MXM_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL); + +DROP TABLE BEJB_MXM_UNI_BTOB; +CREATE TABLE BEJB_MXM_UNI_BTOB ( ID VARCHAR(255) PRIMARY KEY NOT NULL, NAME VARCHAR(255) , VALUE DECIMAL(18,0) NOT NULL ); + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK1_FOR_AEJB_MXM_U FOREIGN KEY (FK1_FOR_AEJB_MXM_UNI_BTOB) REFERENCES AEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK2_FOR_AEJB_MXM_U FOREIGN KEY (FK2_FOR_AEJB_MXM_UNI_BTOB) REFERENCES AEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK3_FOR_AEJB_MXM_U FOREIGN KEY (FK3_FOR_AEJB_MXM_UNI_BTOB) REFERENCES AEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK4_FOR_AEJB_MXM_U FOREIGN KEY (FK4_FOR_AEJB_MXM_UNI_BTOB) REFERENCES AEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK1_FOR_BEJB_MXM_U FOREIGN KEY (FK1_FOR_BEJB_MXM_UNI_BTOB) REFERENCES BEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK2_FOR_BEJB_MXM_U FOREIGN KEY (FK2_FOR_BEJB_MXM_UNI_BTOB) REFERENCES BEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK3_FOR_BEJB_MXM_U FOREIGN KEY (FK3_FOR_BEJB_MXM_UNI_BTOB) REFERENCES BEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE BEANEJB_MXM_UNI_BTOB ADD CONSTRAINT FK4_FOR_BEJB_MXM_U FOREIGN KEY (FK4_FOR_BEJB_MXM_UNI_BTOB) REFERENCES BEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE FKEYS_MXM_UNI_BTOB ADD CONSTRAINT FK_FOR_AEJB_MXM_UN FOREIGN KEY (FK_FOR_AEJB_MXM_UNI_BTOB) REFERENCES AEJB_MXM_UNI_BTOB (ID) ; + +ALTER TABLE FKEYS_MXM_UNI_BTOB ADD CONSTRAINT FK_FOR_BEJB_MXM_UN FOREIGN KEY (FK_FOR_BEJB_MXM_UNI_BTOB) REFERENCES BEJB_MXM_UNI_BTOB (ID) ; + +DROP TABLE PKEY; +CREATE TABLE PKEY ( PMIDINTEGER INT NOT NULL, PMIDSTRING VARCHAR(25) NOT NULL, PMIDFLOAT REAL NOT NULL, BRANDNAME VARCHAR(25) , PRICE REAL , CONSTRAINT PK_PKEY PRIMARY KEY (PMIDINTEGER, PMIDSTRING, PMIDFLOAT)); + +DROP TABLE DATATYPES; +CREATE TABLE DATATYPES ( ID INT NOT NULL, BOOLEANDATA SMALLINT, CHARDATA CHAR, SHORTDATA SMALLINT, INTDATA INT, INTDATA2 INT, LONGDATA BIGINT, DBLDATA DOUBLE, FLOATDATA FLOAT, ENUMODATA INT, ENUMSDATA VARCHAR(25), BYTEDATA SMALLINT, TRANS SMALLINT , BYTEARRAYDATA BLOB(6M), CHARARRAYDATA VARCHAR(448), CONSTRAINT PK_DATATYPES PRIMARY KEY (ID)); + +DROP TABLE DATATYPES2; +CREATE TABLE DATATYPES2 ( DATATYPES2_ID DATE NOT NULL, DATEDATA DATE, TIMEDATA TIME, TSDATA TIMESTAMP, CONSTRAINT PK_DATATYPES2 PRIMARY KEY (DATATYPES2_ID)); + +DROP TABLE DATATYPES3; +CREATE TABLE DATATYPES3 ( ID DECIMAL(18,0) NOT NULL, THEVALUE DECIMAL(18,0), CONSTRAINT PK_DATATYPES3 PRIMARY KEY (ID)); + +DROP TABLE PURCHASE_ORDER; +CREATE TABLE PURCHASE_ORDER (ID INT NOT NULL, TOTAL INT, DESCRIPTION VARCHAR(50), CONSTRAINT PK_PURCHASE_ORDER PRIMARY KEY (ID)); + +DROP TABLE GENERATOR_TABLE; +CREATE TABLE GENERATOR_TABLE (PK_COL VARCHAR(10), VAL_COL INT, CONSTRAINT GENERATOR_TABLE_PK PRIMARY KEY (PK_COL) ); +INSERT into GENERATOR_TABLE(PK_COL, VAL_COL) values ('DT_ID', 1) ; +INSERT into GENERATOR_TABLE(PK_COL, VAL_COL) values ('DT1_ID', 1) ; +INSERT into GENERATOR_TABLE(PK_COL, VAL_COL) values ('DT2_ID', 100) ; +INSERT into GENERATOR_TABLE(PK_COL, VAL_COL) values ('DT3_ID', 1000) ; + +DROP TABLE SEQUENCE; +CREATE TABLE SEQUENCE (SEQ_NAME VARCHAR(10), SEQ_COUNT INT, CONSTRAINT SEQUENCE_PK PRIMARY KEY (SEQ_NAME) ); +INSERT into SEQUENCE(SEQ_NAME, SEQ_COUNT) values ('SEQ_GEN', 0) ; + +DROP TABLE ORDER1; +CREATE TABLE ORDER1 (ID INT PRIMARY KEY NOT NULL, TOTALPRICE DOUBLE , FK1_FOR_ITEM INT); + +DROP TABLE ORDER2; +CREATE TABLE ORDER2 (ID INT PRIMARY KEY NOT NULL, TOTALPRICE DOUBLE , FK2_FOR_ITEM INT); + +DROP TABLE ORDER3; +CREATE TABLE ORDER3 (ID INT PRIMARY KEY NOT NULL, TOTALPRICE DOUBLE , FK3_FOR_ITEM INT); + + +DROP TABLE ITEM ; +CREATE TABLE ITEM (ID INT PRIMARY KEY, ITEMNAME VARCHAR(255)) ; + +ALTER TABLE ORDER1 add constraint FK1_FOR_ITEM Foreign Key (FK1_FOR_ITEM) references ITEM(ID) ; +ALTER TABLE ORDER2 add constraint FK2_FOR_ITEM Foreign Key (FK2_FOR_ITEM) references ITEM(ID) ; +ALTER TABLE ORDER3 add constraint FK3_FOR_ITEM Foreign Key (FK3_FOR_ITEM) references ITEM(ID) ; + +DROP TABLE MEMBER ; +CREATE TABLE MEMBER (MEMBER_ID INT NOT NULL, MEMBER_NAME VARCHAR(255), DUES SMALLINT, VERSION INT, DONATION DECIMAL(18,0), CONSTRAINT PK_MEMBER PRIMARY KEY (MEMBER_ID)) ; + +DROP TABLE ACCOUNT ; +CREATE TABLE ACCOUNT (ID INT NOT NULL, BALANCE DOUBLE, DEPOSIT DOUBLE, WITHDRAW DOUBLE, CONSTRAINT PK_ACCOUNT PRIMARY KEY (ID)) ; + +DROP TABLE SEMESTER ; +CREATE TABLE SEMESTER (ID INTEGER NOT NULL, PRIMARY KEY (ID)) ; + +DROP TABLE STUDENT_COURSE ; +CREATE TABLE STUDENT_COURSE (Student_ID INTEGER NOT NULL, courses_ID INTEGER NOT NULL, PRIMARY KEY (Student_ID, courses_ID)) ; + +DROP TABLE STUDENT ; +CREATE TABLE STUDENT (ID INTEGER NOT NULL, STUDENTNAME VARCHAR(255), PRIMARY KEY (ID)) ; + +DROP TABLE COURSE ; +CREATE TABLE COURSE (ID INTEGER NOT NULL, COURSENAME VARCHAR(255), PRIMARY KEY (ID)) ; + +DROP TABLE ENROLLMENTS ; +CREATE TABLE ENROLLMENTS (STUDENT INTEGER NOT NULL, ENROLLMENT_KEY INTEGER NOT NULL, SEMESTER INTEGER NOT NULL, PRIMARY KEY (STUDENT, ENROLLMENT_KEY, SEMESTER)); + +DROP TABLE COURSE_STUDENT ; +CREATE TABLE COURSE_STUDENT (COURSE_ID INTEGER NOT NULL, STUDENT_ID INTEGER NOT NULL, STUDENTS_ORDER INTEGER, PRIMARY KEY (COURSE_ID , STUDENT_ID)); + +ALTER TABLE STUDENT_COURSE ADD CONSTRAINT STDNTCOURSEStdntID FOREIGN KEY (Student_ID) REFERENCES STUDENT (ID) ; +ALTER TABLE STUDENT_COURSE ADD CONSTRAINT STDNTCOURSEcrsesID FOREIGN KEY (courses_ID) REFERENCES COURSE (ID) ; +ALTER TABLE ENROLLMENTS ADD CONSTRAINT ENROLLMENTSSTUDENT FOREIGN KEY (STUDENT) REFERENCES STUDENT (ID) ; +ALTER TABLE ENROLLMENTS ADD CONSTRAINT NROLLMENTSSEMESTER FOREIGN KEY (SEMESTER) REFERENCES SEMESTER (ID) ; +ALTER TABLE COURSE_STUDENT ADD CONSTRAINT CRSESTUDENTCurseID FOREIGN KEY (COURSE_ID) REFERENCES COURSE (ID) ; +ALTER TABLE COURSE_STUDENT ADD CONSTRAINT CRSSTUDENTstdntsID FOREIGN KEY (STUDENT_ID) REFERENCES STUDENT (ID) ; + +DROP TABLE NOENTITYLISTENER_TABLE; +CREATE TABLE NOENTITYLISTENER_TABLE(ID BIGINT PRIMARY KEY NOT NULL); + +DROP TABLE COURSE_2; +CREATE TABLE COURSE_2(ID BIGINT NOT NULL,NAME VARCHAR(255)); + +DROP TABLE STUDENT_2; +CREATE TABLE STUDENT_2(ID BIGINT NOT NULL,NAME VARCHAR(255)); + +DROP TABLE STUDENT_2_COURSE_2; +CREATE TABLE STUDENT_2_COURSE_2(COURSES_ID BIGINT,STUDENTS_ID BIGINT); + +DROP TABLE NAMEONLYINXML; +CREATE TABLE NAMEONLYINXML(ID BIGINT); + +DROP TABLE NAMEONLYINANNOTATION; +CREATE TABLE NAMEONLYINANNOTATION(ID BIGINT); + +DROP TABLE NAMEOVERRIDE; +CREATE TABLE NAMEOVERRIDE (ID BIGINT); + +DROP TABLE NOENTITYANNOTATION; +CREATE TABLE NOENTITYANNOTATION(ID BIGINT); + +DROP TABLE BOOKSTORE; +CREATE TABLE BOOKSTORE(ID BIGINT NOT NULL,NAME VARCHAR(255),LOCATION VARCHAR(255)); + +DROP TABLE COMPLAINT; +CREATE TABLE COMPLAINT(ID BIGINT NOT NULL, COMPLAINTNUMBER INT, NAME VARCHAR(255), ADDRESS VARCHAR(255)); + +DROP TABLE MOVIETICKET; +CREATE TABLE MOVIETICKET(ID BIGINT NOT NULL, FILMNAME VARCHAR(255), FILMCODE VARCHAR(255)); + +DROP TABLE BOOK; +CREATE TABLE BOOK(ID BIGINT NOT NULL, NAME VARCHAR(255), STATEOFUSA VARCHAR(255)); + +DROP TABLE LAWBOOK; +CREATE TABLE LAWBOOK(ID BIGINT NOT NULL, BOOK_NAME VARCHAR(255), CATEGORY VARCHAR(255),PUBLISHER VARCHAR(255),COST INT); + +DROP TABLE EMPLOYEE_2; +CREATE TABLE EMPLOYEE_2(ID BIGINT NOT NULL, CODE VARCHAR(255), DEPARTMENT_ID BIGINT); + +DROP TABLE DEPARTMENT_2; +CREATE TABLE DEPARTMENT_2(ID BIGINT NOT NULL,NAME VARCHAR(255)); + +DROP TABLE THEATRELOCATION; +CREATE TABLE THEATRELOCATION(ID BIGINT NOT NULL, CODE VARCHAR(255)); + +DROP TABLE THEATRECOMPANY; +CREATE TABLE THEATRECOMPANY(ID BIGINT NOT NULL,NAME VARCHAR(255)); + +DROP TABLE THEATRELOCATION_THEATRECOMPANY; +CREATE TABLE THEATRELOCATION_THEATRECOMPANY(COMPANIES_ID BIGINT, LOCATIONS_ID BIGINT); + +DROP TABLE STORE; +CREATE TABLE STORE(ID BIGINT NOT NULL, NAME VARCHAR(255)); + +DROP TABLE CUSTOMERS; +CREATE TABLE CUSTOMERS(ID BIGINT NOT NULL, CUSTNAME VARCHAR(255), STORE_ID BIGINT); + +DROP TABLE CONSUMER; +CREATE TABLE CONSUMER(ID BIGINT NOT NULL); + +DROP TABLE RETAILORDER; +CREATE TABLE RETAILORDER(ID BIGINT NOT NULL, COST DOUBLE); + +DROP TABLE RETAILORDER_CONSUMER; +CREATE TABLE RETAILORDER_CONSUMER(CONSUMERS_ID BIGINT NOT NULL,ORDERS_ID BIGINT NOT NULL); + +DROP TABLE THEATRELOCATION1; +CREATE TABLE THEATRELOCATION1(ID BIGINT NOT NULL, CODE VARCHAR(255),TCOMP_ID BIGINT); + +DROP TABLE THEATRECOMPANY1; +CREATE TABLE THEATRECOMPANY1(ID BIGINT NOT NULL,NAME VARCHAR(255)); + +DROP TABLE CUBICLE; +CREATE TABLE CUBICLE(ID BIGINT NOT NULL , LOCATION VARCHAR(255), PRIMARY KEY(ID,LOCATION)); + +DROP TABLE HARDWARE; +CREATE TABLE HARDWARE(ID BIGINT NOT NULL, CODE VARCHAR(255),CUBE_ID BIGINT NOT NULL, CUBE_LOCATION VARCHAR(255)); + +DROP TABLE CUSTOMER1; +CREATE TABLE CUSTOMER1(ID BIGINT NOT NULL, NAME VARCHAR(255), CONSTRAINT PK_CUSTOMER1 PRIMARY KEY (ID)); + +DROP TABLE RETAILORDER1; +CREATE TABLE RETAILORDER1(ID BIGINT NOT NULL, COST DOUBLE); + +DROP TABLE CUST_ORDER; +CREATE TABLE CUST_ORDER(CUSTID BIGINT NOT NULL,ORDERID BIGINT NOT NULL); + + +DROP TABLE RETAILORDER2; +CREATE TABLE RETAILORDER2(ID BIGINT NOT NULL, COST DOUBLE, FK_FOR_CUSTOMER1 BIGINT ); + +ALTER TABLE RETAILORDER2 ADD CONSTRAINT FK_FOR_CUST FOREIGN KEY(FK_FOR_CUSTOMER1) REFERENCES CUSTOMER1(ID); + +ALTER TABLE UNI1X1PERSON DROP CONSTRAINT N1X1PRSNPRJCTPRJID; +DROP TABLE UNI1X1PROJECT; +DROP TABLE UNI1X1PERSON; + + +CREATE TABLE UNI1X1PROJECT (PROJID BIGINT NOT NULL, BUDGET FLOAT, NAME VARCHAR(255), PRIMARY KEY (PROJID)); +CREATE TABLE UNI1X1PERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), PROJECT_PROJID BIGINT, PRIMARY KEY (ID)); +ALTER TABLE UNI1X1PERSON ADD CONSTRAINT N1X1PRSNPRJCTPRJID FOREIGN KEY (PROJECT_PROJID) REFERENCES UNI1X1PROJECT (PROJID); + + +ALTER TABLE UNI1XMPERSON_UNI1XMPROJECT DROP CONSTRAINT N1XMPRSNNn1XMPrsnD; +ALTER TABLE UNI1XMPERSON_UNI1XMPROJECT DROP CONSTRAINT N1XMPRSNN1XprjctsD; +DROP TABLE UNI1XMPERSON_UNI1XMPROJECT; +DROP TABLE UNI1XMPROJECT; +DROP TABLE UNI1XMPERSON; + +CREATE TABLE UNI1XMPERSON_UNI1XMPROJECT (Uni1XMPerson_ID BIGINT NOT NULL, projects_ID BIGINT NOT NULL, PRIMARY KEY (Uni1XMPerson_ID, projects_ID)); +CREATE TABLE UNI1XMPROJECT (ID BIGINT NOT NULL, NAME VARCHAR(255), BUDGET FLOAT, PRIMARY KEY (ID)); +CREATE TABLE UNI1XMPERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); +ALTER TABLE UNI1XMPERSON_UNI1XMPROJECT ADD CONSTRAINT N1XMPRSNNn1XMPrsnD FOREIGN KEY (Uni1XMPerson_ID) REFERENCES UNI1XMPERSON (ID); +ALTER TABLE UNI1XMPERSON_UNI1XMPROJECT ADD CONSTRAINT N1XMPRSNN1XprjctsD FOREIGN KEY (projects_ID) REFERENCES UNI1XMPROJECT (ID); + + +ALTER TABLE UNIMX1PERSON DROP CONSTRAINT NMX1PRSNNMX1PRJCTD; +DROP TABLE UNIMX1PROJECT; +DROP TABLE UNIMX1PERSON; + +CREATE TABLE UNIMX1PROJECT (ID BIGINT NOT NULL, NAME VARCHAR(255), BUDGET FLOAT, PRIMARY KEY (ID)); +CREATE TABLE UNIMX1PERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), UNIMX1PROJECT_ID BIGINT, PRIMARY KEY (ID)); +ALTER TABLE UNIMX1PERSON ADD CONSTRAINT NMX1PRSNNMX1PRJCTD FOREIGN KEY (UNIMX1PROJECT_ID) REFERENCES UNIMX1PROJECT (ID); + + +ALTER TABLE UNIMXMPERSON_UNIMXMPROJECT DROP CONSTRAINT NMXMPRSNNnMXMPrsnD; +ALTER TABLE UNIMXMPERSON_UNIMXMPROJECT DROP CONSTRAINT NMXMPRSNnMXMPrjctD; +DROP TABLE UNIMXMPERSON; +DROP TABLE UNIMXMPROJECT; +DROP TABLE UNIMXMPERSON_UNIMXMPROJECT; + +CREATE TABLE UNIMXMPERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); +CREATE TABLE UNIMXMPROJECT (ID BIGINT NOT NULL, NAME VARCHAR(255), BUDGET FLOAT, PRIMARY KEY (ID)); +CREATE TABLE UNIMXMPERSON_UNIMXMPROJECT (UniMXMPerson_ID BIGINT NOT NULL, UniMXMProject_ID BIGINT NOT NULL, PRIMARY KEY (UniMXMPerson_ID, UniMXMProject_ID)); +ALTER TABLE UNIMXMPERSON_UNIMXMPROJECT ADD CONSTRAINT NMXMPRSNNnMXMPrsnD FOREIGN KEY (UniMXMPerson_ID) REFERENCES UNIMXMPERSON (ID); +ALTER TABLE UNIMXMPERSON_UNIMXMPROJECT ADD CONSTRAINT NMXMPRSNnMXMPrjctD FOREIGN KEY (UniMXMProject_ID) REFERENCES UNIMXMPROJECT (ID); + + +ALTER TABLE BIDIR1X1PERSON DROP CONSTRAINT BDR1X1PRSPRJCTPRJD; +DROP TABLE BIDIR1X1PERSON; +DROP TABLE BIDIR1X1PROJECT; + +CREATE TABLE BIDIR1X1PERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), PROJECT_PROJID BIGINT, PRIMARY KEY (ID)); +CREATE TABLE BIDIR1X1PROJECT (PROJID BIGINT NOT NULL, BUDGET FLOAT, NAME VARCHAR(255), PRIMARY KEY (PROJID)); +ALTER TABLE BIDIR1X1PERSON ADD CONSTRAINT BDR1X1PRSPRJCTPRJD FOREIGN KEY (PROJECT_PROJID) REFERENCES BIDIR1X1PROJECT (PROJID); + + +ALTER TABLE BIDIR1XMPROJECT DROP CONSTRAINT BDR1XMPBDR1XMPRSND; +DROP TABLE BIDIR1XMPERSON; +DROP TABLE BIDIR1XMPROJECT; + +CREATE TABLE BIDIR1XMPERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); +CREATE TABLE BIDIR1XMPROJECT (ID BIGINT NOT NULL, NAME VARCHAR(255), BUDGET FLOAT, BIDIR1XMPERSON_ID BIGINT, PRIMARY KEY (ID)); +ALTER TABLE BIDIR1XMPROJECT ADD CONSTRAINT BDR1XMPBDR1XMPRSND FOREIGN KEY (BIDIR1XMPERSON_ID) REFERENCES BIDIR1XMPERSON (ID); + + +ALTER TABLE BIDIRMX1PERSON DROP CONSTRAINT BDRMX1PRNMX1PRJCTD; +DROP TABLE BIDIRMX1PROJECT; +DROP TABLE BIDIRMX1PERSON; + +CREATE TABLE BIDIRMX1PROJECT (ID BIGINT NOT NULL, NAME VARCHAR(255), BUDGET FLOAT, PRIMARY KEY (ID)); +CREATE TABLE BIDIRMX1PERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), UNIMX1PROJECT_ID BIGINT, PRIMARY KEY (ID)); +ALTER TABLE BIDIRMX1PERSON ADD CONSTRAINT BDRMX1PRNMX1PRJCTD FOREIGN KEY (UNIMX1PROJECT_ID) REFERENCES BIDIRMX1PROJECT (ID); + + +ALTER TABLE BIDIRMXMPERSON_BIDIRMXMPROJECT DROP CONSTRAINT BDRMXMPBDRMXMPrsnD; +ALTER TABLE BIDIRMXMPERSON_BIDIRMXMPROJECT DROP CONSTRAINT BDRMXMBDRMXMPrjctD; +DROP TABLE BIDIRMXMPERSON_BIDIRMXMPROJECT; +DROP TABLE BIDIRMXMPERSON; +DROP TABLE BIDIRMXMPROJECT; + +CREATE TABLE BIDIRMXMPERSON_BIDIRMXMPROJECT (BIDIRMXMPerson_ID BIGINT NOT NULL, BIDIRMXMProject_ID BIGINT NOT NULL, PRIMARY KEY (BIDIRMXMPerson_ID, BIDIRMXMProject_ID)); +CREATE TABLE BIDIRMXMPERSON (ID BIGINT NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); +CREATE TABLE BIDIRMXMPROJECT (ID BIGINT NOT NULL, NAME VARCHAR(255), BUDGET FLOAT, PRIMARY KEY (ID)); +ALTER TABLE BIDIRMXMPERSON_BIDIRMXMPROJECT ADD CONSTRAINT BDRMXMPBDRMXMPrsnD FOREIGN KEY (BIDIRMXMPerson_ID) REFERENCES BIDIRMXMPERSON (ID); +ALTER TABLE BIDIRMXMPERSON_BIDIRMXMPROJECT ADD CONSTRAINT BDRMXMBDRMXMPrjctD FOREIGN KEY (BIDIRMXMProject_ID) REFERENCES BIDIRMXMPROJECT (ID); + + +ALTER TABLE DID1DEPENDENT DROP CONSTRAINT DID1DEPENDENTEMPID; +DROP TABLE DID1DEPENDENT; +DROP TABLE DID1EMPLOYEE; + +CREATE TABLE DID1DEPENDENT (NAME VARCHAR(255) NOT NULL, EMP_ID BIGINT NOT NULL, PRIMARY KEY (NAME, EMP_ID)); +CREATE TABLE DID1EMPLOYEE (ID BIGINT NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); +ALTER TABLE DID1DEPENDENT ADD CONSTRAINT DID1DEPENDENTEMPID FOREIGN KEY (EMP_ID) REFERENCES DID1EMPLOYEE (ID); + + +ALTER TABLE DID1BDEPENDENT DROP CONSTRAINT DID1BDEPENDENTMPID; +DROP TABLE DID1BDEPENDENT; +DROP TABLE DID1BEMPLOYEE; + +CREATE TABLE DID1BDEPENDENT (NAME VARCHAR(255) NOT NULL, EMP_ID BIGINT, PRIMARY KEY (NAME, EMP_ID)); +CREATE TABLE DID1BEMPLOYEE (ID BIGINT NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); +ALTER TABLE DID1BDEPENDENT ADD CONSTRAINT DID1BDEPENDENTMPID FOREIGN KEY (EMP_ID) REFERENCES DID1BEMPLOYEE (ID); + + +ALTER TABLE DID2DEPENDENT DROP CONSTRAINT DD2DPENDENTFRSTNME; +DROP TABLE DID2EMPLOYEE; +DROP TABLE DID2DEPENDENT; + +CREATE TABLE DID2EMPLOYEE (FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, EMPNO INTEGER, PRIMARY KEY (FIRSTNAME, LASTNAME)); +CREATE TABLE DID2DEPENDENT (NAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (NAME, FIRSTNAME, LASTNAME)); +ALTER TABLE DID2DEPENDENT ADD CONSTRAINT DD2DPENDENTFRSTNME FOREIGN KEY (FIRSTNAME, LASTNAME) REFERENCES DID2EMPLOYEE (FIRSTNAME, LASTNAME); + + +ALTER TABLE DID2BDEPENDENT DROP CONSTRAINT DD2BDPENDENTLSTNME; +DROP TABLE DID2BEMPLOYEE; +DROP TABLE DID2BDEPENDENT; + +CREATE TABLE DID2BEMPLOYEE (LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, EMPNO INTEGER, PRIMARY KEY (LASTNAME, FIRSTNAME)); +CREATE TABLE DID2BDEPENDENT (NAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (NAME, LASTNAME, FIRSTNAME)); +ALTER TABLE DID2BDEPENDENT ADD CONSTRAINT DD2BDPENDENTLSTNME FOREIGN KEY (LASTNAME, FIRSTNAME) REFERENCES DID2BEMPLOYEE (LASTNAME, FIRSTNAME); + + +ALTER TABLE DID3DEPENDENT DROP CONSTRAINT DD3DPENDENTFRSTNME; +DROP TABLE DID3EMPLOYEE; +DROP TABLE DID3DEPENDENT; + +CREATE TABLE DID3EMPLOYEE (FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (FIRSTNAME, LASTNAME)); +CREATE TABLE DID3DEPENDENT (NAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (NAME, FIRSTNAME, LASTNAME)); +ALTER TABLE DID3DEPENDENT ADD CONSTRAINT DD3DPENDENTFRSTNME FOREIGN KEY (FIRSTNAME, LASTNAME) REFERENCES DID3EMPLOYEE (FIRSTNAME, LASTNAME); + + +ALTER TABLE DID3BDEPENDENT DROP CONSTRAINT DD3BDPENDENTLSTNME; +DROP TABLE DID3BEMPLOYEE; +DROP TABLE DID3BDEPENDENT; + +CREATE TABLE DID3BEMPLOYEE (LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (LASTNAME, FIRSTNAME)); +CREATE TABLE DID3BDEPENDENT (NAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (NAME, LASTNAME, FIRSTNAME)); +ALTER TABLE DID3BDEPENDENT ADD CONSTRAINT DD3BDPENDENTLSTNME FOREIGN KEY (LASTNAME, FIRSTNAME) REFERENCES DID3BEMPLOYEE (LASTNAME, FIRSTNAME); + + +ALTER TABLE DID4MEDICALHISTORY DROP CONSTRAINT DD4MDCLHSTRPTNTSSN; +DROP TABLE DID4MEDICALHISTORY; +DROP TABLE DID4PERSON; + +CREATE TABLE DID4MEDICALHISTORY (DOCTORNAME VARCHAR(255), PATIENT_SSN VARCHAR(255) NOT NULL, PRIMARY KEY (PATIENT_SSN)); +CREATE TABLE DID4PERSON (SSN VARCHAR(255) NOT NULL, NAME VARCHAR(255), PRIMARY KEY (SSN)); +ALTER TABLE DID4MEDICALHISTORY ADD CONSTRAINT DD4MDCLHSTRPTNTSSN FOREIGN KEY (PATIENT_SSN) REFERENCES DID4PERSON (SSN); + + +ALTER TABLE DID4BMEDICALHISTORY DROP CONSTRAINT DD4BMDCLHSTPTNTSSN; +DROP TABLE DID4BMEDICALHISTORY; +DROP TABLE DID4BPERSON; + +CREATE TABLE DID4BMEDICALHISTORY (ID VARCHAR(255) NOT NULL, DOCTORNAME VARCHAR(255), PRIMARY KEY (ID)); +CREATE TABLE DID4BPERSON (SSN VARCHAR(255) NOT NULL, NAME VARCHAR(255), PRIMARY KEY (SSN)); +ALTER TABLE DID4BMEDICALHISTORY ADD CONSTRAINT DD4BMDCLHSTPTNTSSN FOREIGN KEY (ID) REFERENCES DID4BPERSON (SSN); + + +ALTER TABLE DID5MEDICALHISTORY DROP CONSTRAINT DD5MDCLHSTRYFRSTNM; +DROP TABLE DID5PERSON; +DROP TABLE DID5MEDICALHISTORY; + +CREATE TABLE DID5PERSON (FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, SSN VARCHAR(255), PRIMARY KEY (FIRSTNAME, LASTNAME)); +CREATE TABLE DID5MEDICALHISTORY (DOCTORNAME VARCHAR(255), FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (FIRSTNAME, LASTNAME)); +ALTER TABLE DID5MEDICALHISTORY ADD CONSTRAINT DD5MDCLHSTRYFRSTNM FOREIGN KEY (FIRSTNAME, LASTNAME) REFERENCES DID5PERSON (FIRSTNAME, LASTNAME); + + +ALTER TABLE DID5BMEDICALHISTORY DROP CONSTRAINT DD5BMDCLHSTRYLSTNM; +DROP TABLE DID5BMEDICALHISTORY; +DROP TABLE DID5BPERSON; + +CREATE TABLE DID5BMEDICALHISTORY (DOCTORNAME VARCHAR(255), LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (LASTNAME, FIRSTNAME)); +CREATE TABLE DID5BPERSON (LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, SSN VARCHAR(255), PRIMARY KEY (LASTNAME, FIRSTNAME)); +ALTER TABLE DID5BMEDICALHISTORY ADD CONSTRAINT DD5BMDCLHSTRYLSTNM FOREIGN KEY (LASTNAME, FIRSTNAME) REFERENCES DID5BPERSON (LASTNAME, FIRSTNAME); + + +ALTER TABLE DID6MEDICALHISTORY DROP CONSTRAINT DD6MDCLHSTRYFRSTNM; +DROP TABLE DID6MEDICALHISTORY; +DROP TABLE DID6PERSON; + +CREATE TABLE DID6MEDICALHISTORY (DOCTORNAME VARCHAR(255), FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (FIRSTNAME, LASTNAME)); +CREATE TABLE DID6PERSON (SSN VARCHAR(255), FIRSTNAME VARCHAR(255) NOT NULL, LASTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (FIRSTNAME, LASTNAME)); +ALTER TABLE DID6MEDICALHISTORY ADD CONSTRAINT DD6MDCLHSTRYFRSTNM FOREIGN KEY (FIRSTNAME, LASTNAME) REFERENCES DID6PERSON (FIRSTNAME, LASTNAME); + +ALTER TABLE DID6BMEDICALHISTORY DROP CONSTRAINT DD6BMDCLHSTRYLSTNM; +DROP TABLE DID6BPERSON; +DROP TABLE DID6BMEDICALHISTORY; + +CREATE TABLE DID6BPERSON (SSN VARCHAR(255), LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (LASTNAME, FIRSTNAME)); +CREATE TABLE DID6BMEDICALHISTORY (DOCTORNAME VARCHAR(255), LASTNAME VARCHAR(255) NOT NULL, FIRSTNAME VARCHAR(255) NOT NULL, PRIMARY KEY (LASTNAME, FIRSTNAME)); +ALTER TABLE DID6BMEDICALHISTORY ADD CONSTRAINT DD6BMDCLHSTRYLSTNM FOREIGN KEY (LASTNAME, FIRSTNAME) REFERENCES DID6BPERSON (LASTNAME, FIRSTNAME); + + +DROP TABLE EMP_MAPKEYCOL; +CREATE TABLE EMP_MAPKEYCOL(ID INT NOT NULL, FIRSTNAME VARCHAR(255) , LASTNAME VARCHAR(255), HIREDATE DATE, SALARY REAL NOT NULL, STATUS VARCHAR(255), FK_MGR INT, FK_DEPT INT, FK_DEPT3 INT, FK_DEPT4 INT, FK_PROJECT INT , FK_INS INT, OFFICE_ID VARCHAR(255), LASTNAMEEMPLOYEES_KEY VARCHAR(255), CONSTRAINT PK_EMP PRIMARY KEY (ID)) ; +ALTER TABLE EMP_MAPKEYCOL ADD CONSTRAINT FK_DEPT1 FOREIGN KEY (FK_DEPT) REFERENCES DEPARTMENT (ID) ; +ALTER TABLE EMP_MAPKEYCOL ADD CONSTRAINT FK_DEPT3 FOREIGN KEY (FK_DEPT3) REFERENCES DEPARTMENT (ID) ; +ALTER TABLE EMP_MAPKEYCOL ADD CONSTRAINT FK_DEPT4 FOREIGN KEY (FK_DEPT4) REFERENCES DEPARTMENT (ID) ; + +DROP TABLE EMP_MAPKEYCOL2 ; +CREATE TABLE EMP_MAPKEYCOL2(ID INT NOT NULL, LASTNAME VARCHAR(255), THEDATE DATE ,FK_DEPT5 INT, CONSTRAINT PK_EMP2 PRIMARY KEY (ID)) ; +ALTER TABLE EMP_MAPKEYCOL2 ADD CONSTRAINT FK_DEPT5 FOREIGN KEY (FK_DEPT5) REFERENCES DEPARTMENT2 (ID) ; + +ALTER TABLE COLTAB_EMP_EMBEDED_ADDRESS DROP CONSTRAINT FK_EMPEMBADDRID ; +DROP TABLE COLTAB_EMP_EMBEDED_ADDRESS; +DROP TABLE EMPLOYEE_EMBEDED_ADDRESS; +CREATE TABLE EMPLOYEE_EMBEDED_ADDRESS (ID INTEGER NOT NULL, FIRSTNAME VARCHAR(255), LASTNAME VARCHAR(255), PRIMARY KEY (ID)); +CREATE TABLE COLTAB_EMP_EMBEDED_ADDRESS (ADDRESS_LOCATION VARCHAR(255), STREET VARCHAR(255), STATE VARCHAR(255), ZIP VARCHAR(255), CITY VARCHAR(255), ID VARCHAR(255), EMPEMBADDRID INTEGER); +ALTER TABLE COLTAB_EMP_EMBEDED_ADDRESS ADD CONSTRAINT FK_EMPEMBADDRID FOREIGN KEY (EMPEMBADDRID) REFERENCES EMPLOYEE_EMBEDED_ADDRESS (ID) ; + +DROP SEQUENCE SEQGENERATOR RESTRICT; +CREATE SEQUENCE SEQGENERATOR AS INT START WITH 10; + +DROP TABLE UUIDTYPE; +CREATE TABLE UUIDTYPE (ID VARCHAR(96) NOT NULL, NAME VARCHAR(255), PRIMARY KEY (ID)); + +DROP TABLE CRITERIA_TEST_COLTABLE; +DROP TABLE CRITERIA_TEST_TABLE; +CREATE TABLE CRITERIA_TEST_TABLE (ID INTEGER PRIMARY KEY NOT NULL, DATE_VAL DATE, INT_VAL INTEGER, STR_VAL_1 VARCHAR(255), STR_VAL_2 VARCHAR(255), TIME_VAL TIME); +CREATE TABLE CRITERIA_TEST_COLTABLE(ENT_ID INTEGER NOT NULL, COLVAL VARCHAR(255), CONSTRAINT FK_CRITERIA_TEST_COLTABLE_ENT_ID FOREIGN KEY (ENT_ID) REFERENCES CRITERIA_TEST_TABLE (ID)); \ No newline at end of file diff --git a/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.dml.jpa.sql b/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.dml.jpa.sql new file mode 100644 index 0000000000..ed4405919b --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-run-ee/sql/derby/derby.dml.jpa.sql @@ -0,0 +1,2 @@ +Insert_Jpa_Purchase_Order= INSERT INTO PURCHASE_ORDER(ID, TOTAL, DESCRIPTION) VALUES(?, ?, null) +Select_Jpa_Purchase_Order= SELECT ID, TOTAL FROM PURCHASE_ORDER WHERE ID=? \ No newline at end of file diff --git a/glassfish-runner/persistence-tck/persistence-tck-run-ee/src/test/resources/arquillian.xml b/glassfish-runner/persistence-tck/persistence-tck-run-ee/src/test/resources/arquillian.xml new file mode 100644 index 0000000000..8cc5fa646d --- /dev/null +++ b/glassfish-runner/persistence-tck/persistence-tck-run-ee/src/test/resources/arquillian.xml @@ -0,0 +1,38 @@ + + + + + + + + + + + + false + localhost + false + false + 4848 + true + ${glassfish.home} + ${glassfish.debug} + + + + diff --git a/glassfish-runner/persistence-tck/pom.xml b/glassfish-runner/persistence-tck/pom.xml index cc7542cfd6..a2adebc9de 100644 --- a/glassfish-runner/persistence-tck/pom.xml +++ b/glassfish-runner/persistence-tck/pom.xml @@ -30,7 +30,9 @@ pom + persistence-tck-arquillian-extension persistence-tck-install + persistence-tck-run-ee persistence-tck-run-se diff --git a/jpa/spec-tests/src/main/resources/ee/jakarta/tck/persistence/common/pluggability/altprovider/METAINF/services/jakarta.persistence.spi.PersistenceProvider b/jpa/spec-tests/src/main/resources/ee/jakarta/tck/persistence/common/pluggability/altprovider/METAINF/services/jakarta.persistence.spi.PersistenceProvider index 314f3e7877..08c48386f0 100755 --- a/jpa/spec-tests/src/main/resources/ee/jakarta/tck/persistence/common/pluggability/altprovider/METAINF/services/jakarta.persistence.spi.PersistenceProvider +++ b/jpa/spec-tests/src/main/resources/ee/jakarta/tck/persistence/common/pluggability/altprovider/METAINF/services/jakarta.persistence.spi.PersistenceProvider @@ -1 +1 @@ -com.sun.ts.tests.jpa.common.pluggability.altprovider.implementation.PersistenceProvider \ No newline at end of file +ee.jakarta.tck.persistence.common.pluggability.altprovider.implementation.PersistenceProvider \ No newline at end of file