/******************************************************************************* * Copyright (c) 1998, 2015 Oracle and/or its affiliates. All rights reserved. * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * Oracle - initial API and implementation from Oracle TopLink ******************************************************************************/ package org.eclipse.persistence.testing.tests.validation; import org.eclipse.persistence.descriptors.ClassDescriptor; import org.eclipse.persistence.descriptors.RelationalDescriptor; import org.eclipse.persistence.exceptions.DescriptorException; import org.eclipse.persistence.exceptions.IntegrityChecker; import org.eclipse.persistence.exceptions.EclipseLinkException; import org.eclipse.persistence.mappings.DirectCollectionMapping; import org.eclipse.persistence.mappings.DirectToFieldMapping; import org.eclipse.persistence.sessions.DatabaseSession; //Created by Ian Reid //Date: Feb 5, 2k3 public class ReferenceTableNotSpecifiedTest extends ExceptionTest { public ReferenceTableNotSpecifiedTest() { super(); setDescription("This tests Reference Table Not Specified (TL-ERROR 79) " + ""); } protected void setup() { expectedException = DescriptorException.referenceTableNotSpecified(null); orgDescriptor = ((DatabaseSession)getSession()).getDescriptor(org.eclipse.persistence.testing.models.employee.domain.Employee.class); orgIntegrityChecker = getSession().getIntegrityChecker(); } ClassDescriptor orgDescriptor; IntegrityChecker orgIntegrityChecker; public void reset() { ((DatabaseSession)getSession()).getDescriptors().remove(org.eclipse.persistence.testing.models.employee.domain.Employee.class); if (orgDescriptor != null) ((DatabaseSession)getSession()).addDescriptor(orgDescriptor); if (orgIntegrityChecker != null) getSession().setIntegrityChecker(orgIntegrityChecker); } public void test() { try { getSession().setIntegrityChecker(new IntegrityChecker()); getSession().getIntegrityChecker().dontCatchExceptions(); ((DatabaseSession)getSession()).addDescriptor(descriptor()); } catch (EclipseLinkException exception) { caughtException = exception; } } public RelationalDescriptor descriptor() { RelationalDescriptor descriptor = new RelationalDescriptor(); descriptor.setJavaClass(org.eclipse.persistence.testing.models.employee.domain.Employee.class); descriptor.addTableName("EMPLOYEE"); descriptor.addTableName("ADDRESS"); descriptor.addPrimaryKeyFieldName("EMPLOYEE.EMP_ID"); // Descriptor properties. descriptor.useFullIdentityMap(); descriptor.setIdentityMapSize(100); descriptor.useRemoteFullIdentityMap(); descriptor.setRemoteIdentityMapSize(100); descriptor.setSequenceNumberFieldName("EMP_ID"); descriptor.setSequenceNumberName("EMP_SEQ"); DirectToFieldMapping idMapping = new DirectToFieldMapping(); idMapping.setAttributeName("id"); idMapping.setFieldName("EMPLOYEE.EMP_ID"); descriptor.addMapping(idMapping); DirectCollectionMapping responsibilitiesListMapping = new DirectCollectionMapping(); responsibilitiesListMapping.setAttributeName("responsibilitiesList"); responsibilitiesListMapping.useBasicIndirection(); //if the following is missing then the correct error will occure. // responsibilitiesListMapping.setReferenceTableName("RESPONS"); responsibilitiesListMapping.setDirectFieldName("RESPONS.DESCRIP"); responsibilitiesListMapping.setReferenceKeyFieldName("RESPONS.EMP_ID"); responsibilitiesListMapping.setReferenceKeyFieldName("EMPLOYEE.EMP_ID"); descriptor.addMapping(responsibilitiesListMapping); return descriptor; } }