blob: 51ae09d9e097dc9e9faafeb72bb4b1b137e850f8 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 1998, 2013 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;
}
}