blob: 91a55072aba4a86a6739da056ae2daf50032881b [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.jpql;
//CR#3844 - class created on April 10, 2002
/* EJBQL finder does not work with an inheritance hierarchy.In a model with inheritance,
an EJBQL finder executed on a base class gives an error regarding invalid table
in context of a subclass table.
UsingEmployee demo, the following EJBQL is executed on the Project class:
"SELECT OBJECT(project) FROM Project project WHERE project.name = ?1");
with the value "Swirly Dirly", which is the name of the LargeProject
(a subclass of the Project class).
The following Exception is thrown:
EXCEPTION DESCRIPTION: The field [DatabaseField(LPROJECT.PROJ_ID)] in this
expression has an invalid table in this context. */
// Domain imports
import java.util.Vector;
import org.eclipse.persistence.testing.models.employee.domain.*;
//TopLink imports
import org.eclipse.persistence.queries.*;
import org.eclipse.persistence.expressions.*;
public class ComplexInheritanceTest extends org.eclipse.persistence.testing.tests.jpql.JPQLTestCase {
public ComplexInheritanceTest() {
super();
setDescription("Test that EJBQL finder works across inheritance hierarchy");
}
public void setup() {
//
// Set up query, using query framework, to return a Project object which will be compared
// against the Project object which is returned by the EJBQL query
String projectName = null;
getAbstractSession().addAlias("ProjectBaseClass", getSession().getDescriptor(Project.class));
Project project = null;
Vector projects = getSomeProjects();
for(int i = 0; i < projects.size(); i++) {
project = (Project)projects.elementAt(i);
if(project instanceof LargeProject) {
break;
}
}
projectName = project.getName();
ReadObjectQuery roq = new ReadObjectQuery();
ExpressionBuilder eb = new ExpressionBuilder();
Expression whereClause = eb.get("name").equal(projectName);
roq.setSelectionCriteria(whereClause);
roq.setReferenceClass(LargeProject.class);
LargeProject proj = (LargeProject)getSession().executeQuery(roq);
//Set Project object which will be compared against the one returned by EJBQL
if(proj == null) {
// null OriginalObject should be deemed equal to an empty Vector - but comparator
// returns returns false.
// Substitute null with an empty Vector to get the through this comparator limitation.
setOriginalOject(new Vector(0));
} else {
setOriginalOject(proj);
}
//Set criteria for EJBQL and call super-class method to construct the EJBQL query
String ejbql = "SELECT OBJECT(project) FROM ProjectBaseClass project WHERE project.name = \"" + projectName + "\"";
this.setEjbqlString(ejbql);
this.setReferenceClass(LargeProject.class);
}
public void reset() {
// Null out instance variables that were set in this test
getAbstractSession().getAliasDescriptors().remove("ProjectBaseClass");
super.reset();
getSession().getIdentityMapAccessor().initializeAllIdentityMaps();
}
}