diff options
Diffstat (limited to 'jpa/tests/org.eclipse.jpt.core.tests/src/org/eclipse/jpt/core/tests/internal/context/orm/XmlQueryHintTests.java')
-rw-r--r-- | jpa/tests/org.eclipse.jpt.core.tests/src/org/eclipse/jpt/core/tests/internal/context/orm/XmlQueryHintTests.java | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/jpa/tests/org.eclipse.jpt.core.tests/src/org/eclipse/jpt/core/tests/internal/context/orm/XmlQueryHintTests.java b/jpa/tests/org.eclipse.jpt.core.tests/src/org/eclipse/jpt/core/tests/internal/context/orm/XmlQueryHintTests.java new file mode 100644 index 0000000000..ea6a41e786 --- /dev/null +++ b/jpa/tests/org.eclipse.jpt.core.tests/src/org/eclipse/jpt/core/tests/internal/context/orm/XmlQueryHintTests.java @@ -0,0 +1,122 @@ +/******************************************************************************* + * Copyright (c) 2007 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.core.tests.internal.context.orm; + +import org.eclipse.jpt.core.internal.IMappingKeys; +import org.eclipse.jpt.core.internal.JptCorePlugin; +import org.eclipse.jpt.core.internal.context.orm.XmlEntity; +import org.eclipse.jpt.core.internal.context.orm.XmlPersistentType; +import org.eclipse.jpt.core.internal.context.orm.XmlQueryHint; +import org.eclipse.jpt.core.internal.resource.orm.QueryHint; +import org.eclipse.jpt.core.internal.resource.persistence.PersistenceFactory; +import org.eclipse.jpt.core.internal.resource.persistence.XmlMappingFileRef; +import org.eclipse.jpt.core.tests.internal.context.ContextModelTestCase; + +public class XmlQueryHintTests extends ContextModelTestCase +{ + public XmlQueryHintTests(String name) { + super(name); + } + + + @Override + protected void setUp() throws Exception { + super.setUp(); + XmlMappingFileRef mappingFileRef = PersistenceFactory.eINSTANCE.createXmlMappingFileRef(); + mappingFileRef.setFileName(JptCorePlugin.DEFAULT_ORM_XML_FILE_PATH); + xmlPersistenceUnit().getMappingFiles().add(mappingFileRef); + persistenceResource().save(null); + } + + public void testUpdateName() throws Exception { + XmlPersistentType xmlPersistentType = entityMappings().addXmlPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo"); + XmlEntity xmlEntity = (XmlEntity) xmlPersistentType.getMapping(); + XmlQueryHint xmlQueryHint = xmlEntity.addNamedQuery(0).addHint(0); + + QueryHint queryHintResource = ormResource().getEntityMappings().getEntities().get(0).getNamedQueries().get(0).getHints().get(0); + + assertNull(xmlQueryHint.getName()); + assertNull(queryHintResource.getName()); + + //set name in the resource model, verify context model updated + queryHintResource.setName("newName"); + assertEquals("newName", xmlQueryHint.getName()); + assertEquals("newName", queryHintResource.getName()); + + //set name to null in the resource model + queryHintResource.setName(null); + assertNull(xmlQueryHint.getName()); + assertNull(queryHintResource.getName()); + } + + public void testModifyName() throws Exception { + XmlPersistentType xmlPersistentType = entityMappings().addXmlPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo"); + XmlEntity xmlEntity = (XmlEntity) xmlPersistentType.getMapping(); + XmlQueryHint xmlQueryHint = xmlEntity.addNamedQuery(0).addHint(0); + + QueryHint queryHintResource = ormResource().getEntityMappings().getEntities().get(0).getNamedQueries().get(0).getHints().get(0); + + assertNull(xmlQueryHint.getName()); + assertNull(queryHintResource.getName()); + + //set name in the context model, verify resource model updated + xmlQueryHint.setName("newName"); + assertEquals("newName", xmlQueryHint.getName()); + assertEquals("newName", queryHintResource.getName()); + + //set name to null in the context model + xmlQueryHint.setName(null); + assertNull(xmlQueryHint.getName()); + assertNull(queryHintResource.getName()); + } + + public void testUpdateValue() throws Exception { + XmlPersistentType xmlPersistentType = entityMappings().addXmlPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo"); + XmlEntity xmlEntity = (XmlEntity) xmlPersistentType.getMapping(); + XmlQueryHint xmlQueryHint = xmlEntity.addNamedQuery(0).addHint(0); + + QueryHint queryHintResource = ormResource().getEntityMappings().getEntities().get(0).getNamedQueries().get(0).getHints().get(0); + + assertNull(xmlQueryHint.getValue()); + assertNull(queryHintResource.getValue()); + + //set name in the resource model, verify context model updated + queryHintResource.setValue("newName"); + assertEquals("newName", xmlQueryHint.getValue()); + assertEquals("newName", queryHintResource.getValue()); + + //set name to null in the resource model + queryHintResource.setValue(null); + assertNull(xmlQueryHint.getValue()); + assertNull(queryHintResource.getValue()); + } + + public void testModifyValue() throws Exception { + XmlPersistentType xmlPersistentType = entityMappings().addXmlPersistentType(IMappingKeys.ENTITY_TYPE_MAPPING_KEY, "model.Foo"); + XmlEntity xmlEntity = (XmlEntity) xmlPersistentType.getMapping(); + XmlQueryHint xmlQueryHint = xmlEntity.addNamedQuery(0).addHint(0); + + QueryHint queryHintResource = ormResource().getEntityMappings().getEntities().get(0).getNamedQueries().get(0).getHints().get(0); + + assertNull(xmlQueryHint.getValue()); + assertNull(queryHintResource.getValue()); + + //set name in the context model, verify resource model updated + xmlQueryHint.setValue("newName"); + assertEquals("newName", xmlQueryHint.getValue()); + assertEquals("newName", queryHintResource.getValue()); + + //set name to null in the context model + xmlQueryHint.setValue(null); + assertNull(xmlQueryHint.getValue()); + assertNull(queryHintResource.getValue()); + } +}
\ No newline at end of file |