blob: b689dc22b6884b017e210a7e38726f5b523b377a [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2007, 2012 Oracle. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0, which accompanies this distribution
* and is available at http://www.eclipse.org/legal/epl-v10.html.
*
* Contributors:
* Oracle - initial API and implementation
******************************************************************************/
package org.eclipse.jpt.jpa.core.tests.internal.context.orm;
import java.util.Iterator;
import java.util.ListIterator;
import org.eclipse.jdt.core.ICompilationUnit;
import org.eclipse.jpt.common.core.tests.internal.projects.TestJavaProject.SourceWriter;
import org.eclipse.jpt.common.utility.internal.iterators.ArrayIterator;
import org.eclipse.jpt.jpa.core.JptJpaCorePlugin;
import org.eclipse.jpt.jpa.core.MappingKeys;
import org.eclipse.jpt.jpa.core.context.IdMapping;
import org.eclipse.jpt.jpa.core.context.JoinColumn;
import org.eclipse.jpt.jpa.core.context.JoinTable;
import org.eclipse.jpt.jpa.core.context.ManyToManyMapping;
import org.eclipse.jpt.jpa.core.context.ReadOnlyPersistentAttribute;
import org.eclipse.jpt.jpa.core.context.UniqueConstraint;
import org.eclipse.jpt.jpa.core.context.java.JavaEntity;
import org.eclipse.jpt.jpa.core.context.java.JavaJoinColumn;
import org.eclipse.jpt.jpa.core.context.java.JavaJoinTable;
import org.eclipse.jpt.jpa.core.context.java.JavaManyToManyMapping;
import org.eclipse.jpt.jpa.core.context.java.JavaPersistentAttribute;
import org.eclipse.jpt.jpa.core.context.orm.OrmEntity;
import org.eclipse.jpt.jpa.core.context.orm.OrmJoinColumn;
import org.eclipse.jpt.jpa.core.context.orm.OrmJoinTable;
import org.eclipse.jpt.jpa.core.context.orm.OrmManyToManyMapping;
import org.eclipse.jpt.jpa.core.context.orm.OrmPersistentAttribute;
import org.eclipse.jpt.jpa.core.context.orm.OrmPersistentType;
import org.eclipse.jpt.jpa.core.context.orm.OrmReadOnlyPersistentAttribute;
import org.eclipse.jpt.jpa.core.context.orm.OrmUniqueConstraint;
import org.eclipse.jpt.jpa.core.internal.context.orm.VirtualOrmPersistentAttribute;
import org.eclipse.jpt.jpa.core.resource.java.JPA;
import org.eclipse.jpt.jpa.core.resource.orm.OrmFactory;
import org.eclipse.jpt.jpa.core.resource.orm.XmlJoinTable;
import org.eclipse.jpt.jpa.core.resource.orm.XmlManyToMany;
import org.eclipse.jpt.jpa.core.resource.orm.XmlUniqueConstraint;
import org.eclipse.jpt.jpa.core.resource.persistence.PersistenceFactory;
import org.eclipse.jpt.jpa.core.resource.persistence.XmlMappingFileRef;
import org.eclipse.jpt.jpa.core.tests.internal.context.ContextModelTestCase;
@SuppressWarnings("nls")
public class OrmJoinTableTests extends ContextModelTestCase
{
public OrmJoinTableTests(String name) {
super(name);
}
@Override
protected void setUp() throws Exception {
super.setUp();
XmlMappingFileRef mappingFileRef = PersistenceFactory.eINSTANCE.createXmlMappingFileRef();
mappingFileRef.setFileName(JptJpaCorePlugin.DEFAULT_ORM_XML_RUNTIME_PATH.toString());
getXmlPersistenceUnit().getMappingFiles().add(mappingFileRef);
getPersistenceXmlResource().save(null);
}
private ICompilationUnit createTestEntityWithValidManyToMany() throws Exception {
return this.createTestType(new DefaultAnnotationWriter() {
@Override
public Iterator<String> imports() {
return new ArrayIterator<String>(JPA.ENTITY, JPA.MANY_TO_MANY, JPA.ID, "java.util.Collection");
}
@Override
public void appendTypeAnnotationTo(StringBuilder sb) {
sb.append("@Entity");
}
@Override
public void appendIdFieldAnnotationTo(StringBuilder sb) {
sb.append("@ManyToMany").append(CR);
sb.append(" private Collection<Project> projects;").append(CR);
}
});
}
private void createTargetEntity() throws Exception {
SourceWriter sourceWriter = new SourceWriter() {
public void appendSourceTo(StringBuilder sb) {
sb.append(CR);
sb.append("import ");
sb.append(JPA.ENTITY);
sb.append(";");
sb.append(CR);
sb.append("import ");
sb.append(JPA.ID);
sb.append(";");
sb.append(CR);
sb.append(CR);
sb.append("@Entity");
sb.append(CR);
sb.append("public class Project {").append(CR);
sb.append(CR);
sb.append(" @Id").append(CR);
sb.append(" private int proj_id;").append(CR);
sb.append(CR);
sb.append("}");
}
};
this.javaProject.createCompilationUnit(PACKAGE_NAME, "Project.java", sourceWriter);
}
private void createTargetEntityWithBackPointer() throws Exception {
SourceWriter sourceWriter = new SourceWriter() {
public void appendSourceTo(StringBuilder sb) {
sb.append(CR);
sb.append("import ");
sb.append(JPA.ENTITY);
sb.append(";");
sb.append(CR);
sb.append("import ");
sb.append(JPA.ID);
sb.append(";");
sb.append(CR);
sb.append("import ");
sb.append(JPA.MANY_TO_MANY);
sb.append(";");
sb.append(CR);
sb.append(CR);
sb.append("@Entity");
sb.append(CR);
sb.append("public class Project {").append(CR);
sb.append(CR);
sb.append(" @Id").append(CR);
sb.append(" private int proj_id;").append(CR);
sb.append(" @ManyToMany(mappedBy=\"projects\"").append(CR);
sb.append(" private java.util.Collection<" + TYPE_NAME + "> employees;").append(CR);
sb.append(CR);
sb.append("}");
}
};
this.javaProject.createCompilationUnit(PACKAGE_NAME, "Project.java", sourceWriter);
}
public void testUpdateSpecifiedName() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertNull(ormJoinTable.getSpecifiedName());
assertNull(manyToMany.getJoinTable());
//set name in the resource model, verify context model updated
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
manyToMany.getJoinTable().setName("FOO");
assertEquals("FOO", ormJoinTable.getSpecifiedName());
assertEquals("FOO", manyToMany.getJoinTable().getName());
//set name to null in the resource model
manyToMany.getJoinTable().setName(null);
assertNull(ormJoinTable.getSpecifiedName());
assertNull(manyToMany.getJoinTable().getName());
manyToMany.getJoinTable().setName("FOO");
assertEquals("FOO", ormJoinTable.getSpecifiedName());
assertEquals("FOO", manyToMany.getJoinTable().getName());
manyToMany.setJoinTable(null);
assertNull(ormJoinTable.getSpecifiedName());
assertNull(manyToMany.getJoinTable());
}
public void testModifySpecifiedName() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertNull(ormJoinTable.getSpecifiedName());
assertNull(manyToMany.getJoinTable());
//set name in the context model, verify resource model modified
ormJoinTable.setSpecifiedName("foo");
assertEquals("foo", ormJoinTable.getSpecifiedName());
assertEquals("foo", manyToMany.getJoinTable().getName());
//set name to null in the context model
ormJoinTable.setSpecifiedName(null);
assertNull(ormJoinTable.getSpecifiedName());
assertNull(manyToMany.getJoinTable());
}
public void testVirtualJoinTable() throws Exception {
createTestEntityWithValidManyToMany();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmReadOnlyPersistentAttribute ormPersistentAttribute = ormPersistentType.getAttributeNamed("projects");
ManyToManyMapping virtualManyToManyMapping = (ManyToManyMapping) ormPersistentAttribute.getMapping();
JoinTable virtualJoinTable = virtualManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertTrue(ormPersistentAttribute.isVirtual());
assertEquals(null, virtualJoinTable.getSpecifiedName());
createTargetEntity();
getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME_ + "Project");
assertEquals(TYPE_NAME + "_Project", virtualJoinTable.getName());
assertNull(virtualJoinTable.getSpecifiedCatalog());
assertNull(virtualJoinTable.getSpecifiedSchema());
assertEquals(0, virtualJoinTable.getSpecifiedJoinColumnsSize());
assertEquals(0, virtualJoinTable.getSpecifiedInverseJoinColumnsSize());
JoinColumn ormJoinColumn = virtualJoinTable.getDefaultJoinColumn();
//TODO need to test joinColumn defaults here as well as in java and all the relationship mapping types
// assertEquals("id_project_id", ormJoinColumn.getDefaultName());
// assertEquals("id_project_id", ormJoinColumn.getDefaultReferencedColumnName());
JoinColumn inverseOrmJoinColumn = virtualJoinTable.getDefaultInverseJoinColumn();
// assertEquals("id_project_id", inverseOrmJoinColumn.getDefaultName());
// assertEquals("id_project_id", inverseOrmJoinColumn.getDefaultReferencedColumnName());
JavaPersistentAttribute javaPersistentAttribute = ormPersistentAttribute.getJavaPersistentAttribute();
JavaManyToManyMapping javaManyToManyMapping = (JavaManyToManyMapping) javaPersistentAttribute.getMapping();
JavaJoinTable javaJoinTable = javaManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
javaJoinTable.setSpecifiedName("FOO");
javaJoinTable.setSpecifiedCatalog("CATALOG");
javaJoinTable.setSpecifiedSchema("SCHEMA");
JavaJoinColumn javaJoinColumn = javaJoinTable.addSpecifiedJoinColumn(0);
javaJoinColumn.setSpecifiedName("NAME");
javaJoinColumn.setSpecifiedReferencedColumnName("REFERENCED_NAME");
JavaJoinColumn inverseJavaJoinColumn = javaJoinTable.addSpecifiedInverseJoinColumn(0);
inverseJavaJoinColumn.setSpecifiedName("INVERSE_NAME");
inverseJavaJoinColumn.setSpecifiedReferencedColumnName("INVERSE_REFERENCED_NAME");
assertEquals("FOO", virtualJoinTable.getSpecifiedName());
assertEquals("CATALOG", virtualJoinTable.getSpecifiedCatalog());
assertEquals("SCHEMA", virtualJoinTable.getSpecifiedSchema());
assertEquals(1, virtualJoinTable.getSpecifiedJoinColumnsSize());
assertEquals(1, virtualJoinTable.getSpecifiedInverseJoinColumnsSize());
ormJoinColumn = virtualJoinTable.getSpecifiedJoinColumns().iterator().next();
assertEquals("NAME", ormJoinColumn.getSpecifiedName());
assertEquals("REFERENCED_NAME", ormJoinColumn.getSpecifiedReferencedColumnName());
inverseOrmJoinColumn = virtualJoinTable.getSpecifiedInverseJoinColumns().iterator().next();
assertEquals("INVERSE_NAME", inverseOrmJoinColumn.getSpecifiedName());
assertEquals("INVERSE_REFERENCED_NAME", inverseOrmJoinColumn.getSpecifiedReferencedColumnName());
}
public void testUpdateDefaultNameFromJavaTable() throws Exception {
createTestEntityWithValidManyToMany();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("projects"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertEquals(null, ormJoinTable.getDefaultName());
createTargetEntity();
OrmPersistentType targetPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME + ".Project");
assertEquals(TYPE_NAME + "_Project", ormJoinTable.getDefaultName());
((JavaEntity) targetPersistentType.getJavaPersistentType().getMapping()).getTable().setSpecifiedName("FOO");
assertEquals(TYPE_NAME + "_FOO", ormJoinTable.getDefaultName());
((JavaEntity) ormPersistentType.getJavaPersistentType().getMapping()).getTable().setSpecifiedName("BAR");
assertEquals("BAR_FOO", ormJoinTable.getDefaultName());
ormPersistentType.getJavaPersistentType().getAttributeNamed("projects").setMappingKey(MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
JavaManyToManyMapping javaManyMapping = (JavaManyToManyMapping) ormPersistentType.getJavaPersistentType().getAttributeNamed("projects").getMapping();
javaManyMapping.getRelationship().getJoinTableStrategy().getJoinTable().setSpecifiedName("JAVA_JOIN_TABLE");
assertEquals("BAR_FOO", ormJoinTable.getDefaultName());
//set metadata-complete to true, will ignore java annotation settings
getEntityMappings().getPersistenceUnitMetadata().setXmlMappingMetadataComplete(true);
//ormPersistentType.getMapping().setSpecifiedMetadataComplete(Boolean.TRUE);
assertEquals(TYPE_NAME + "_Project", ormJoinTable.getDefaultName());
getEntityMappings().getPersistenceUnitMetadata().setXmlMappingMetadataComplete(false);
//remove m-m mapping from the orm.xml file
ormPersistentAttribute.removeFromXml();
//ormPersistentType.getMapping().setSpecifiedMetadataComplete(null);
OrmReadOnlyPersistentAttribute ormPersistentAttribute2 = ormPersistentType.getAttributeNamed("projects");
ManyToManyMapping virtualManyToManyMapping = (ManyToManyMapping) ormPersistentAttribute2.getMapping();
JoinTable virtualJoinTable = virtualManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertTrue(ormPersistentAttribute2.isVirtual());
assertEquals("JAVA_JOIN_TABLE", virtualJoinTable.getSpecifiedName());//specifiedName since this is a virtual mapping now
javaManyMapping.getRelationship().getJoinTableStrategy().getJoinTable().setSpecifiedName(null);
javaManyMapping.getRelationship().setStrategyToJoinTable();
assertNull(virtualJoinTable.getSpecifiedName());
assertEquals("BAR_FOO", virtualJoinTable.getDefaultName());
((OrmEntity) ormPersistentType.getMapping()).getTable().setSpecifiedName("ORM_TABLE_NAME");
assertEquals("ORM_TABLE_NAME_FOO", virtualJoinTable.getDefaultName());
((OrmEntity) targetPersistentType.getMapping()).getTable().setSpecifiedName("ORM_TARGET");
assertEquals("ORM_TABLE_NAME_ORM_TARGET", virtualJoinTable.getDefaultName());
}
public void testUpdateSpecifiedSchema() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertNull(ormJoinTable.getSpecifiedSchema());
assertNull(manyToMany.getJoinTable());
//set schema in the resource model, verify context model updated
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
manyToMany.getJoinTable().setSchema("FOO");
assertEquals("FOO", ormJoinTable.getSpecifiedSchema());
assertEquals("FOO", manyToMany.getJoinTable().getSchema());
//set Schema to null in the resource model
manyToMany.getJoinTable().setSchema(null);
assertNull(ormJoinTable.getSpecifiedSchema());
assertNull(manyToMany.getJoinTable().getSchema());
manyToMany.getJoinTable().setSchema("FOO");
assertEquals("FOO", ormJoinTable.getSpecifiedSchema());
assertEquals("FOO", manyToMany.getJoinTable().getSchema());
manyToMany.setJoinTable(null);
assertNull(ormJoinTable.getSpecifiedSchema());
assertNull(manyToMany.getJoinTable());
}
// public void testUpdateDefaultSchemaFromJavaTable() throws Exception {
// createTestEntity();
//
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// assertNull(xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.javaEntity().getTable().setSpecifiedSchema("Foo");
// assertEquals("Foo", xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.setSpecifiedMetadataComplete(Boolean.TRUE);
// assertNull(xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().setXmlMappingMetadataComplete(true);
// xmlEntity.setSpecifiedMetadataComplete(Boolean.FALSE);
// assertNull(xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.setSpecifiedMetadataComplete(null);
// assertNull(xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().setXmlMappingMetadataComplete(false);
// assertEquals("Foo", xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.getTable().setSpecifiedName("Bar");
// assertNull(xmlEntity.getTable().getDefaultSchema());
// }
//
// public void testUpdateDefaultSchemaNoJava() throws Exception {
// createTestEntity();
//
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo");
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// assertNull(xmlEntity.getTable().getDefaultSchema());
// }
//
// public void testUpdateDefaultSchemaFromParent() throws Exception {
// createTestEntity();
// createTestSubType();
//
// OrmPersistentType parentOrmPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
// OrmPersistentType childOrmPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME + ".AnnotationTestTypeChild");
// XmlEntity parentXmlEntity = (XmlEntity) parentOrmPersistentType.getMapping();
// XmlEntity childXmlEntity = (XmlEntity) childOrmPersistentType.getMapping();
//
// assertNull(parentXmlEntity.getTable().getDefaultSchema());
// assertNull(childXmlEntity.getTable().getDefaultSchema());
//
// parentXmlEntity.getTable().setSpecifiedSchema("FOO");
// assertNull(parentXmlEntity.getTable().getDefaultSchema());
// assertEquals("FOO", childXmlEntity.getTable().getDefaultSchema());
//
// parentXmlEntity.setSpecifiedInheritanceStrategy(InheritanceType.JOINED);
// assertNull(parentXmlEntity.getTable().getDefaultSchema());
// assertNull(childXmlEntity.getTable().getDefaultSchema());
// }
//
// public void testUpdateDefaultSchemaFromPersistenceUnitDefaults() throws Exception {
// createTestEntity();
//
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// assertNull(xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().getPersistenceUnitDefaults().setSchema("FOO");
// assertEquals("FOO", xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.entityMappings().setSpecifiedSchema("BAR");
// assertEquals("BAR", xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.javaEntity().getTable().setSpecifiedSchema("JAVA_SCHEMA");
// assertEquals("JAVA_SCHEMA", xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.getTable().setSpecifiedName("BLAH");
// //xml entity now has a table element so default schema is not taken from java
// assertEquals("BAR", xmlEntity.getTable().getDefaultSchema());
//
//
// xmlEntity.entityMappings().setSpecifiedSchema(null);
// assertEquals("FOO", xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().getPersistenceUnitDefaults().setSchema(null);
// assertNull(xmlEntity.getTable().getDefaultSchema());
//
// xmlEntity.getTable().setSpecifiedName(null);
// assertEquals("JAVA_SCHEMA", xmlEntity.getTable().getDefaultSchema());
// }
public void testModifySpecifiedSchema() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertNull(ormJoinTable.getSpecifiedSchema());
assertNull(manyToMany.getJoinTable());
//set Schema in the context model, verify resource model modified
ormJoinTable.setSpecifiedSchema("foo");
assertEquals("foo", ormJoinTable.getSpecifiedSchema());
assertEquals("foo", manyToMany.getJoinTable().getSchema());
//set Schema to null in the context model
ormJoinTable.setSpecifiedSchema(null);
assertNull(ormJoinTable.getSpecifiedSchema());
assertNull(manyToMany.getJoinTable());
}
public void testUpdateSpecifiedCatalog() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertNull(ormJoinTable.getSpecifiedCatalog());
assertNull(manyToMany.getJoinTable());
//set Catalog in the resource model, verify context model updated
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
manyToMany.getJoinTable().setCatalog("FOO");
assertEquals("FOO", ormJoinTable.getSpecifiedCatalog());
assertEquals("FOO", manyToMany.getJoinTable().getCatalog());
//set Catalog to null in the resource model
manyToMany.getJoinTable().setCatalog(null);
assertNull(ormJoinTable.getSpecifiedCatalog());
assertNull(manyToMany.getJoinTable().getCatalog());
manyToMany.getJoinTable().setCatalog("FOO");
assertEquals("FOO", ormJoinTable.getSpecifiedCatalog());
assertEquals("FOO", manyToMany.getJoinTable().getCatalog());
manyToMany.setJoinTable(null);
assertNull(ormJoinTable.getSpecifiedCatalog());
assertNull(manyToMany.getJoinTable());
}
public void testModifySpecifiedCatalog() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertNull(ormJoinTable.getSpecifiedCatalog());
assertNull(manyToMany.getJoinTable());
//set Catalog in the context model, verify resource model modified
ormJoinTable.setSpecifiedCatalog("foo");
assertEquals("foo", ormJoinTable.getSpecifiedCatalog());
assertEquals("foo", manyToMany.getJoinTable().getCatalog());
//set Catalog to null in the context model
ormJoinTable.setSpecifiedCatalog(null);
assertNull(ormJoinTable.getSpecifiedCatalog());
assertNull(manyToMany.getJoinTable());
}
// public void testUpdateDefaultCatalogFromJavaTable() throws Exception {
// createTestEntity();
//
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// assertNull(xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.javaEntity().getTable().setSpecifiedCatalog("Foo");
// assertEquals("Foo", xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.setSpecifiedMetadataComplete(Boolean.TRUE);
// assertNull(xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().setXmlMappingMetadataComplete(true);
// xmlEntity.setSpecifiedMetadataComplete(Boolean.FALSE);
// assertNull(xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.setSpecifiedMetadataComplete(null);
// assertNull(xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().setXmlMappingMetadataComplete(false);
// assertEquals("Foo", xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.getTable().setSpecifiedName("Bar");
// assertNull(xmlEntity.getTable().getDefaultCatalog());
// }
//
// public void testUpdateDefaultCatalogNoJava() throws Exception {
// createTestEntity();
//
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo");
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// assertNull(xmlEntity.getTable().getDefaultCatalog());
// }
//
// public void testUpdateDefaultCatalogFromParent() throws Exception {
// createTestEntity();
// createTestSubType();
//
// OrmPersistentType parentOrmPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
// OrmPersistentType childOrmPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME + ".AnnotationTestTypeChild");
// XmlEntity parentXmlEntity = (XmlEntity) parentOrmPersistentType.getMapping();
// XmlEntity childXmlEntity = (XmlEntity) childOrmPersistentType.getMapping();
//
// assertNull(parentXmlEntity.getTable().getDefaultCatalog());
// assertNull(childXmlEntity.getTable().getDefaultCatalog());
//
// parentXmlEntity.getTable().setSpecifiedCatalog("FOO");
// assertNull(parentXmlEntity.getTable().getDefaultCatalog());
// assertEquals("FOO", childXmlEntity.getTable().getDefaultCatalog());
//
// parentXmlEntity.setSpecifiedInheritanceStrategy(InheritanceType.JOINED);
// assertNull(parentXmlEntity.getTable().getDefaultCatalog());
// assertNull(childXmlEntity.getTable().getDefaultCatalog());
// }
//
// public void testUpdateDefaultCatalogFromPersistenceUnitDefaults() throws Exception {
// createTestEntity();
//
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// assertNull(xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().getPersistenceUnitDefaults().setCatalog("FOO");
// assertEquals("FOO", xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.entityMappings().setSpecifiedCatalog("BAR");
// assertEquals("BAR", xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.javaEntity().getTable().setSpecifiedCatalog("JAVA_CATALOG");
// assertEquals("JAVA_CATALOG", xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.getTable().setSpecifiedName("BLAH");
// //xml entity now has a table element so default schema is not taken from java
// assertEquals("BAR", xmlEntity.getTable().getDefaultCatalog());
//
//
// xmlEntity.entityMappings().setSpecifiedCatalog(null);
// assertEquals("FOO", xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.entityMappings().getPersistenceUnitMetadata().getPersistenceUnitDefaults().setCatalog(null);
// assertNull(xmlEntity.getTable().getDefaultCatalog());
//
// xmlEntity.getTable().setSpecifiedName(null);
// assertEquals("JAVA_CATALOG", xmlEntity.getTable().getDefaultCatalog());
//}
//
// public void testUpdateName() throws Exception {
// OrmPersistentType ormPersistentType = entityMappings().addOrmPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo");
// XmlEntity xmlEntity = (XmlEntity) ormPersistentType.getMapping();
// Entity entityResource = ormResource().getEntityMappings().getEntities().get(0);
// assertEquals("Foo", xmlEntity.getName());
//
// //set class in the resource model, verify context model updated
// entityResource.setClassName("com.Bar");
// assertEquals("Bar", xmlEntity.getName());
//
// entityResource.setName("Baz");
// assertEquals("Baz", xmlEntity.getName());
//
// //set class to null in the resource model
// entityResource.setClassName(null);
// assertEquals("Baz", xmlEntity.getName());
//
// entityResource.setName(null);
// assertNull(xmlEntity.getName());
// }
public void testAddSpecifiedJoinColumn() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
OrmJoinColumn joinColumn = ormJoinTable.addSpecifiedJoinColumn(0);
joinColumn.setSpecifiedName("FOO");
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals("FOO", joinTableResource.getJoinColumns().get(0).getName());
OrmJoinColumn joinColumn2 = ormJoinTable.addSpecifiedJoinColumn(0);
joinColumn2.setSpecifiedName("BAR");
assertEquals("BAR", joinTableResource.getJoinColumns().get(0).getName());
assertEquals("FOO", joinTableResource.getJoinColumns().get(1).getName());
OrmJoinColumn joinColumn3 = ormJoinTable.addSpecifiedJoinColumn(1);
joinColumn3.setSpecifiedName("BAZ");
assertEquals("BAR", joinTableResource.getJoinColumns().get(0).getName());
assertEquals("BAZ", joinTableResource.getJoinColumns().get(1).getName());
assertEquals("FOO", joinTableResource.getJoinColumns().get(2).getName());
ListIterator<OrmJoinColumn> joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals(joinColumn2, joinColumns.next());
assertEquals(joinColumn3, joinColumns.next());
assertEquals(joinColumn, joinColumns.next());
joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
}
public void testRemoveSpecifiedJoinColumn() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
ormJoinTable.addSpecifiedJoinColumn(0).setSpecifiedName("FOO");
ormJoinTable.addSpecifiedJoinColumn(1).setSpecifiedName("BAR");
ormJoinTable.addSpecifiedJoinColumn(2).setSpecifiedName("BAZ");
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals(3, joinTableResource.getJoinColumns().size());
ormJoinTable.removeSpecifiedJoinColumn(0);
assertEquals(2, joinTableResource.getJoinColumns().size());
assertEquals("BAR", joinTableResource.getJoinColumns().get(0).getName());
assertEquals("BAZ", joinTableResource.getJoinColumns().get(1).getName());
ormJoinTable.removeSpecifiedJoinColumn(0);
assertEquals(1, joinTableResource.getJoinColumns().size());
assertEquals("BAZ", joinTableResource.getJoinColumns().get(0).getName());
ormJoinTable.removeSpecifiedJoinColumn(0);
assertEquals(0, joinTableResource.getJoinColumns().size());
}
public void testMoveSpecifiedJoinColumn() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
ormJoinTable.addSpecifiedJoinColumn(0).setSpecifiedName("FOO");
ormJoinTable.addSpecifiedJoinColumn(1).setSpecifiedName("BAR");
ormJoinTable.addSpecifiedJoinColumn(2).setSpecifiedName("BAZ");
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals(3, joinTableResource.getJoinColumns().size());
ormJoinTable.moveSpecifiedJoinColumn(2, 0);
ListIterator<OrmJoinColumn> joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertEquals("BAR", joinTableResource.getJoinColumns().get(0).getName());
assertEquals("BAZ", joinTableResource.getJoinColumns().get(1).getName());
assertEquals("FOO", joinTableResource.getJoinColumns().get(2).getName());
ormJoinTable.moveSpecifiedJoinColumn(0, 1);
joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("BAR", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertEquals("BAZ", joinTableResource.getJoinColumns().get(0).getName());
assertEquals("BAR", joinTableResource.getJoinColumns().get(1).getName());
assertEquals("FOO", joinTableResource.getJoinColumns().get(2).getName());
}
public void testUpdateInverseJoinColumns() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
joinTableResource.getInverseJoinColumns().add(OrmFactory.eINSTANCE.createXmlJoinColumn());
joinTableResource.getInverseJoinColumns().add(OrmFactory.eINSTANCE.createXmlJoinColumn());
joinTableResource.getInverseJoinColumns().add(OrmFactory.eINSTANCE.createXmlJoinColumn());
joinTableResource.getInverseJoinColumns().get(0).setName("FOO");
joinTableResource.getInverseJoinColumns().get(1).setName("BAR");
joinTableResource.getInverseJoinColumns().get(2).setName("BAZ");
ListIterator<OrmJoinColumn> joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("FOO", joinColumns.next().getName());
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getInverseJoinColumns().move(2, 0);
joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getInverseJoinColumns().move(0, 1);
joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("BAR", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getInverseJoinColumns().remove(1);
joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getInverseJoinColumns().remove(1);
joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getInverseJoinColumns().remove(0);
assertFalse(ormJoinTable.getSpecifiedInverseJoinColumns().iterator().hasNext());
}
public void testAddSpecifiedInverseJoinColumn() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
OrmJoinColumn joinColumn = ormJoinTable.addSpecifiedInverseJoinColumn(0);
joinColumn.setSpecifiedName("FOO");
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals("FOO", joinTableResource.getInverseJoinColumns().get(0).getName());
OrmJoinColumn joinColumn2 = ormJoinTable.addSpecifiedInverseJoinColumn(0);
joinColumn2.setSpecifiedName("BAR");
assertEquals("BAR", joinTableResource.getInverseJoinColumns().get(0).getName());
assertEquals("FOO", joinTableResource.getInverseJoinColumns().get(1).getName());
OrmJoinColumn joinColumn3 = ormJoinTable.addSpecifiedInverseJoinColumn(1);
joinColumn3.setSpecifiedName("BAZ");
assertEquals("BAR", joinTableResource.getInverseJoinColumns().get(0).getName());
assertEquals("BAZ", joinTableResource.getInverseJoinColumns().get(1).getName());
assertEquals("FOO", joinTableResource.getInverseJoinColumns().get(2).getName());
ListIterator<OrmJoinColumn> joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals(joinColumn2, joinColumns.next());
assertEquals(joinColumn3, joinColumns.next());
assertEquals(joinColumn, joinColumns.next());
joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
}
public void testRemoveSpecifiedInverseJoinColumn() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
ormJoinTable.addSpecifiedInverseJoinColumn(0).setSpecifiedName("FOO");
ormJoinTable.addSpecifiedInverseJoinColumn(1).setSpecifiedName("BAR");
ormJoinTable.addSpecifiedInverseJoinColumn(2).setSpecifiedName("BAZ");
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals(3, joinTableResource.getInverseJoinColumns().size());
ormJoinTable.removeSpecifiedInverseJoinColumn(0);
assertEquals(2, joinTableResource.getInverseJoinColumns().size());
assertEquals("BAR", joinTableResource.getInverseJoinColumns().get(0).getName());
assertEquals("BAZ", joinTableResource.getInverseJoinColumns().get(1).getName());
ormJoinTable.removeSpecifiedInverseJoinColumn(0);
assertEquals(1, joinTableResource.getInverseJoinColumns().size());
assertEquals("BAZ", joinTableResource.getInverseJoinColumns().get(0).getName());
ormJoinTable.removeSpecifiedInverseJoinColumn(0);
assertEquals(0, joinTableResource.getInverseJoinColumns().size());
}
public void testMoveSpecifiedInverseJoinColumn() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
ormJoinTable.addSpecifiedInverseJoinColumn(0).setSpecifiedName("FOO");
ormJoinTable.addSpecifiedInverseJoinColumn(1).setSpecifiedName("BAR");
ormJoinTable.addSpecifiedInverseJoinColumn(2).setSpecifiedName("BAZ");
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals(3, joinTableResource.getInverseJoinColumns().size());
ormJoinTable.moveSpecifiedInverseJoinColumn(2, 0);
ListIterator<OrmJoinColumn> joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertEquals("BAR", joinTableResource.getInverseJoinColumns().get(0).getName());
assertEquals("BAZ", joinTableResource.getInverseJoinColumns().get(1).getName());
assertEquals("FOO", joinTableResource.getInverseJoinColumns().get(2).getName());
ormJoinTable.moveSpecifiedInverseJoinColumn(0, 1);
joinColumns = ormJoinTable.getSpecifiedInverseJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("BAR", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertEquals("BAZ", joinTableResource.getInverseJoinColumns().get(0).getName());
assertEquals("BAR", joinTableResource.getInverseJoinColumns().get(1).getName());
assertEquals("FOO", joinTableResource.getInverseJoinColumns().get(2).getName());
}
public void testUpdateJoinColumns() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
joinTableResource.getJoinColumns().add(OrmFactory.eINSTANCE.createXmlJoinColumn());
joinTableResource.getJoinColumns().add(OrmFactory.eINSTANCE.createXmlJoinColumn());
joinTableResource.getJoinColumns().add(OrmFactory.eINSTANCE.createXmlJoinColumn());
joinTableResource.getJoinColumns().get(0).setName("FOO");
joinTableResource.getJoinColumns().get(1).setName("BAR");
joinTableResource.getJoinColumns().get(2).setName("BAZ");
ListIterator<OrmJoinColumn> joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("FOO", joinColumns.next().getName());
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getJoinColumns().move(2, 0);
joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAR", joinColumns.next().getName());
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getJoinColumns().move(0, 1);
joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("BAR", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getJoinColumns().remove(1);
joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertEquals("FOO", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getJoinColumns().remove(1);
joinColumns = ormJoinTable.getSpecifiedJoinColumns().iterator();
assertEquals("BAZ", joinColumns.next().getName());
assertFalse(joinColumns.hasNext());
joinTableResource.getJoinColumns().remove(0);
assertFalse(ormJoinTable.getSpecifiedJoinColumns().iterator().hasNext());
}
public void testUniqueConstraints() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
ListIterator<OrmUniqueConstraint> uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertFalse(uniqueConstraints.hasNext());
XmlUniqueConstraint uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(0, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "foo");
uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(0, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "bar");
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertTrue(uniqueConstraints.hasNext());
assertEquals("bar", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("foo", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
}
public void testUniqueConstraintsSize() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
assertEquals(0, ormJoinTable.getUniqueConstraintsSize());
XmlUniqueConstraint uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(0, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "foo");
uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(1, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "bar");
assertEquals(2, ormJoinTable.getUniqueConstraintsSize());
}
public void testAddUniqueConstraint() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "FOO");
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "BAR");
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "BAZ");
ListIterator<XmlUniqueConstraint> uniqueConstraints = joinTableResource.getUniqueConstraints().listIterator();
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().get(0));
assertEquals("BAR", uniqueConstraints.next().getColumnNames().get(0));
assertEquals("FOO", uniqueConstraints.next().getColumnNames().get(0));
assertFalse(uniqueConstraints.hasNext());
}
public void testAddUniqueConstraint2() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "FOO");
ormJoinTable.addUniqueConstraint(1).addColumnName(0, "BAR");
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "BAZ");
ListIterator<XmlUniqueConstraint> uniqueConstraints = joinTableResource.getUniqueConstraints().listIterator();
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().get(0));
assertEquals("FOO", uniqueConstraints.next().getColumnNames().get(0));
assertEquals("BAR", uniqueConstraints.next().getColumnNames().get(0));
assertFalse(uniqueConstraints.hasNext());
}
public void testRemoveUniqueConstraint() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "FOO");
ormJoinTable.addUniqueConstraint(1).addColumnName(0, "BAR");
ormJoinTable.addUniqueConstraint(2).addColumnName(0, "BAZ");
assertEquals(3, joinTableResource.getUniqueConstraints().size());
ormJoinTable.removeUniqueConstraint(1);
ListIterator<XmlUniqueConstraint> uniqueConstraintResources = joinTableResource.getUniqueConstraints().listIterator();
assertEquals("FOO", uniqueConstraintResources.next().getColumnNames().get(0));
assertEquals("BAZ", uniqueConstraintResources.next().getColumnNames().get(0));
assertFalse(uniqueConstraintResources.hasNext());
Iterator<OrmUniqueConstraint> uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
ormJoinTable.removeUniqueConstraint(1);
uniqueConstraintResources = joinTableResource.getUniqueConstraints().listIterator();
assertEquals("FOO", uniqueConstraintResources.next().getColumnNames().get(0));
assertFalse(uniqueConstraintResources.hasNext());
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
ormJoinTable.removeUniqueConstraint(0);
uniqueConstraintResources = joinTableResource.getUniqueConstraints().listIterator();
assertFalse(uniqueConstraintResources.hasNext());
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertFalse(uniqueConstraints.hasNext());
}
public void testMoveUniqueConstraint() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
ormJoinTable.addUniqueConstraint(0).addColumnName(0, "FOO");
ormJoinTable.addUniqueConstraint(1).addColumnName(0, "BAR");
ormJoinTable.addUniqueConstraint(2).addColumnName(0, "BAZ");
assertEquals(3, joinTableResource.getUniqueConstraints().size());
ormJoinTable.moveUniqueConstraint(2, 0);
ListIterator<OrmUniqueConstraint> uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("BAR", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
ListIterator<XmlUniqueConstraint> uniqueConstraintResources = joinTableResource.getUniqueConstraints().listIterator();
assertEquals("BAR", uniqueConstraintResources.next().getColumnNames().get(0));
assertEquals("BAZ", uniqueConstraintResources.next().getColumnNames().get(0));
assertEquals("FOO", uniqueConstraintResources.next().getColumnNames().get(0));
ormJoinTable.moveUniqueConstraint(0, 1);
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAR", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
uniqueConstraintResources = joinTableResource.getUniqueConstraints().listIterator();
assertEquals("BAZ", uniqueConstraintResources.next().getColumnNames().get(0));
assertEquals("BAR", uniqueConstraintResources.next().getColumnNames().get(0));
assertEquals("FOO", uniqueConstraintResources.next().getColumnNames().get(0));
}
public void testUpdateUniqueConstraints() throws Exception {
createTestType();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
OrmPersistentAttribute ormPersistentAttribute = ormPersistentType.addAttributeToXml(ormPersistentType.getAttributeNamed("id"), MappingKeys.MANY_TO_MANY_ATTRIBUTE_MAPPING_KEY);
OrmManyToManyMapping ormManyToManyMapping = (OrmManyToManyMapping) ormPersistentAttribute.getMapping();
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
OrmJoinTable ormJoinTable = ormManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
XmlJoinTable joinTableResource = manyToMany.getJoinTable();
XmlUniqueConstraint uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(0, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "FOO");
uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(1, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "BAR");
uniqueConstraintResource = OrmFactory.eINSTANCE.createXmlUniqueConstraint();
joinTableResource.getUniqueConstraints().add(2, uniqueConstraintResource);
uniqueConstraintResource.getColumnNames().add(0, "BAZ");
ListIterator<OrmUniqueConstraint> uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAR", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
joinTableResource.getUniqueConstraints().move(2, 0);
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("BAR", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
joinTableResource.getUniqueConstraints().move(0, 1);
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAR", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
joinTableResource.getUniqueConstraints().remove(1);
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
joinTableResource.getUniqueConstraints().remove(1);
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
joinTableResource.getUniqueConstraints().remove(0);
uniqueConstraints = ormJoinTable.getUniqueConstraints().iterator();
assertFalse(uniqueConstraints.hasNext());
}
public void testUniqueConstraintsFromJava() throws Exception {
createTestEntityWithValidManyToMany();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
ReadOnlyPersistentAttribute virtualAttribute = ormPersistentType.getAttributes().iterator().next();
ManyToManyMapping virtualManyToManyMapping = (ManyToManyMapping) virtualAttribute.getMapping();
JoinTable virtualJoinTable = virtualManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
assertTrue(virtualAttribute.isVirtual());
ListIterator<? extends UniqueConstraint> uniqueConstraints = virtualJoinTable.getUniqueConstraints().iterator();
assertFalse(uniqueConstraints.hasNext());
JavaManyToManyMapping javaManyToManyMapping = (JavaManyToManyMapping) ormPersistentType.getJavaPersistentType().getAttributes().iterator().next().getMapping();
JavaJoinTable javaJoinTable = javaManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
javaJoinTable.addUniqueConstraint(0).addColumnName(0, "FOO");
javaJoinTable.addUniqueConstraint(1).addColumnName(0, "BAR");
javaJoinTable.addUniqueConstraint(2).addColumnName(0, "BAZ");
uniqueConstraints = virtualJoinTable.getUniqueConstraints().iterator();
assertTrue(uniqueConstraints.hasNext());
assertEquals("FOO", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAR", uniqueConstraints.next().getColumnNames().iterator().next());
assertEquals("BAZ", uniqueConstraints.next().getColumnNames().iterator().next());
assertFalse(uniqueConstraints.hasNext());
OrmManyToManyMapping specifiedManyToManyMapping = (OrmManyToManyMapping) ((VirtualOrmPersistentAttribute) virtualAttribute).addToXml().getMapping();
assertEquals(0, specifiedManyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable().getUniqueConstraintsSize());
}
public void testDefaultName() throws Exception {
createTestEntityWithValidManyToMany();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
ormPersistentType.getAttributeNamed("projects").addToXml();
OrmManyToManyMapping manyToManyMapping = (OrmManyToManyMapping) ormPersistentType.getAttributeNamed("projects").getMapping();
JoinTable joinTable = manyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
//joinTable default name is null because targetEntity is not in the persistence unit
assertNull(joinTable.getDefaultName());
//add target entity to the persistence unit, now join table name is [table name]_[target table name]
createTargetEntity();
getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME + ".Project");
assertEquals(TYPE_NAME + "_Project", joinTable.getDefaultName());
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
assertNull(manyToMany.getJoinTable());
//target entity does not resolve, default name is null
manyToManyMapping.setSpecifiedTargetEntity("Foo");
assertNull(joinTable.getDefaultName());
//default target entity does resolve, so default name is again [table name]_[target table name]
manyToManyMapping.setSpecifiedTargetEntity(null);
assertEquals(TYPE_NAME + "_Project", joinTable.getDefaultName());
//add the join table xml element, verify default join table name is the same
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
assertEquals(TYPE_NAME + "_Project", joinTable.getDefaultName());
assertNotNull(manyToMany.getJoinTable());
//set a table on the target entity, very default join table name updates
manyToManyMapping.getResolvedTargetEntity().getTable().setSpecifiedName("FOO");
assertEquals(TYPE_NAME + "_FOO", joinTable.getDefaultName());
//set a table on the owning entity, very default join table name updates
((OrmEntity) ormPersistentType.getMapping()).getTable().setSpecifiedName("BAR");
assertEquals("BAR_FOO", joinTable.getDefaultName());
}
public void testDefaultJoinColumns() throws Exception {
createTestEntityWithValidManyToMany();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
ormPersistentType.getAttributeNamed("projects").addToXml();
OrmManyToManyMapping manyToManyMapping = (OrmManyToManyMapping) ormPersistentType.getAttributeNamed("projects").getMapping();
JoinTable joinTable = manyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
JoinColumn joinColumn = joinTable.getJoinColumns().iterator().next();
JoinColumn inverseJoinColumn = joinTable.getInverseJoinColumns().iterator().next();
//joinTable default name is null because targetEntity is not in the persistence unit
assertNull(joinColumn.getDefaultName());
assertNull(joinColumn.getDefaultReferencedColumnName());
assertNull(inverseJoinColumn.getDefaultName());
assertNull(inverseJoinColumn.getDefaultReferencedColumnName());
//add target entity to the persistence unit, join column default name and referenced column still null because owning entity has no primary key
createTargetEntity();
getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME + ".Project");
assertNull(joinColumn.getDefaultName());
assertNull(joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
//create primary key in owning entity
ormPersistentType.getJavaPersistentType().getAttributeNamed("id").setMappingKey(MappingKeys.ID_ATTRIBUTE_MAPPING_KEY);
assertEquals(TYPE_NAME + "_id", joinColumn.getDefaultName());
assertEquals("id", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
//set specified column name on primary key in owning entity
((IdMapping) ormPersistentType.getJavaPersistentType().getAttributeNamed("id").getMapping()).getColumn().setSpecifiedName("MY_ID");
assertEquals(TYPE_NAME + "_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
assertNull(manyToMany.getJoinTable());
//target entity does not resolve, inverse join column name and referenced column name is null
manyToManyMapping.setSpecifiedTargetEntity("Foo");
assertEquals(TYPE_NAME + "_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertNull(inverseJoinColumn.getDefaultName());
assertNull(inverseJoinColumn.getDefaultReferencedColumnName());
//default target entity does resolve, so defaults for join column are back
manyToManyMapping.setSpecifiedTargetEntity(null);
assertEquals(TYPE_NAME + "_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
//add the join table xml element, verify default join column defaults are the same
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
assertEquals(TYPE_NAME + "_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
assertNotNull(manyToMany.getJoinTable());
}
public void testDefaultJoinColumnsBidirectionalRelationship() throws Exception {
createTestEntityWithValidManyToMany();
OrmPersistentType ormPersistentType = getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, FULLY_QUALIFIED_TYPE_NAME);
ormPersistentType.getAttributeNamed("projects").addToXml();
OrmManyToManyMapping manyToManyMapping = (OrmManyToManyMapping) ormPersistentType.getAttributeNamed("projects").getMapping();
JoinTable joinTable = manyToManyMapping.getRelationship().getJoinTableStrategy().getJoinTable();
JoinColumn joinColumn = joinTable.getJoinColumns().iterator().next();
JoinColumn inverseJoinColumn = joinTable.getInverseJoinColumns().iterator().next();
//joinTable default name is null because targetEntity is not in the persistence unit
assertNull(joinColumn.getDefaultName());
assertNull(joinColumn.getDefaultReferencedColumnName());
assertNull(inverseJoinColumn.getDefaultName());
assertNull(inverseJoinColumn.getDefaultReferencedColumnName());
//add target entity to the persistence unit, join column default name and referenced column still null because owning entity has no primary key
createTargetEntityWithBackPointer();
getEntityMappings().addPersistentType(MappingKeys.ENTITY_TYPE_MAPPING_KEY, PACKAGE_NAME + ".Project");
assertNull(joinColumn.getDefaultName());
assertNull(joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
//create primary key in owning entity
ormPersistentType.getJavaPersistentType().getAttributeNamed("id").setMappingKey(MappingKeys.ID_ATTRIBUTE_MAPPING_KEY);
assertEquals("employees_id", joinColumn.getDefaultName());
assertEquals("id", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
//set specified column name on primary key in owning entity
((IdMapping) ormPersistentType.getJavaPersistentType().getAttributeNamed("id").getMapping()).getColumn().setSpecifiedName("MY_ID");
assertEquals("employees_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
XmlManyToMany manyToMany = getXmlEntityMappings().getEntities().get(0).getAttributes().getManyToManys().get(0);
assertNull(manyToMany.getJoinTable());
//target entity does not resolve, inverse join column name and referenced column name is null
manyToManyMapping.setSpecifiedTargetEntity("Foo");
assertEquals(TYPE_NAME + "_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertNull(inverseJoinColumn.getDefaultName());
assertNull(inverseJoinColumn.getDefaultReferencedColumnName());
//default target entity does resolve, so defaults for join column are back
manyToManyMapping.setSpecifiedTargetEntity(null);
assertEquals("employees_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
//add the join table xml element, verify default join column defaults are the same
manyToMany.setJoinTable(OrmFactory.eINSTANCE.createXmlJoinTable());
assertEquals("employees_MY_ID", joinColumn.getDefaultName());
assertEquals("MY_ID", joinColumn.getDefaultReferencedColumnName());
assertEquals("projects_proj_id", inverseJoinColumn.getDefaultName());
assertEquals("proj_id", inverseJoinColumn.getDefaultReferencedColumnName());
assertNotNull(manyToMany.getJoinTable());
}
}