/******************************************************************************* | |
* 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 NoReferenceKeyIsSpecifiedTest extends ExceptionTest { | |
public NoReferenceKeyIsSpecifiedTest() { | |
super(); | |
setDescription("This tests No Reference Key Is Specified (TL-ERROR 52) " + ""); | |
} | |
protected void setup() { | |
expectedException = DescriptorException.noReferenceKeyIsSpecified(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(); | |
responsibilitiesListMapping.setReferenceTableName("RESPONS"); | |
responsibilitiesListMapping.setDirectFieldName("RESPONS.DESCRIP"); | |
//if the following is missing then the correct error will occure. | |
// responsibilitiesListMapping.setReferenceKeyFieldName("RESPONS.EMP_ID"); | |
descriptor.addMapping(responsibilitiesListMapping); | |
return descriptor; | |
} | |
} |