[OLINGO-202] Required changes provided
This commit is contained in:
parent
05b26700ad
commit
081df2aa70
|
@ -30,6 +30,8 @@ public class EdmActionImportImpl extends EdmOperationImportImpl implements EdmAc
|
||||||
|
|
||||||
private final ActionImport actionImport;
|
private final ActionImport actionImport;
|
||||||
|
|
||||||
|
private FullQualifiedName actionFQN;
|
||||||
|
|
||||||
public EdmActionImportImpl(final Edm edm, final EdmEntityContainer container, final String name,
|
public EdmActionImportImpl(final Edm edm, final EdmEntityContainer container, final String name,
|
||||||
final ActionImport actionImport) {
|
final ActionImport actionImport) {
|
||||||
|
|
||||||
|
@ -37,18 +39,17 @@ public class EdmActionImportImpl extends EdmOperationImportImpl implements EdmAc
|
||||||
this.actionImport = actionImport;
|
this.actionImport = actionImport;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public FullQualifiedName getActionFQN() {
|
||||||
public EdmAction getUnboundAction() {
|
if (actionFQN == null) {
|
||||||
return getBoundAction(null, null);
|
actionFQN = new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(actionImport.getAction()).
|
||||||
|
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName();
|
||||||
|
}
|
||||||
|
return actionFQN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmAction getBoundAction(
|
public EdmAction getUnboundAction() {
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
return edm.getUnboundAction(getActionFQN());
|
||||||
|
|
||||||
return edm.getAction(new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(actionImport.getAction()).
|
|
||||||
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName(),
|
|
||||||
bindingParameterTypeName, isBindingParameterCollection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -210,6 +210,37 @@ public class EdmClientImpl extends AbstractEdm {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<EdmFunction> createUnboundFunctions(final FullQualifiedName functionName) {
|
||||||
|
final List<EdmFunction> result = new ArrayList<EdmFunction>();
|
||||||
|
|
||||||
|
final Schema schema = xmlSchemaByNamespace.get(functionName.getNamespace());
|
||||||
|
if (schema instanceof org.apache.olingo.client.api.edm.xml.v4.Schema) {
|
||||||
|
final List<Function> functions = ((org.apache.olingo.client.api.edm.xml.v4.Schema) schema).
|
||||||
|
getFunctions(functionName.getName());
|
||||||
|
for (final Iterator<Function> itor = functions.iterator(); itor.hasNext();) {
|
||||||
|
final Function function = itor.next();
|
||||||
|
if (!function.isBound()) {
|
||||||
|
result.add(EdmFunctionImpl.getInstance(this, functionName, function));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (EntityContainer entityContainer : schema.getEntityContainers()) {
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
final List<FunctionImport> functionImports =
|
||||||
|
(List<FunctionImport>) entityContainer.getFunctionImports(functionName.getName());
|
||||||
|
for (final Iterator<FunctionImport> itor = functionImports.iterator(); itor.hasNext();) {
|
||||||
|
final FunctionImport functionImport = itor.next();
|
||||||
|
if (FunctionImportUtils.canProxyFunction(functionImport) && !functionImport.isBindable()) {
|
||||||
|
result.add(EdmFunctionProxy.getInstance(this, functionName, functionImport));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected EdmFunction createUnboundFunction(final FullQualifiedName functionName, final List<String> parameterNames) {
|
protected EdmFunction createUnboundFunction(final FullQualifiedName functionName, final List<String> parameterNames) {
|
||||||
EdmFunction result = null;
|
EdmFunction result = null;
|
||||||
|
@ -235,8 +266,8 @@ public class EdmClientImpl extends AbstractEdm {
|
||||||
} else {
|
} else {
|
||||||
for (EntityContainer entityContainer : schema.getEntityContainers()) {
|
for (EntityContainer entityContainer : schema.getEntityContainers()) {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
final List<FunctionImport> functionImports = (List<FunctionImport>) entityContainer.
|
final List<FunctionImport> functionImports =
|
||||||
getFunctionImports(functionName.getName());
|
(List<FunctionImport>) entityContainer.getFunctionImports(functionName.getName());
|
||||||
boolean found = false;
|
boolean found = false;
|
||||||
for (final Iterator<FunctionImport> itor = functionImports.iterator(); itor.hasNext() && !found;) {
|
for (final Iterator<FunctionImport> itor = functionImports.iterator(); itor.hasNext() && !found;) {
|
||||||
final FunctionImport functionImport = itor.next();
|
final FunctionImport functionImport = itor.next();
|
||||||
|
|
|
@ -32,6 +32,8 @@ public class EdmFunctionImportImpl extends EdmOperationImportImpl implements Edm
|
||||||
|
|
||||||
private final FunctionImport functionImport;
|
private final FunctionImport functionImport;
|
||||||
|
|
||||||
|
private FullQualifiedName functionFQN;
|
||||||
|
|
||||||
public EdmFunctionImportImpl(final Edm edm, final EdmEntityContainer container, final String name,
|
public EdmFunctionImportImpl(final Edm edm, final EdmEntityContainer container, final String name,
|
||||||
final FunctionImport functionImport) {
|
final FunctionImport functionImport) {
|
||||||
|
|
||||||
|
@ -40,17 +42,22 @@ public class EdmFunctionImportImpl extends EdmOperationImportImpl implements Edm
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getUnboundFunction(final List<String> parameterNames) {
|
public FullQualifiedName getFunctionFqn() {
|
||||||
return getBoundFunction(parameterNames, null, null);
|
if (functionFQN == null) {
|
||||||
|
functionFQN = new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(functionImport.getFunction()).
|
||||||
|
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName();
|
||||||
|
}
|
||||||
|
return functionFQN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getBoundFunction(final List<String> parameterNames,
|
public List<EdmFunction> getUnboundFunctions() {
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
return edm.getUnboundFunctions(getFunctionFqn());
|
||||||
|
}
|
||||||
|
|
||||||
return edm.getFunction(new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(functionImport.getFunction()).
|
@Override
|
||||||
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName(),
|
public EdmFunction getUnboundFunction(final List<String> parameterNames) {
|
||||||
bindingParameterTypeName, isBindingParameterCollection, parameterNames);
|
return edm.getUnboundFunction(getFunctionFqn(), parameterNames);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -58,8 +65,4 @@ public class EdmFunctionImportImpl extends EdmOperationImportImpl implements Edm
|
||||||
return functionImport.isIncludeInServiceDocument();
|
return functionImport.isIncludeInServiceDocument();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public FullQualifiedName getFunctionFqn() {
|
|
||||||
return new FullQualifiedName(functionImport.getFunction());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,8 @@ public class EdmActionImportProxy extends EdmOperationImportImpl implements EdmA
|
||||||
|
|
||||||
private final FunctionImport functionImport;
|
private final FunctionImport functionImport;
|
||||||
|
|
||||||
|
private FullQualifiedName actionFQN;
|
||||||
|
|
||||||
public EdmActionImportProxy(final Edm edm, final EdmEntityContainer container, final String name,
|
public EdmActionImportProxy(final Edm edm, final EdmEntityContainer container, final String name,
|
||||||
final FunctionImport functionImport) {
|
final FunctionImport functionImport) {
|
||||||
|
|
||||||
|
@ -38,19 +40,17 @@ public class EdmActionImportProxy extends EdmOperationImportImpl implements EdmA
|
||||||
this.functionImport = functionImport;
|
this.functionImport = functionImport;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public FullQualifiedName getActionFQN() {
|
||||||
public EdmAction getUnboundAction() {
|
if (actionFQN == null) {
|
||||||
return edm.getAction(new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(functionImport.getName()).
|
actionFQN = new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(functionImport.getName()).
|
||||||
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName(), null, null);
|
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName();
|
||||||
|
}
|
||||||
|
return actionFQN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmAction getBoundAction(
|
public EdmAction getUnboundAction() {
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
return edm.getUnboundAction(getActionFQN());
|
||||||
|
|
||||||
return edm.getAction(new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(functionImport.getName()).
|
|
||||||
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName(),
|
|
||||||
bindingParameterTypeName, isBindingParameterCollection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,6 @@ import java.util.List;
|
||||||
|
|
||||||
import org.apache.olingo.client.api.edm.xml.v3.FunctionImport;
|
import org.apache.olingo.client.api.edm.xml.v3.FunctionImport;
|
||||||
import org.apache.olingo.client.core.edm.EdmOperationImportImpl;
|
import org.apache.olingo.client.core.edm.EdmOperationImportImpl;
|
||||||
import org.apache.olingo.commons.core.edm.EdmTypeInfo;
|
|
||||||
import org.apache.olingo.commons.api.edm.Edm;
|
import org.apache.olingo.commons.api.edm.Edm;
|
||||||
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
||||||
import org.apache.olingo.commons.api.edm.EdmFunction;
|
import org.apache.olingo.commons.api.edm.EdmFunction;
|
||||||
|
@ -33,6 +32,8 @@ public class EdmFunctionImportProxy extends EdmOperationImportImpl implements Ed
|
||||||
|
|
||||||
private final FunctionImport functionImport;
|
private final FunctionImport functionImport;
|
||||||
|
|
||||||
|
private FullQualifiedName functionFQN;
|
||||||
|
|
||||||
public EdmFunctionImportProxy(final Edm edm, final EdmEntityContainer container, final String name,
|
public EdmFunctionImportProxy(final Edm edm, final EdmEntityContainer container, final String name,
|
||||||
final FunctionImport functionImport) {
|
final FunctionImport functionImport) {
|
||||||
|
|
||||||
|
@ -41,27 +42,27 @@ public class EdmFunctionImportProxy extends EdmOperationImportImpl implements Ed
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getUnboundFunction(final List<String> parameterNames) {
|
public FullQualifiedName getFunctionFqn() {
|
||||||
return getBoundFunction(parameterNames, null, null);
|
if (functionFQN == null) {
|
||||||
|
functionFQN = new FullQualifiedName(container.getNamespace(), getName());
|
||||||
|
}
|
||||||
|
return functionFQN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getBoundFunction(final List<String> parameterNames,
|
public List<EdmFunction> getUnboundFunctions() {
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
return edm.getUnboundFunctions(getFunctionFqn());
|
||||||
|
}
|
||||||
|
|
||||||
return edm.getFunction(new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(functionImport.getName()).
|
@Override
|
||||||
setDefaultNamespace(container.getNamespace()).build().getFullQualifiedName(),
|
public EdmFunction getUnboundFunction(final List<String> parameterNames) {
|
||||||
bindingParameterTypeName, isBindingParameterCollection, parameterNames);
|
return edm.getUnboundFunction(getFunctionFqn(), parameterNames);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isIncludeInServiceDocument() {
|
public boolean isIncludeInServiceDocument() {
|
||||||
//V3 states that all function imports are included in the service document
|
// V3 states that all function imports are included in the service document
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public FullQualifiedName getFunctionFqn() {
|
|
||||||
return new FullQualifiedName(container.getNamespace(), getName());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,13 +48,13 @@ import org.apache.olingo.commons.api.domain.v3.ODataEntitySet;
|
||||||
import org.apache.olingo.commons.api.domain.v3.ODataProperty;
|
import org.apache.olingo.commons.api.domain.v3.ODataProperty;
|
||||||
import org.apache.olingo.commons.api.edm.Edm;
|
import org.apache.olingo.commons.api.edm.Edm;
|
||||||
import org.apache.olingo.commons.api.edm.EdmAction;
|
import org.apache.olingo.commons.api.edm.EdmAction;
|
||||||
import org.apache.olingo.commons.api.edm.EdmActionImport;
|
|
||||||
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
||||||
import org.apache.olingo.commons.api.edm.EdmFunction;
|
import org.apache.olingo.commons.api.edm.EdmFunction;
|
||||||
import org.apache.olingo.commons.api.edm.EdmFunctionImport;
|
import org.apache.olingo.commons.api.edm.EdmFunctionImport;
|
||||||
import org.apache.olingo.commons.api.edm.EdmParameter;
|
import org.apache.olingo.commons.api.edm.EdmParameter;
|
||||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
|
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
|
||||||
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
|
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
|
||||||
|
import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
||||||
import org.apache.olingo.commons.api.format.ODataPubFormat;
|
import org.apache.olingo.commons.api.format.ODataPubFormat;
|
||||||
import org.apache.olingo.commons.core.edm.EdmTypeInfo;
|
import org.apache.olingo.commons.core.edm.EdmTypeInfo;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -244,10 +244,10 @@ public class InvokeTestITCase extends AbstractTestITCase {
|
||||||
assertNotNull(edm);
|
assertNotNull(edm);
|
||||||
|
|
||||||
final EdmEntityContainer container = edm.getSchemas().get(0).getEntityContainer();
|
final EdmEntityContainer container = edm.getSchemas().get(0).getEntityContainer();
|
||||||
final EdmActionImport actImp = container.getActionImport(operation.getTitle());
|
|
||||||
final EdmTypeInfo createdTypeInfo =
|
final EdmTypeInfo createdTypeInfo =
|
||||||
new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(created.getName()).build();
|
new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(created.getName()).build();
|
||||||
final EdmAction action = actImp.getBoundAction(
|
final EdmAction action = edm.getBoundAction(
|
||||||
|
new FullQualifiedName(container.getNamespace(), operation.getTitle()),
|
||||||
createdTypeInfo.getFullQualifiedName(), createdTypeInfo.isCollection());
|
createdTypeInfo.getFullQualifiedName(), createdTypeInfo.isCollection());
|
||||||
|
|
||||||
final ODataInvokeRequest<ODataNoContent> req = getClient().getInvokeRequestFactory().
|
final ODataInvokeRequest<ODataNoContent> req = getClient().getInvokeRequestFactory().
|
||||||
|
@ -294,11 +294,11 @@ public class InvokeTestITCase extends AbstractTestITCase {
|
||||||
assertNotNull(edm);
|
assertNotNull(edm);
|
||||||
|
|
||||||
final EdmEntityContainer container = edm.getSchemas().get(0).getEntityContainer();
|
final EdmEntityContainer container = edm.getSchemas().get(0).getEntityContainer();
|
||||||
final EdmActionImport actImp = container.getActionImport("IncreaseSalaries");
|
|
||||||
|
|
||||||
final EdmTypeInfo employeesTypeInfo = new EdmTypeInfo.Builder().setEdm(edm).
|
final EdmTypeInfo employeesTypeInfo = new EdmTypeInfo.Builder().setEdm(edm).
|
||||||
setTypeExpression("Collection(Microsoft.Test.OData.Services.AstoriaDefaultService.Employee)").build();
|
setTypeExpression("Collection(Microsoft.Test.OData.Services.AstoriaDefaultService.Employee)").build();
|
||||||
final EdmAction action = actImp.getBoundAction(
|
final EdmAction action = edm.getBoundAction(
|
||||||
|
new FullQualifiedName(container.getNamespace(), "IncreaseSalaries"),
|
||||||
employeesTypeInfo.getFullQualifiedName(), employeesTypeInfo.isCollection());
|
employeesTypeInfo.getFullQualifiedName(), employeesTypeInfo.isCollection());
|
||||||
|
|
||||||
final EdmParameter param = action.getParameter(action.getParameterNames().get(1));
|
final EdmParameter param = action.getParameter(action.getParameterNames().get(1));
|
||||||
|
@ -308,7 +308,7 @@ public class InvokeTestITCase extends AbstractTestITCase {
|
||||||
build();
|
build();
|
||||||
|
|
||||||
final ODataInvokeRequest<ODataNoContent> req = getClient().getInvokeRequestFactory().getInvokeRequest(
|
final ODataInvokeRequest<ODataNoContent> req = getClient().getInvokeRequestFactory().getInvokeRequest(
|
||||||
builder.appendOperationCallSegment(actImp.getName()).build(), action,
|
builder.appendOperationCallSegment(action.getName()).build(), action,
|
||||||
Collections.<String, ODataValue>singletonMap(param.getName(), paramValue));
|
Collections.<String, ODataValue>singletonMap(param.getName(), paramValue));
|
||||||
final ODataInvokeResponse<ODataNoContent> res = req.execute();
|
final ODataInvokeResponse<ODataNoContent> res = req.execute();
|
||||||
assertNotNull(res);
|
assertNotNull(res);
|
||||||
|
|
|
@ -189,16 +189,16 @@ public class MetadataTest extends AbstractTest {
|
||||||
final EdmEntityType computer = metadata.getEntityType(new FullQualifiedName(container.getNamespace(), "Computer"));
|
final EdmEntityType computer = metadata.getEntityType(new FullQualifiedName(container.getNamespace(), "Computer"));
|
||||||
assertNotNull(computer);
|
assertNotNull(computer);
|
||||||
|
|
||||||
final EdmFunction getComputer = metadata.getFunction(
|
final EdmFunction getComputer = metadata.getBoundFunction(
|
||||||
new FullQualifiedName(container.getNamespace(), "GetComputer"),
|
new FullQualifiedName(container.getNamespace(), "GetComputer"),
|
||||||
new FullQualifiedName(container.getNamespace(), computer.getName()),
|
new FullQualifiedName(container.getNamespace(), computer.getName()),
|
||||||
Boolean.FALSE, Arrays.asList(new String[] {"computer"}));
|
Boolean.FALSE, Arrays.asList("computer"));
|
||||||
assertNotNull(getComputer);
|
assertNotNull(getComputer);
|
||||||
assertEquals(computer, getComputer.getParameter("computer").getType());
|
assertEquals(computer, getComputer.getParameter("computer").getType());
|
||||||
assertEquals(computer, getComputer.getReturnType().getType());
|
assertEquals(computer, getComputer.getReturnType().getType());
|
||||||
|
|
||||||
final EdmAction resetDataSource2 = metadata.getAction(
|
final EdmAction resetDataSource2 = metadata.getUnboundAction(
|
||||||
new FullQualifiedName(container.getNamespace(), "ResetDataSource"), null, Boolean.FALSE);
|
new FullQualifiedName(container.getNamespace(), "ResetDataSource"));
|
||||||
assertNotNull(resetDataSource2);
|
assertNotNull(resetDataSource2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -100,7 +100,7 @@ public class MetadataTest extends AbstractTest {
|
||||||
assertEquals(folder, user.getNavigationProperty("Inbox").getType());
|
assertEquals(folder, user.getNavigationProperty("Inbox").getType());
|
||||||
|
|
||||||
// 4. Action
|
// 4. Action
|
||||||
final EdmAction move = edm.getAction(
|
final EdmAction move = edm.getBoundAction(
|
||||||
new FullQualifiedName("Microsoft.Exchange.Services.OData.Model", "Move"),
|
new FullQualifiedName("Microsoft.Exchange.Services.OData.Model", "Move"),
|
||||||
new FullQualifiedName("Microsoft.Exchange.Services.OData.Model", "Folder"),
|
new FullQualifiedName("Microsoft.Exchange.Services.OData.Model", "Folder"),
|
||||||
false);
|
false);
|
||||||
|
@ -209,9 +209,8 @@ public class MetadataTest extends AbstractTest {
|
||||||
assertNotNull(fi);
|
assertNotNull(fi);
|
||||||
assertEquals(demoService.getEntitySet("Products"), fi.getReturnedEntitySet());
|
assertEquals(demoService.getEntitySet("Products"), fi.getReturnedEntitySet());
|
||||||
|
|
||||||
final EdmFunction function = edm.getFunction(
|
final EdmFunction function = edm.getUnboundFunction(
|
||||||
new FullQualifiedName(metadata.getSchema(0).getNamespace(), "ProductsByRating"),
|
new FullQualifiedName(metadata.getSchema(0).getNamespace(), "ProductsByRating"), null);
|
||||||
null, Boolean.FALSE, null);
|
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
assertEquals(function.getName(), fi.getUnboundFunction(null).getName());
|
assertEquals(function.getName(), fi.getUnboundFunction(null).getName());
|
||||||
assertEquals(function.getNamespace(), fi.getUnboundFunction(null).getNamespace());
|
assertEquals(function.getNamespace(), fi.getUnboundFunction(null).getNamespace());
|
||||||
|
|
|
@ -27,92 +27,117 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public interface Edm {
|
public interface Edm {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method <b>DOES NOT</b> support lazy loading. All schemas are loaded completely!
|
* This method <b>DOES NOT</b> support lazy loading. All schemas are loaded completely!
|
||||||
*
|
*
|
||||||
* @return all schemas defined for this EDM
|
* @return all schemas defined for this EDM
|
||||||
*/
|
*/
|
||||||
List<EdmSchema> getSchemas();
|
List<EdmSchema> getSchemas();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get entity container by full qualified name.
|
* Get entity container by full qualified name.
|
||||||
* <br/>
|
* <br/>
|
||||||
* See {@link EdmEntityContainer} for more information.
|
* See {@link EdmEntityContainer} for more information.
|
||||||
*
|
*
|
||||||
* @param name
|
* @param name
|
||||||
* @return {@link EdmEntityContainer}
|
* @return {@link EdmEntityContainer}
|
||||||
*/
|
*/
|
||||||
EdmEntityContainer getEntityContainer(FullQualifiedName name);
|
EdmEntityContainer getEntityContainer(FullQualifiedName name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get enum type by full qualified name.
|
* Get enum type by full qualified name.
|
||||||
* <br/>
|
* <br/>
|
||||||
* See {@link EdmEnumType} for more information
|
* See {@link EdmEnumType} for more information
|
||||||
*
|
*
|
||||||
* @param name
|
* @param name
|
||||||
* @return {@link EdmEnumType}
|
* @return {@link EdmEnumType}
|
||||||
*/
|
*/
|
||||||
EdmEnumType getEnumType(FullQualifiedName name);
|
EdmEnumType getEnumType(FullQualifiedName name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a type definition by full qualified name.
|
* Get a type definition by full qualified name.
|
||||||
* <br/>
|
* <br/>
|
||||||
* See {@link EdmTypeDefinition} for more information
|
* See {@link EdmTypeDefinition} for more information
|
||||||
*
|
*
|
||||||
* @param name
|
* @param name
|
||||||
* @return {@link EdmTypeDefinition}
|
* @return {@link EdmTypeDefinition}
|
||||||
*/
|
*/
|
||||||
EdmTypeDefinition getTypeDefinition(FullQualifiedName name);
|
EdmTypeDefinition getTypeDefinition(FullQualifiedName name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get entity type by full qualified name.
|
* Get entity type by full qualified name.
|
||||||
* <br/>
|
* <br/>
|
||||||
* See {@link EdmEntityType} for more information.
|
* See {@link EdmEntityType} for more information.
|
||||||
*
|
*
|
||||||
* @param name
|
* @param name
|
||||||
* @return {@link EdmEntityType}
|
* @return {@link EdmEntityType}
|
||||||
*/
|
*/
|
||||||
EdmEntityType getEntityType(FullQualifiedName name);
|
EdmEntityType getEntityType(FullQualifiedName name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get complex type by full qualified name..
|
* Get complex type by full qualified name..
|
||||||
* <br/>
|
* <br/>
|
||||||
* See {@link EdmComplexType} for more information.
|
* See {@link EdmComplexType} for more information.
|
||||||
*
|
*
|
||||||
* @param name
|
* @param name
|
||||||
* @return {@link EdmComplexType}
|
* @return {@link EdmComplexType}
|
||||||
*/
|
*/
|
||||||
EdmComplexType getComplexType(FullQualifiedName name);
|
EdmComplexType getComplexType(FullQualifiedName name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get Action by full qualified name and binding parameter type.
|
* Get unbound Action by full qualified name.
|
||||||
*
|
*
|
||||||
* @param actionName must not be null
|
* @param actionName must not be null
|
||||||
* @param bindingParameterTypeName may be null if it is an unbound action
|
* @return {@link EdmAction}
|
||||||
* @param isBindingParameterCollection may be null if it is an unbound action
|
*/
|
||||||
* @return {@link EdmAction}
|
EdmAction getUnboundAction(FullQualifiedName actionName);
|
||||||
*/
|
|
||||||
EdmAction getAction(FullQualifiedName actionName, FullQualifiedName bindingParameterTypeName,
|
|
||||||
Boolean isBindingParameterCollection);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get Function by full qualified name and binding parameter type and binding parameter names.
|
* Get Action by full qualified name and binding parameter type.
|
||||||
*
|
*
|
||||||
* @param functionName
|
* @param actionName must not be null
|
||||||
* @param bindingParameterTypeName may be null if it is an unbound function
|
* @param bindingParameterTypeName must not be null
|
||||||
* @param isBindingParameterCollection may be null if it is an unbound function
|
* @param isBindingParameterCollection may be null
|
||||||
* @param parameterNames may be null if it is an unbound function
|
* @return {@link EdmAction}
|
||||||
* @return {@link EdmFunction}
|
*/
|
||||||
*/
|
EdmAction getBoundAction(FullQualifiedName actionName, FullQualifiedName bindingParameterTypeName,
|
||||||
EdmFunction getFunction(FullQualifiedName functionName, FullQualifiedName bindingParameterTypeName,
|
Boolean isBindingParameterCollection);
|
||||||
Boolean isBindingParameterCollection, List<String> parameterNames);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get service metadata.
|
* Get Function by full qualified name.
|
||||||
* <br/>
|
*
|
||||||
* See {@link EdmServiceMetadata} for more information.
|
* @param functionName must not be null
|
||||||
*
|
* @return {@link EdmFunction}
|
||||||
* @return {@link EdmServiceMetadata}
|
*/
|
||||||
*/
|
List<EdmFunction> getUnboundFunctions(FullQualifiedName functionName);
|
||||||
EdmServiceMetadata getServiceMetadata();
|
|
||||||
|
/**
|
||||||
|
* Get Function by full qualified name.
|
||||||
|
*
|
||||||
|
* @param functionName must not be null
|
||||||
|
* @param parameterNames may be null: in this case it is considered as empty
|
||||||
|
* @return {@link EdmFunction}
|
||||||
|
*/
|
||||||
|
EdmFunction getUnboundFunction(FullQualifiedName functionName, List<String> parameterNames);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get Function by full qualified name and binding parameter type and binding parameter names.
|
||||||
|
*
|
||||||
|
* @param functionName must not be null
|
||||||
|
* @param bindingParameterTypeName must not be null
|
||||||
|
* @param isBindingParameterCollection may be null
|
||||||
|
* @param parameterNames may be null: in this case it is considered as empty
|
||||||
|
* @return {@link EdmFunction}
|
||||||
|
*/
|
||||||
|
EdmFunction getBoundFunction(FullQualifiedName functionName, FullQualifiedName bindingParameterTypeName,
|
||||||
|
Boolean isBindingParameterCollection, List<String> parameterNames);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get service metadata.
|
||||||
|
* <br/>
|
||||||
|
* See {@link EdmServiceMetadata} for more information.
|
||||||
|
*
|
||||||
|
* @return {@link EdmServiceMetadata}
|
||||||
|
*/
|
||||||
|
EdmServiceMetadata getServiceMetadata();
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,13 +29,4 @@ public interface EdmActionImport extends EdmOperationImport {
|
||||||
* @return unbound action.
|
* @return unbound action.
|
||||||
*/
|
*/
|
||||||
EdmAction getUnboundAction();
|
EdmAction getUnboundAction();
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets bound action.
|
|
||||||
*
|
|
||||||
* @param bindingParameterTypeName may be null if it is an unbound function
|
|
||||||
* @param isBindingParameterCollection may be null if it is an unbound function
|
|
||||||
* @return bound action with given parameter names
|
|
||||||
*/
|
|
||||||
EdmAction getBoundAction(FullQualifiedName bindingParameterTypeName, Boolean isBindingParameterCollection);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,13 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public interface EdmFunctionImport extends EdmOperationImport {
|
public interface EdmFunctionImport extends EdmOperationImport {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets unbound functions.
|
||||||
|
*
|
||||||
|
* @return unbound functions
|
||||||
|
*/
|
||||||
|
List<EdmFunction> getUnboundFunctions();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets unbound function with given parameter names.
|
* Gets unbound function with given parameter names.
|
||||||
*
|
*
|
||||||
|
@ -33,17 +40,6 @@ public interface EdmFunctionImport extends EdmOperationImport {
|
||||||
*/
|
*/
|
||||||
EdmFunction getUnboundFunction(List<String> parameterNames);
|
EdmFunction getUnboundFunction(List<String> parameterNames);
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets bound function with given parameter names.
|
|
||||||
*
|
|
||||||
* @param parameterNames parameter names
|
|
||||||
* @param bindingParameterTypeName may be null if it is an unbound function
|
|
||||||
* @param isBindingParameterCollection may be null if it is an unbound function
|
|
||||||
* @return bound function with given parameter names
|
|
||||||
*/
|
|
||||||
EdmFunction getBoundFunction(List<String> parameterNames,
|
|
||||||
FullQualifiedName bindingParameterTypeName, Boolean isBindingParameterCollection);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the Full qualified name for the function as specified in the metadata
|
* @return the Full qualified name for the function as specified in the metadata
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.olingo.commons.core.edm;
|
package org.apache.olingo.commons.core.edm;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -37,12 +38,12 @@ import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
||||||
public abstract class AbstractEdm implements Edm {
|
public abstract class AbstractEdm implements Edm {
|
||||||
|
|
||||||
private final Map<FullQualifiedName, EdmEntityContainer> entityContainers =
|
private final Map<FullQualifiedName, EdmEntityContainer> entityContainers =
|
||||||
new HashMap<FullQualifiedName, EdmEntityContainer>();
|
new HashMap<FullQualifiedName, EdmEntityContainer>();
|
||||||
|
|
||||||
private final Map<FullQualifiedName, EdmEnumType> enumTypes = new HashMap<FullQualifiedName, EdmEnumType>();
|
private final Map<FullQualifiedName, EdmEnumType> enumTypes = new HashMap<FullQualifiedName, EdmEnumType>();
|
||||||
|
|
||||||
private final Map<FullQualifiedName, EdmTypeDefinition> typeDefinitions =
|
private final Map<FullQualifiedName, EdmTypeDefinition> typeDefinitions =
|
||||||
new HashMap<FullQualifiedName, EdmTypeDefinition>();
|
new HashMap<FullQualifiedName, EdmTypeDefinition>();
|
||||||
|
|
||||||
private final Map<FullQualifiedName, EdmEntityType> entityTypes = new HashMap<FullQualifiedName, EdmEntityType>();
|
private final Map<FullQualifiedName, EdmEntityType> entityTypes = new HashMap<FullQualifiedName, EdmEntityType>();
|
||||||
|
|
||||||
|
@ -50,7 +51,10 @@ public abstract class AbstractEdm implements Edm {
|
||||||
|
|
||||||
private final Map<FullQualifiedName, EdmAction> unboundActions = new HashMap<FullQualifiedName, EdmAction>();
|
private final Map<FullQualifiedName, EdmAction> unboundActions = new HashMap<FullQualifiedName, EdmAction>();
|
||||||
|
|
||||||
private final Map<FunctionMapKey, EdmFunction> unboundFunctions = new HashMap<FunctionMapKey, EdmFunction>();
|
private final Map<FullQualifiedName, List<EdmFunction>> unboundFunctionsByName =
|
||||||
|
new HashMap<FullQualifiedName, List<EdmFunction>>();
|
||||||
|
|
||||||
|
private final Map<FunctionMapKey, EdmFunction> unboundFunctionsByKey = new HashMap<FunctionMapKey, EdmFunction>();
|
||||||
|
|
||||||
private final Map<ActionMapKey, EdmAction> boundActions = new HashMap<ActionMapKey, EdmAction>();
|
private final Map<ActionMapKey, EdmAction> boundActions = new HashMap<ActionMapKey, EdmAction>();
|
||||||
|
|
||||||
|
@ -69,26 +73,26 @@ public abstract class AbstractEdm implements Edm {
|
||||||
if (schemas != null) {
|
if (schemas != null) {
|
||||||
aliasToNamespaceInfo = new HashMap<String, String>();
|
aliasToNamespaceInfo = new HashMap<String, String>();
|
||||||
for (EdmSchema schema : schemas) {
|
for (EdmSchema schema : schemas) {
|
||||||
String namespace = schema.getNamespace();
|
final String namespace = schema.getNamespace();
|
||||||
if (schema.getAlias() != null) {
|
if (schema.getAlias() != null) {
|
||||||
aliasToNamespaceInfo.put(schema.getAlias(), namespace);
|
aliasToNamespaceInfo.put(schema.getAlias(), namespace);
|
||||||
}
|
}
|
||||||
|
|
||||||
List<EdmEnumType> localEnumTypes = schema.getEnumTypes();
|
final List<EdmEnumType> localEnumTypes = schema.getEnumTypes();
|
||||||
if (localEnumTypes != null) {
|
if (localEnumTypes != null) {
|
||||||
for (EdmEnumType enumType : localEnumTypes) {
|
for (EdmEnumType enumType : localEnumTypes) {
|
||||||
enumTypes.put(new FullQualifiedName(namespace, enumType.getName()), enumType);
|
enumTypes.put(new FullQualifiedName(namespace, enumType.getName()), enumType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<EdmTypeDefinition> localTypeDefinitions = schema.getTypeDefinitions();
|
final List<EdmTypeDefinition> localTypeDefinitions = schema.getTypeDefinitions();
|
||||||
if (localTypeDefinitions != null) {
|
if (localTypeDefinitions != null) {
|
||||||
for (EdmTypeDefinition typeDef : localTypeDefinitions) {
|
for (EdmTypeDefinition typeDef : localTypeDefinitions) {
|
||||||
typeDefinitions.put(new FullQualifiedName(namespace, typeDef.getName()), typeDef);
|
typeDefinitions.put(new FullQualifiedName(namespace, typeDef.getName()), typeDef);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<EdmComplexType> localComplexTypes = schema.getComplexTypes();
|
final List<EdmComplexType> localComplexTypes = schema.getComplexTypes();
|
||||||
if (localComplexTypes != null) {
|
if (localComplexTypes != null) {
|
||||||
for (EdmComplexType complexType : localComplexTypes) {
|
for (EdmComplexType complexType : localComplexTypes) {
|
||||||
complexTypes.put(new FullQualifiedName(namespace, complexType.getName()), complexType);
|
complexTypes.put(new FullQualifiedName(namespace, complexType.getName()), complexType);
|
||||||
|
@ -102,39 +106,45 @@ public abstract class AbstractEdm implements Edm {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<EdmAction> localActions = schema.getActions();
|
final List<EdmAction> localActions = schema.getActions();
|
||||||
if (localActions != null) {
|
if (localActions != null) {
|
||||||
for (EdmAction action : localActions) {
|
for (EdmAction action : localActions) {
|
||||||
|
final FullQualifiedName name = new FullQualifiedName(namespace, action.getName());
|
||||||
if (action.isBound()) {
|
if (action.isBound()) {
|
||||||
ActionMapKey key = new ActionMapKey(new FullQualifiedName(namespace, action.getName()),
|
final ActionMapKey key = new ActionMapKey(name,
|
||||||
action.getBindingParameterTypeFqn(), action.isBindingParameterTypeCollection());
|
action.getBindingParameterTypeFqn(), action.isBindingParameterTypeCollection());
|
||||||
boundActions.put(key, action);
|
boundActions.put(key, action);
|
||||||
} else {
|
} else {
|
||||||
unboundActions.put(new FullQualifiedName(namespace, action.getName()), action);
|
unboundActions.put(name, action);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<EdmFunction> localFunctions = schema.getFunctions();
|
final List<EdmFunction> localFunctions = schema.getFunctions();
|
||||||
if (localFunctions != null) {
|
if (localFunctions != null) {
|
||||||
for (EdmFunction function : localFunctions) {
|
for (EdmFunction function : localFunctions) {
|
||||||
FunctionMapKey key =
|
final FullQualifiedName name = new FullQualifiedName(namespace, function.getName());
|
||||||
new FunctionMapKey(new FullQualifiedName(namespace, function.getName()), function
|
final FunctionMapKey key = new FunctionMapKey(name,
|
||||||
.getBindingParameterTypeFqn(), function.isBindingParameterTypeCollection(), function
|
function.getBindingParameterTypeFqn(), function.isBindingParameterTypeCollection(),
|
||||||
.getParameterNames());
|
function.getParameterNames());
|
||||||
|
|
||||||
if (function.isBound()) {
|
if (function.isBound()) {
|
||||||
boundFunctions.put(key, function);
|
boundFunctions.put(key, function);
|
||||||
} else {
|
} else {
|
||||||
unboundFunctions.put(key, function);
|
if (!unboundFunctionsByName.containsKey(name)) {
|
||||||
|
unboundFunctionsByName.put(name, new ArrayList<EdmFunction>());
|
||||||
|
}
|
||||||
|
unboundFunctionsByName.get(name).add(function);
|
||||||
|
|
||||||
|
unboundFunctionsByKey.put(key, function);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EdmEntityContainer entityContainer = schema.getEntityContainer();
|
final EdmEntityContainer entityContainer = schema.getEntityContainer();
|
||||||
if(entityContainer != null){
|
if (entityContainer != null) {
|
||||||
entityContainers.put(new FullQualifiedName(namespace, entityContainer.getName()), entityContainer);
|
entityContainers.put(new FullQualifiedName(namespace, entityContainer.getName()), entityContainer);
|
||||||
if(!entityContainers.containsKey(null)){
|
if (!entityContainers.containsKey(null)) {
|
||||||
entityContainers.put(null, entityContainer);
|
entityContainers.put(null, entityContainer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -213,29 +223,12 @@ public abstract class AbstractEdm implements Edm {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmAction getAction(final FullQualifiedName actionName, final FullQualifiedName bindingParameterTypeName,
|
public EdmAction getUnboundAction(final FullQualifiedName actionName) {
|
||||||
final Boolean isBindingParameterCollection) {
|
EdmAction action = unboundActions.get(actionName);
|
||||||
|
if (action == null) {
|
||||||
EdmAction action = null;
|
action = createUnboundAction(resolvePossibleAlias(actionName));
|
||||||
|
if (action != null) {
|
||||||
final FullQualifiedName actionFqn = resolvePossibleAlias(actionName);
|
unboundActions.put(actionName, action);
|
||||||
if (bindingParameterTypeName == null) {
|
|
||||||
action = unboundActions.get(actionName);
|
|
||||||
if (action == null) {
|
|
||||||
action = createUnboundAction(actionFqn);
|
|
||||||
if (action != null) {
|
|
||||||
unboundActions.put(actionName, action);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
final FullQualifiedName bindingParameterTypeFqn = resolvePossibleAlias(bindingParameterTypeName);
|
|
||||||
final ActionMapKey key = new ActionMapKey(actionFqn, bindingParameterTypeFqn, isBindingParameterCollection);
|
|
||||||
action = boundActions.get(key);
|
|
||||||
if (action == null) {
|
|
||||||
action = createBoundAction(actionFqn, bindingParameterTypeFqn, isBindingParameterCollection);
|
|
||||||
if (action != null) {
|
|
||||||
boundActions.put(key, action);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -243,34 +236,83 @@ public abstract class AbstractEdm implements Edm {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getFunction(final FullQualifiedName functionName,
|
public EdmAction getBoundAction(final FullQualifiedName actionName,
|
||||||
final FullQualifiedName bindingParameterTypeName,
|
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
||||||
final Boolean isBindingParameterCollection, final List<String> parameterNames) {
|
|
||||||
|
|
||||||
EdmFunction function = null;
|
final FullQualifiedName actionFqn = resolvePossibleAlias(actionName);
|
||||||
|
final FullQualifiedName bindingParameterTypeFqn = resolvePossibleAlias(bindingParameterTypeName);
|
||||||
|
final ActionMapKey key = new ActionMapKey(actionFqn, bindingParameterTypeFqn, isBindingParameterCollection);
|
||||||
|
EdmAction action = boundActions.get(key);
|
||||||
|
if (action == null) {
|
||||||
|
action = createBoundAction(actionFqn, bindingParameterTypeFqn, isBindingParameterCollection);
|
||||||
|
if (action != null) {
|
||||||
|
boundActions.put(key, action);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return action;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<EdmFunction> getUnboundFunctions(final FullQualifiedName functionName) {
|
||||||
final FullQualifiedName functionFqn = resolvePossibleAlias(functionName);
|
final FullQualifiedName functionFqn = resolvePossibleAlias(functionName);
|
||||||
if (bindingParameterTypeName == null) {
|
|
||||||
final FunctionMapKey key = new FunctionMapKey(
|
List<EdmFunction> functions = unboundFunctionsByName.get(functionFqn);
|
||||||
functionFqn, bindingParameterTypeName, isBindingParameterCollection, parameterNames);
|
if (functions == null) {
|
||||||
function = unboundFunctions.get(key);
|
functions = createUnboundFunctions(functionFqn);
|
||||||
if (function == null) {
|
if (functions != null) {
|
||||||
function = createUnboundFunction(functionFqn, parameterNames);
|
unboundFunctionsByName.put(functionFqn, functions);
|
||||||
if (function != null) {
|
|
||||||
unboundFunctions.put(key, function);
|
for (EdmFunction unbound : functions) {
|
||||||
|
final FunctionMapKey key = new FunctionMapKey(
|
||||||
|
new FullQualifiedName(unbound.getNamespace(), unbound.getName()),
|
||||||
|
unbound.getBindingParameterTypeFqn(),
|
||||||
|
unbound.isBindingParameterTypeCollection(),
|
||||||
|
unbound.getParameterNames());
|
||||||
|
unboundFunctionsByKey.put(key, unbound);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
final FullQualifiedName bindingParameterTypeFqn = resolvePossibleAlias(bindingParameterTypeName);
|
|
||||||
final FunctionMapKey key =
|
return functions;
|
||||||
new FunctionMapKey(functionFqn, bindingParameterTypeFqn, isBindingParameterCollection, parameterNames);
|
}
|
||||||
function = boundFunctions.get(key);
|
|
||||||
if (function == null) {
|
@Override
|
||||||
function = createBoundFunction(functionFqn, bindingParameterTypeFqn, isBindingParameterCollection,
|
public EdmFunction getUnboundFunction(final FullQualifiedName functionName, final List<String> parameterNames) {
|
||||||
parameterNames);
|
final FullQualifiedName functionFqn = resolvePossibleAlias(functionName);
|
||||||
if (function != null) {
|
|
||||||
boundFunctions.put(key, function);
|
final FunctionMapKey key = new FunctionMapKey(functionFqn, null, null, parameterNames);
|
||||||
|
EdmFunction function = unboundFunctionsByKey.get(key);
|
||||||
|
if (function == null) {
|
||||||
|
function = createUnboundFunction(functionFqn, parameterNames);
|
||||||
|
if (function != null) {
|
||||||
|
unboundFunctionsByKey.put(key, function);
|
||||||
|
|
||||||
|
if (!unboundFunctionsByName.containsKey(functionFqn)) {
|
||||||
|
unboundFunctionsByName.put(functionFqn, new ArrayList<EdmFunction>());
|
||||||
}
|
}
|
||||||
|
unboundFunctionsByName.get(functionFqn).add(function);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return function;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EdmFunction getBoundFunction(final FullQualifiedName functionName,
|
||||||
|
final FullQualifiedName bindingParameterTypeName,
|
||||||
|
final Boolean isBindingParameterCollection, final List<String> parameterNames) {
|
||||||
|
|
||||||
|
final FullQualifiedName functionFqn = resolvePossibleAlias(functionName);
|
||||||
|
final FullQualifiedName bindingParameterTypeFqn = resolvePossibleAlias(bindingParameterTypeName);
|
||||||
|
final FunctionMapKey key =
|
||||||
|
new FunctionMapKey(functionFqn, bindingParameterTypeFqn, isBindingParameterCollection, parameterNames);
|
||||||
|
EdmFunction function = boundFunctions.get(key);
|
||||||
|
if (function == null) {
|
||||||
|
function = createBoundFunction(functionFqn, bindingParameterTypeFqn, isBindingParameterCollection,
|
||||||
|
parameterNames);
|
||||||
|
if (function != null) {
|
||||||
|
boundFunctions.put(key, function);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -316,15 +358,17 @@ public abstract class AbstractEdm implements Edm {
|
||||||
|
|
||||||
protected abstract EdmAction createUnboundAction(FullQualifiedName actionName);
|
protected abstract EdmAction createUnboundAction(FullQualifiedName actionName);
|
||||||
|
|
||||||
|
protected abstract List<EdmFunction> createUnboundFunctions(FullQualifiedName functionName);
|
||||||
|
|
||||||
protected abstract EdmFunction createUnboundFunction(FullQualifiedName functionName, List<String> parameterNames);
|
protected abstract EdmFunction createUnboundFunction(FullQualifiedName functionName, List<String> parameterNames);
|
||||||
|
|
||||||
protected abstract EdmAction createBoundAction(FullQualifiedName actionName,
|
protected abstract EdmAction createBoundAction(FullQualifiedName actionName,
|
||||||
FullQualifiedName bindingParameterTypeName,
|
FullQualifiedName bindingParameterTypeName,
|
||||||
Boolean isBindingParameterCollection);
|
Boolean isBindingParameterCollection);
|
||||||
|
|
||||||
protected abstract EdmFunction createBoundFunction(FullQualifiedName functionName,
|
protected abstract EdmFunction createBoundFunction(FullQualifiedName functionName,
|
||||||
FullQualifiedName bindingParameterTypeName, Boolean isBindingParameterCollection,
|
FullQualifiedName bindingParameterTypeName, Boolean isBindingParameterCollection,
|
||||||
List<String> parameterNames);
|
List<String> parameterNames);
|
||||||
|
|
||||||
protected abstract EdmServiceMetadata createServiceMetadata();
|
protected abstract EdmServiceMetadata createServiceMetadata();
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,7 @@ import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -41,7 +42,6 @@ import org.apache.olingo.commons.api.edm.EdmSchema;
|
||||||
import org.apache.olingo.commons.api.edm.EdmServiceMetadata;
|
import org.apache.olingo.commons.api.edm.EdmServiceMetadata;
|
||||||
import org.apache.olingo.commons.api.edm.EdmTypeDefinition;
|
import org.apache.olingo.commons.api.edm.EdmTypeDefinition;
|
||||||
import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
||||||
import org.apache.olingo.commons.core.edm.AbstractEdm;
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -57,14 +57,14 @@ public class EdmImplCachingTest {
|
||||||
public void cacheSchema() {
|
public void cacheSchema() {
|
||||||
List<EdmSchema> schemas = edm.getSchemas();
|
List<EdmSchema> schemas = edm.getSchemas();
|
||||||
assertNotNull(schemas);
|
assertNotNull(schemas);
|
||||||
|
|
||||||
assertEquals(1, schemas.size());
|
assertEquals(1, schemas.size());
|
||||||
|
|
||||||
List<EdmSchema> cachedSchemas = edm.getSchemas();
|
List<EdmSchema> cachedSchemas = edm.getSchemas();
|
||||||
assertTrue(schemas == cachedSchemas );
|
assertTrue(schemas == cachedSchemas);
|
||||||
assertEquals(schemas, schemas);
|
assertEquals(schemas, schemas);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void cacheEntityContainer() {
|
public void cacheEntityContainer() {
|
||||||
EdmEntityContainer entityContainer = edm.getEntityContainer(null);
|
EdmEntityContainer entityContainer = edm.getEntityContainer(null);
|
||||||
|
@ -158,32 +158,32 @@ public class EdmImplCachingTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void cacheUnboundAction() {
|
public void cacheUnboundAction() {
|
||||||
EdmAction action = edm.getAction(NAME1, null, null);
|
EdmAction action = edm.getUnboundAction(NAME1);
|
||||||
assertNotNull(action);
|
assertNotNull(action);
|
||||||
|
|
||||||
EdmAction cachedAction = edm.getAction(NAME1, null, null);
|
EdmAction cachedAction = edm.getUnboundAction(NAME1);
|
||||||
assertNotNull(cachedAction);
|
assertNotNull(cachedAction);
|
||||||
|
|
||||||
assertTrue(action == cachedAction);
|
assertTrue(action == cachedAction);
|
||||||
assertEquals(action, cachedAction);
|
assertEquals(action, cachedAction);
|
||||||
|
|
||||||
EdmAction action2 = edm.getAction(NAME2, null, false);
|
EdmAction action2 = edm.getUnboundAction(NAME2);
|
||||||
assertNotNull(action2);
|
assertNotNull(action2);
|
||||||
assertNotSame(action, action2);
|
assertNotSame(action, action2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void cacheBoundAction() {
|
public void cacheBoundAction() {
|
||||||
EdmAction action = edm.getAction(NAME1, NAME2, true);
|
EdmAction action = edm.getBoundAction(NAME1, NAME2, true);
|
||||||
assertNotNull(action);
|
assertNotNull(action);
|
||||||
|
|
||||||
EdmAction cachedAction = edm.getAction(NAME1, NAME2, true);
|
EdmAction cachedAction = edm.getBoundAction(NAME1, NAME2, true);
|
||||||
assertNotNull(cachedAction);
|
assertNotNull(cachedAction);
|
||||||
|
|
||||||
assertTrue(action == cachedAction);
|
assertTrue(action == cachedAction);
|
||||||
assertEquals(action, cachedAction);
|
assertEquals(action, cachedAction);
|
||||||
|
|
||||||
EdmAction action2 = edm.getAction(NAME2, NAME2, true);
|
EdmAction action2 = edm.getBoundAction(NAME2, NAME2, true);
|
||||||
assertNotNull(action2);
|
assertNotNull(action2);
|
||||||
assertNotSame(action, action2);
|
assertNotSame(action, action2);
|
||||||
|
|
||||||
|
@ -191,16 +191,16 @@ public class EdmImplCachingTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void cacheUnboundFunctionNoParameters() {
|
public void cacheUnboundFunctionNoParameters() {
|
||||||
EdmFunction function = edm.getFunction(NAME1, null, null, null);
|
EdmFunction function = edm.getUnboundFunction(NAME1, null);
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
|
|
||||||
EdmFunction cachedfunction = edm.getFunction(NAME1, null, null, null);
|
EdmFunction cachedfunction = edm.getUnboundFunction(NAME1, null);
|
||||||
assertNotNull(cachedfunction);
|
assertNotNull(cachedfunction);
|
||||||
|
|
||||||
assertTrue(function == cachedfunction);
|
assertTrue(function == cachedfunction);
|
||||||
assertEquals(function, cachedfunction);
|
assertEquals(function, cachedfunction);
|
||||||
|
|
||||||
EdmFunction function2 = edm.getFunction(NAME2, null, false, null);
|
EdmFunction function2 = edm.getBoundFunction(NAME2, null, false, null);
|
||||||
assertNotNull(function2);
|
assertNotNull(function2);
|
||||||
|
|
||||||
assertNotSame(function, function2);
|
assertNotSame(function, function2);
|
||||||
|
@ -208,16 +208,16 @@ public class EdmImplCachingTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void cacheBoundFunction() {
|
public void cacheBoundFunction() {
|
||||||
EdmFunction function = edm.getFunction(NAME1, NAME2, true, new ArrayList<String>());
|
EdmFunction function = edm.getBoundFunction(NAME1, NAME2, true, new ArrayList<String>());
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
|
|
||||||
EdmFunction cachedfunction = edm.getFunction(NAME1, NAME2, true, new ArrayList<String>());
|
EdmFunction cachedfunction = edm.getBoundFunction(NAME1, NAME2, true, new ArrayList<String>());
|
||||||
assertNotNull(cachedfunction);
|
assertNotNull(cachedfunction);
|
||||||
|
|
||||||
assertTrue(function == cachedfunction);
|
assertTrue(function == cachedfunction);
|
||||||
assertEquals(function, cachedfunction);
|
assertEquals(function, cachedfunction);
|
||||||
|
|
||||||
EdmFunction function2 = edm.getFunction(NAME2, NAME2, true, new ArrayList<String>());
|
EdmFunction function2 = edm.getBoundFunction(NAME2, NAME2, true, new ArrayList<String>());
|
||||||
assertNotNull(function2);
|
assertNotNull(function2);
|
||||||
|
|
||||||
assertNotSame(function, function2);
|
assertNotSame(function, function2);
|
||||||
|
@ -228,19 +228,19 @@ public class EdmImplCachingTest {
|
||||||
ArrayList<String> parameters1 = new ArrayList<String>();
|
ArrayList<String> parameters1 = new ArrayList<String>();
|
||||||
parameters1.add("A");
|
parameters1.add("A");
|
||||||
parameters1.add("B");
|
parameters1.add("B");
|
||||||
EdmFunction function = edm.getFunction(NAME1, NAME2, true, parameters1);
|
EdmFunction function = edm.getBoundFunction(NAME1, NAME2, true, parameters1);
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
|
|
||||||
ArrayList<String> parameters2 = new ArrayList<String>();
|
ArrayList<String> parameters2 = new ArrayList<String>();
|
||||||
parameters2.add("B");
|
parameters2.add("B");
|
||||||
parameters2.add("A");
|
parameters2.add("A");
|
||||||
EdmFunction cachedfunction = edm.getFunction(NAME1, NAME2, true, parameters2);
|
EdmFunction cachedfunction = edm.getBoundFunction(NAME1, NAME2, true, parameters2);
|
||||||
assertNotNull(cachedfunction);
|
assertNotNull(cachedfunction);
|
||||||
|
|
||||||
assertTrue(function == cachedfunction);
|
assertTrue(function == cachedfunction);
|
||||||
assertEquals(function, cachedfunction);
|
assertEquals(function, cachedfunction);
|
||||||
|
|
||||||
EdmFunction function2 = edm.getFunction(NAME2, NAME2, true, new ArrayList<String>());
|
EdmFunction function2 = edm.getBoundFunction(NAME2, NAME2, true, new ArrayList<String>());
|
||||||
assertNotNull(function2);
|
assertNotNull(function2);
|
||||||
|
|
||||||
assertNotSame(function, function2);
|
assertNotSame(function, function2);
|
||||||
|
@ -383,6 +383,22 @@ public class EdmImplCachingTest {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<EdmFunction> createUnboundFunctions(final FullQualifiedName fqn) {
|
||||||
|
if (NAME1.equals(fqn)) {
|
||||||
|
EdmFunction function = mock(EdmFunction.class);
|
||||||
|
when(function.getNamespace()).thenReturn(fqn.getNamespace());
|
||||||
|
when(function.getName()).thenReturn(fqn.getName());
|
||||||
|
return Collections.singletonList(function);
|
||||||
|
} else if (NAME2.equals(fqn)) {
|
||||||
|
EdmFunction function = mock(EdmFunction.class);
|
||||||
|
when(function.getNamespace()).thenReturn(fqn.getNamespace());
|
||||||
|
when(function.getName()).thenReturn(fqn.getName());
|
||||||
|
return Collections.singletonList(function);
|
||||||
|
}
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected EdmFunction createUnboundFunction(final FullQualifiedName fqn, final List<String> parameterNames) {
|
protected EdmFunction createUnboundFunction(final FullQualifiedName fqn, final List<String> parameterNames) {
|
||||||
if (NAME1.equals(fqn)) {
|
if (NAME1.equals(fqn)) {
|
||||||
|
|
|
@ -26,6 +26,7 @@ import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -41,7 +42,6 @@ import org.apache.olingo.commons.api.edm.EdmSchema;
|
||||||
import org.apache.olingo.commons.api.edm.EdmServiceMetadata;
|
import org.apache.olingo.commons.api.edm.EdmServiceMetadata;
|
||||||
import org.apache.olingo.commons.api.edm.EdmTypeDefinition;
|
import org.apache.olingo.commons.api.edm.EdmTypeDefinition;
|
||||||
import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
||||||
import org.apache.olingo.commons.core.edm.AbstractEdm;
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ public class EdmImplCallCreateTest {
|
||||||
List<EdmSchema> schemas = edm.getSchemas();
|
List<EdmSchema> schemas = edm.getSchemas();
|
||||||
assertNotNull(schemas);
|
assertNotNull(schemas);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void callCreateEntityContainer() {
|
public void callCreateEntityContainer() {
|
||||||
EdmEntityContainer entityContainer = edm.getEntityContainer(FQN);
|
EdmEntityContainer entityContainer = edm.getEntityContainer(FQN);
|
||||||
|
@ -116,36 +116,36 @@ public class EdmImplCallCreateTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void callCreateAction() {
|
public void callCreateAction() {
|
||||||
EdmAction action = edm.getAction(FQN, null, null);
|
EdmAction action = edm.getUnboundAction(FQN);
|
||||||
assertNotNull(action);
|
assertNotNull(action);
|
||||||
assertEquals(FQN.getNamespace(), action.getNamespace());
|
assertEquals(FQN.getNamespace(), action.getNamespace());
|
||||||
assertEquals(FQN.getName(), action.getName());
|
assertEquals(FQN.getName(), action.getName());
|
||||||
|
|
||||||
EdmAction action2 = edm.getAction(FQN, FQN, true);
|
EdmAction action2 = edm.getBoundAction(FQN, FQN, true);
|
||||||
assertNotNull(action2);
|
assertNotNull(action2);
|
||||||
assertEquals(FQN.getNamespace(), action2.getNamespace());
|
assertEquals(FQN.getNamespace(), action2.getNamespace());
|
||||||
assertEquals(FQN.getName(), action2.getName());
|
assertEquals(FQN.getName(), action2.getName());
|
||||||
|
|
||||||
assertNotSame(action, action2);
|
assertNotSame(action, action2);
|
||||||
|
|
||||||
assertNull(edm.getAction(WRONG_FQN, null, null));
|
assertNull(edm.getUnboundAction(WRONG_FQN));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void callCreateFunction() {
|
public void callCreateFunction() {
|
||||||
EdmFunction function = edm.getFunction(FQN, null, null, null);
|
EdmFunction function = edm.getUnboundFunction(FQN, null);
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
assertEquals(FQN.getNamespace(), function.getNamespace());
|
assertEquals(FQN.getNamespace(), function.getNamespace());
|
||||||
assertEquals(FQN.getName(), function.getName());
|
assertEquals(FQN.getName(), function.getName());
|
||||||
|
|
||||||
EdmFunction function2 = edm.getFunction(FQN, FQN, true, new ArrayList<String>());
|
EdmFunction function2 = edm.getBoundFunction(FQN, FQN, true, new ArrayList<String>());
|
||||||
assertNotNull(function2);
|
assertNotNull(function2);
|
||||||
assertEquals(FQN.getNamespace(), function2.getNamespace());
|
assertEquals(FQN.getNamespace(), function2.getNamespace());
|
||||||
assertEquals(FQN.getName(), function2.getName());
|
assertEquals(FQN.getName(), function2.getName());
|
||||||
|
|
||||||
assertNotSame(function, function2);
|
assertNotSame(function, function2);
|
||||||
|
|
||||||
assertNull(edm.getFunction(WRONG_FQN, null, null, null));
|
assertNull(edm.getUnboundFunction(WRONG_FQN, null));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -261,6 +261,17 @@ public class EdmImplCallCreateTest {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<EdmFunction> createUnboundFunctions(final FullQualifiedName fqn) {
|
||||||
|
if (FQN.getNamespace().equals(fqn.getNamespace()) && FQN.getName().equals(fqn.getName())) {
|
||||||
|
EdmFunction function = mock(EdmFunction.class);
|
||||||
|
when(function.getNamespace()).thenReturn(fqn.getNamespace());
|
||||||
|
when(function.getName()).thenReturn(fqn.getName());
|
||||||
|
return Collections.singletonList(function);
|
||||||
|
}
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected EdmFunction createUnboundFunction(final FullQualifiedName fqn, final List<String> parameterNames) {
|
protected EdmFunction createUnboundFunction(final FullQualifiedName fqn, final List<String> parameterNames) {
|
||||||
if (FQN.getNamespace().equals(fqn.getNamespace()) && FQN.getName().equals(fqn.getName())) {
|
if (FQN.getNamespace().equals(fqn.getNamespace()) && FQN.getName().equals(fqn.getName())) {
|
||||||
|
|
|
@ -22,7 +22,6 @@ import org.apache.olingo.commons.api.edm.Edm;
|
||||||
import org.apache.olingo.commons.api.edm.EdmAction;
|
import org.apache.olingo.commons.api.edm.EdmAction;
|
||||||
import org.apache.olingo.commons.api.edm.EdmActionImport;
|
import org.apache.olingo.commons.api.edm.EdmActionImport;
|
||||||
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
import org.apache.olingo.commons.api.edm.EdmEntityContainer;
|
||||||
import org.apache.olingo.commons.api.edm.FullQualifiedName;
|
|
||||||
import org.apache.olingo.server.api.edm.provider.ActionImport;
|
import org.apache.olingo.server.api.edm.provider.ActionImport;
|
||||||
|
|
||||||
public class EdmActionImportImpl extends EdmOperationImportImpl implements EdmActionImport {
|
public class EdmActionImportImpl extends EdmOperationImportImpl implements EdmActionImport {
|
||||||
|
@ -37,14 +36,7 @@ public class EdmActionImportImpl extends EdmOperationImportImpl implements EdmAc
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmAction getUnboundAction() {
|
public EdmAction getUnboundAction() {
|
||||||
return getBoundAction(null, null);
|
return edm.getUnboundAction(actionImport.getAction());
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public EdmAction getBoundAction(
|
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
|
||||||
|
|
||||||
return edm.getAction(actionImport.getAction(), bindingParameterTypeName, isBindingParameterCollection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,17 +38,18 @@ public class EdmFunctionImportImpl extends EdmOperationImportImpl implements Edm
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getUnboundFunction(final List<String> parameterNames) {
|
public FullQualifiedName getFunctionFqn() {
|
||||||
return getBoundFunction(parameterNames, null, null);
|
return functionImport.getFunction();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction getBoundFunction(final List<String> parameterNames,
|
public EdmFunction getUnboundFunction(final List<String> parameterNames) {
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
return edm.getUnboundFunction(getFunctionFqn(), parameterNames);
|
||||||
|
}
|
||||||
return edm.getFunction(functionImport.getFunction(),
|
|
||||||
bindingParameterTypeName, isBindingParameterCollection, parameterNames);
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<EdmFunction> getUnboundFunctions() {
|
||||||
|
return edm.getUnboundFunctions(getFunctionFqn());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -56,8 +57,4 @@ public class EdmFunctionImportImpl extends EdmOperationImportImpl implements Edm
|
||||||
return functionImport.isIncludeInServiceDocument();
|
return functionImport.isIncludeInServiceDocument();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public FullQualifiedName getFunctionFqn() {
|
|
||||||
return functionImport.getFunction();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,7 +129,7 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmAction createBoundAction(final FullQualifiedName actionName,
|
public EdmAction createBoundAction(final FullQualifiedName actionName,
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
List<Action> actions = actionsMap.get(actionName);
|
List<Action> actions = actionsMap.get(actionName);
|
||||||
|
@ -147,7 +147,7 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
final List<Parameter> parameters = action.getParameters();
|
final List<Parameter> parameters = action.getParameters();
|
||||||
final Parameter parameter = parameters.get(0);
|
final Parameter parameter = parameters.get(0);
|
||||||
if (bindingParameterTypeName.equals(parameter.getType())
|
if (bindingParameterTypeName.equals(parameter.getType())
|
||||||
&& isBindingParameterCollection.booleanValue() == parameter.isCollection()) {
|
&& isBindingParameterCollection.booleanValue() == parameter.isCollection()) {
|
||||||
|
|
||||||
return EdmActionImpl.getInstance(this, actionName, action);
|
return EdmActionImpl.getInstance(this, actionName, action);
|
||||||
}
|
}
|
||||||
|
@ -162,8 +162,8 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EdmFunction createBoundFunction(final FullQualifiedName functionName,
|
public EdmFunction createBoundFunction(final FullQualifiedName functionName,
|
||||||
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection,
|
final FullQualifiedName bindingParameterTypeName, final Boolean isBindingParameterCollection,
|
||||||
final List<String> parameterNames) {
|
final List<String> parameterNames) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
List<Function> functions = functionsMap.get(functionName);
|
List<Function> functions = functionsMap.get(functionName);
|
||||||
|
@ -175,8 +175,8 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
functionsMap.put(functionName, functions);
|
functionsMap.put(functionName, functions);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final List<String> parameterNamesCopy =
|
final List<String> parameterNamesCopy
|
||||||
parameterNames == null ? Collections.<String> emptyList() : parameterNames;
|
= parameterNames == null ? Collections.<String>emptyList() : parameterNames;
|
||||||
for (Function function : functions) {
|
for (Function function : functions) {
|
||||||
if (function.isBound()) {
|
if (function.isBound()) {
|
||||||
List<Parameter> providerParameters = function.getParameters();
|
List<Parameter> providerParameters = function.getParameters();
|
||||||
|
@ -185,7 +185,7 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
}
|
}
|
||||||
final Parameter bindingParameter = providerParameters.get(0);
|
final Parameter bindingParameter = providerParameters.get(0);
|
||||||
if (bindingParameterTypeName.equals(bindingParameter.getType())
|
if (bindingParameterTypeName.equals(bindingParameter.getType())
|
||||||
&& isBindingParameterCollection.booleanValue() == bindingParameter.isCollection()) {
|
&& isBindingParameterCollection.booleanValue() == bindingParameter.isCollection()) {
|
||||||
|
|
||||||
if (parameterNamesCopy.size() == providerParameters.size() - 1) {
|
if (parameterNamesCopy.size() == providerParameters.size() - 1) {
|
||||||
final List<String> providerParameterNames = new ArrayList<String>();
|
final List<String> providerParameterNames = new ArrayList<String>();
|
||||||
|
@ -251,19 +251,44 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected EdmFunction createUnboundFunction(final FullQualifiedName functionName, final List<String> parameterNames) {
|
protected List<EdmFunction> createUnboundFunctions(final FullQualifiedName functionName) {
|
||||||
|
List<EdmFunction> result = new ArrayList<EdmFunction>();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
List<Function> functions = functionsMap.get(functionName);
|
List<Function> functions = functionsMap.get(functionName);
|
||||||
if (functions == null) {
|
if (functions == null) {
|
||||||
functions = provider.getFunctions(functionName);
|
functions = provider.getFunctions(functionName);
|
||||||
if (functions != null) {
|
if (functions != null) {
|
||||||
functionsMap.put(functionName, functions);
|
functionsMap.put(functionName, functions);
|
||||||
} else {
|
|
||||||
return null;
|
for (Function function : functions) {
|
||||||
|
if (!function.isBound()) {
|
||||||
|
result.add(EdmFunctionImpl.getInstance(this, functionName, function));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final List<String> parameterNamesCopy =
|
} catch (ODataException e) {
|
||||||
parameterNames == null ? Collections.<String> emptyList() : parameterNames;
|
throw new EdmException(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected EdmFunction createUnboundFunction(final FullQualifiedName functionName, final List<String> parameterNames) {
|
||||||
|
try {
|
||||||
|
List<Function> functions = functionsMap.get(functionName);
|
||||||
|
if (functions == null) {
|
||||||
|
functions = provider.getFunctions(functionName);
|
||||||
|
if (functions == null) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
functionsMap.put(functionName, functions);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
final List<String> parameterNamesCopy
|
||||||
|
= parameterNames == null ? Collections.<String>emptyList() : parameterNames;
|
||||||
for (Function function : functions) {
|
for (Function function : functions) {
|
||||||
if (!function.isBound()) {
|
if (!function.isBound()) {
|
||||||
List<Parameter> providerParameters = function.getParameters();
|
List<Parameter> providerParameters = function.getParameters();
|
||||||
|
@ -271,7 +296,7 @@ public class EdmProviderImpl extends AbstractEdm {
|
||||||
providerParameters = Collections.emptyList();
|
providerParameters = Collections.emptyList();
|
||||||
}
|
}
|
||||||
if (parameterNamesCopy.size() == providerParameters.size()) {
|
if (parameterNamesCopy.size() == providerParameters.size()) {
|
||||||
List<String> functionParameterNames = new ArrayList<String>();
|
final List<String> functionParameterNames = new ArrayList<String>();
|
||||||
for (Parameter parameter : providerParameters) {
|
for (Parameter parameter : providerParameters) {
|
||||||
functionParameterNames.add(parameter.getName());
|
functionParameterNames.add(parameter.getName());
|
||||||
}
|
}
|
||||||
|
|
|
@ -558,7 +558,7 @@ public class UriParseTreeVisitor extends UriParserBaseVisitor<Object> {
|
||||||
FullQualifiedName fullBindingTypeName = new FullQualifiedName(source.type.getNamespace(), source.type.getName());
|
FullQualifiedName fullBindingTypeName = new FullQualifiedName(source.type.getNamespace(), source.type.getName());
|
||||||
|
|
||||||
// check for action
|
// check for action
|
||||||
EdmAction action = edm.getAction(fullFilterName, fullBindingTypeName, source.isCollection);
|
EdmAction action = edm.getBoundAction(fullFilterName, fullBindingTypeName, source.isCollection);
|
||||||
if (action != null) {
|
if (action != null) {
|
||||||
UriResourceActionImpl pathInfoAction = new UriResourceActionImpl();
|
UriResourceActionImpl pathInfoAction = new UriResourceActionImpl();
|
||||||
pathInfoAction.setAction(action);
|
pathInfoAction.setAction(action);
|
||||||
|
@ -583,7 +583,7 @@ public class UriParseTreeVisitor extends UriParserBaseVisitor<Object> {
|
||||||
names.add(item.getName());
|
names.add(item.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
EdmFunction function = edm.getFunction(fullFilterName, fullBindingTypeName, source.isCollection, names);
|
EdmFunction function = edm.getBoundFunction(fullFilterName, fullBindingTypeName, source.isCollection, names);
|
||||||
|
|
||||||
if (function != null) {
|
if (function != null) {
|
||||||
UriResourceFunctionImpl pathInfoFunction = new UriResourceFunctionImpl()
|
UriResourceFunctionImpl pathInfoFunction = new UriResourceFunctionImpl()
|
||||||
|
@ -597,7 +597,7 @@ public class UriParseTreeVisitor extends UriParserBaseVisitor<Object> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for unbound function in the $filter case ( where the previous resource segment is a $it)
|
// check for unbound function in the $filter case ( where the previous resource segment is a $it)
|
||||||
function = edm.getFunction(fullFilterName, null, null, names);
|
function = edm.getUnboundFunction(fullFilterName, names);
|
||||||
|
|
||||||
if (function != null) {
|
if (function != null) {
|
||||||
UriResourceFunctionImpl pathInfoFunction = new UriResourceFunctionImpl()
|
UriResourceFunctionImpl pathInfoFunction = new UriResourceFunctionImpl()
|
||||||
|
@ -1972,7 +1972,7 @@ public class UriParseTreeVisitor extends UriParserBaseVisitor<Object> {
|
||||||
FullQualifiedName finalTypeName = new FullQualifiedName(prevType.getNamespace(), prevType.getName());
|
FullQualifiedName finalTypeName = new FullQualifiedName(prevType.getNamespace(), prevType.getName());
|
||||||
|
|
||||||
// check for action
|
// check for action
|
||||||
EdmAction action = edm.getAction(fullName, finalTypeName, null);
|
EdmAction action = edm.getBoundAction(fullName, finalTypeName, null);
|
||||||
|
|
||||||
if (action != null) {
|
if (action != null) {
|
||||||
UriResourceActionImpl uriAction = new UriResourceActionImpl();
|
UriResourceActionImpl uriAction = new UriResourceActionImpl();
|
||||||
|
@ -1983,7 +1983,7 @@ public class UriParseTreeVisitor extends UriParserBaseVisitor<Object> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for function
|
// check for function
|
||||||
EdmFunction function = edm.getFunction(fullName, finalTypeName, null, null);
|
EdmFunction function = edm.getBoundFunction(fullName, finalTypeName, null, null);
|
||||||
|
|
||||||
if (function != null) {
|
if (function != null) {
|
||||||
UriResourceFunctionImpl uriFunction = new UriResourceFunctionImpl();
|
UriResourceFunctionImpl uriFunction = new UriResourceFunctionImpl();
|
||||||
|
|
|
@ -57,7 +57,7 @@ public class EdmActionImportImplTest {
|
||||||
container = mock(EdmEntityContainer.class);
|
container = mock(EdmEntityContainer.class);
|
||||||
when(edm.getEntityContainer(entityContainerFqn)).thenReturn(container);
|
when(edm.getEntityContainer(entityContainerFqn)).thenReturn(container);
|
||||||
action = mock(EdmAction.class);
|
action = mock(EdmAction.class);
|
||||||
when(edm.getAction(actionFqn, null, null)).thenReturn(action);
|
when(edm.getUnboundAction(actionFqn)).thenReturn(action);
|
||||||
|
|
||||||
entitySet = mock(EdmEntitySet.class);
|
entitySet = mock(EdmEntitySet.class);
|
||||||
when(container.getEntitySet("entitySetName")).thenReturn(entitySet);
|
when(container.getEntitySet("entitySetName")).thenReturn(entitySet);
|
||||||
|
|
|
@ -104,46 +104,46 @@ public class EdmProviderImplOverloadingTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void simpleActionGet() {
|
public void simpleActionGet() {
|
||||||
EdmAction action = edm.getAction(operationName1, null, null);
|
EdmAction action = edm.getUnboundAction(operationName1);
|
||||||
assertNotNull(action);
|
assertNotNull(action);
|
||||||
assertEquals(operationName1.getNamespace(), action.getNamespace());
|
assertEquals(operationName1.getNamespace(), action.getNamespace());
|
||||||
assertEquals(operationName1.getName(), action.getName());
|
assertEquals(operationName1.getName(), action.getName());
|
||||||
|
|
||||||
assertNull(edm.getAction(wrongOperationName, null, null));
|
assertNull(edm.getUnboundAction(wrongOperationName));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void boundActionOverloading() {
|
public void boundActionOverloading() {
|
||||||
EdmAction action = edm.getAction(operationName1, operationType1, false);
|
EdmAction action = edm.getBoundAction(operationName1, operationType1, false);
|
||||||
assertNotNull(action);
|
assertNotNull(action);
|
||||||
assertEquals(operationName1.getNamespace(), action.getNamespace());
|
assertEquals(operationName1.getNamespace(), action.getNamespace());
|
||||||
assertEquals(operationName1.getName(), action.getName());
|
assertEquals(operationName1.getName(), action.getName());
|
||||||
assertTrue(action == edm.getAction(operationName1, operationType1, false));
|
assertTrue(action == edm.getBoundAction(operationName1, operationType1, false));
|
||||||
|
|
||||||
EdmAction action2 = edm.getAction(operationName1, operationType1, true);
|
EdmAction action2 = edm.getBoundAction(operationName1, operationType1, true);
|
||||||
assertNotNull(action2);
|
assertNotNull(action2);
|
||||||
assertEquals(operationName1.getNamespace(), action2.getNamespace());
|
assertEquals(operationName1.getNamespace(), action2.getNamespace());
|
||||||
assertEquals(operationName1.getName(), action2.getName());
|
assertEquals(operationName1.getName(), action2.getName());
|
||||||
assertTrue(action2 == edm.getAction(operationName1, operationType1, true));
|
assertTrue(action2 == edm.getBoundAction(operationName1, operationType1, true));
|
||||||
|
|
||||||
assertNotSame(action, action2);
|
assertNotSame(action, action2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void simpleFunctionGet() {
|
public void simpleFunctionGet() {
|
||||||
EdmFunction function = edm.getFunction(operationName1, null, null, null);
|
EdmFunction function = edm.getUnboundFunction(operationName1, null);
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
assertEquals(operationName1.getNamespace(), function.getNamespace());
|
assertEquals(operationName1.getNamespace(), function.getNamespace());
|
||||||
assertEquals(operationName1.getName(), function.getName());
|
assertEquals(operationName1.getName(), function.getName());
|
||||||
|
|
||||||
EdmFunction function2 = edm.getFunction(operationName1, null, null, new ArrayList<String>());
|
EdmFunction function2 = edm.getUnboundFunction(operationName1, new ArrayList<String>());
|
||||||
assertNotNull(function2);
|
assertNotNull(function2);
|
||||||
assertEquals(operationName1.getNamespace(), function2.getNamespace());
|
assertEquals(operationName1.getNamespace(), function2.getNamespace());
|
||||||
assertEquals(operationName1.getName(), function2.getName());
|
assertEquals(operationName1.getName(), function2.getName());
|
||||||
|
|
||||||
assertEquals(function, function2);
|
assertEquals(function, function2);
|
||||||
|
|
||||||
assertNull(edm.getFunction(wrongOperationName, null, null, new ArrayList<String>()));
|
assertNull(edm.getUnboundFunction(wrongOperationName, new ArrayList<String>()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -152,28 +152,28 @@ public class EdmProviderImplOverloadingTest {
|
||||||
parameter1Names.add("a");
|
parameter1Names.add("a");
|
||||||
List<String> parameter2Names = new ArrayList<String>();
|
List<String> parameter2Names = new ArrayList<String>();
|
||||||
parameter2Names.add("b");
|
parameter2Names.add("b");
|
||||||
EdmFunction function = edm.getFunction(operationName1, null, null, new ArrayList<String>());
|
EdmFunction function = edm.getUnboundFunction(operationName1, new ArrayList<String>());
|
||||||
assertNotNull(function);
|
assertNotNull(function);
|
||||||
assertFalse(function.isBound());
|
assertFalse(function.isBound());
|
||||||
|
|
||||||
EdmFunction function1 = edm.getFunction(operationName1, null, null, parameter1Names);
|
EdmFunction function1 = edm.getUnboundFunction(operationName1, parameter1Names);
|
||||||
assertNotNull(function1);
|
assertNotNull(function1);
|
||||||
assertFalse(function1.isBound());
|
assertFalse(function1.isBound());
|
||||||
|
|
||||||
assertFalse(function == function1);
|
assertFalse(function == function1);
|
||||||
assertNotSame(function, function1);
|
assertNotSame(function, function1);
|
||||||
|
|
||||||
EdmFunction function2 = edm.getFunction(operationName1, null, null, parameter2Names);
|
EdmFunction function2 = edm.getUnboundFunction(operationName1, parameter2Names);
|
||||||
assertNotNull(function2);
|
assertNotNull(function2);
|
||||||
assertFalse(function2.isBound());
|
assertFalse(function2.isBound());
|
||||||
|
|
||||||
assertFalse(function1 == function2);
|
assertFalse(function1 == function2);
|
||||||
assertNotSame(function1, function2);
|
assertNotSame(function1, function2);
|
||||||
|
|
||||||
EdmFunction function3 = edm.getFunction(operationName1, operationType1, false, parameter2Names);
|
EdmFunction function3 = edm.getBoundFunction(operationName1, operationType1, false, parameter2Names);
|
||||||
assertNotNull(function3);
|
assertNotNull(function3);
|
||||||
assertTrue(function3.isBound());
|
assertTrue(function3.isBound());
|
||||||
EdmFunction function4 = edm.getFunction(operationName1, operationType2, false, parameter2Names);
|
EdmFunction function4 = edm.getBoundFunction(operationName1, operationType2, false, parameter2Names);
|
||||||
assertNotNull(function4);
|
assertNotNull(function4);
|
||||||
assertTrue(function4.isBound());
|
assertTrue(function4.isBound());
|
||||||
|
|
||||||
|
@ -192,7 +192,7 @@ public class EdmProviderImplOverloadingTest {
|
||||||
|
|
||||||
@Test(expected = EdmException.class)
|
@Test(expected = EdmException.class)
|
||||||
public void noParametersAtBoundFunctionReslutsInException() {
|
public void noParametersAtBoundFunctionReslutsInException() {
|
||||||
edm.getFunction(badOperationName, operationType1, true, null);
|
edm.getBoundFunction(badOperationName, operationType1, true, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,10 +89,10 @@ public class EdmProviderImplTest {
|
||||||
when(localProvider.getActions(FQN)).thenReturn(null);
|
when(localProvider.getActions(FQN)).thenReturn(null);
|
||||||
when(localProvider.getFunctions(FQN)).thenReturn(null);
|
when(localProvider.getFunctions(FQN)).thenReturn(null);
|
||||||
Edm localEdm = new EdmProviderImpl(localProvider);
|
Edm localEdm = new EdmProviderImpl(localProvider);
|
||||||
localEdm.getAction(FQN, null, null);
|
localEdm.getUnboundAction(FQN);
|
||||||
localEdm.getFunction(FQN, null, null, null);
|
localEdm.getUnboundFunction(FQN, null);
|
||||||
localEdm.getAction(FQN, FQN, true);
|
localEdm.getBoundAction(FQN, FQN, true);
|
||||||
localEdm.getFunction(FQN, FQN, true, null);
|
localEdm.getBoundFunction(FQN, FQN, true, null);
|
||||||
localEdm.getComplexType(FQN);
|
localEdm.getComplexType(FQN);
|
||||||
localEdm.getEntityContainer(FQN);
|
localEdm.getEntityContainer(FQN);
|
||||||
localEdm.getEntityType(FQN);
|
localEdm.getEntityType(FQN);
|
||||||
|
@ -123,24 +123,24 @@ public class EdmProviderImplTest {
|
||||||
|
|
||||||
// seperate because of signature
|
// seperate because of signature
|
||||||
try {
|
try {
|
||||||
localEdm.getAction(fqn, null, null);
|
localEdm.getUnboundAction(fqn);
|
||||||
} catch (EdmException e) {
|
} catch (EdmException e) {
|
||||||
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
localEdm.getFunction(fqn, null, null, null);
|
localEdm.getUnboundFunction(fqn, null);
|
||||||
} catch (EdmException e) {
|
} catch (EdmException e) {
|
||||||
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
localEdm.getAction(fqn, fqn, true);
|
localEdm.getBoundAction(fqn, fqn, true);
|
||||||
} catch (EdmException e) {
|
} catch (EdmException e) {
|
||||||
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
localEdm.getFunction(fqn, fqn, true, null);
|
localEdm.getBoundFunction(fqn, fqn, true, null);
|
||||||
} catch (EdmException e) {
|
} catch (EdmException e) {
|
||||||
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
assertEquals("org.apache.olingo.commons.api.ODataException: msg", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
|
@ -149,7 +149,7 @@ public class EdmSchemaImplTest {
|
||||||
assertEquals(2, actions.size());
|
assertEquals(2, actions.size());
|
||||||
|
|
||||||
for (EdmAction action : actions) {
|
for (EdmAction action : actions) {
|
||||||
assertTrue(action == edm.getAction(new FullQualifiedName("namespace", action.getName()), null, null));
|
assertTrue(action == edm.getUnboundAction(new FullQualifiedName("namespace", action.getName())));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,7 +161,7 @@ public class EdmSchemaImplTest {
|
||||||
|
|
||||||
for (EdmFunction function : functions) {
|
for (EdmFunction function : functions) {
|
||||||
FullQualifiedName functionName = new FullQualifiedName("namespace", function.getName());
|
FullQualifiedName functionName = new FullQualifiedName("namespace", function.getName());
|
||||||
assertTrue(function == edm.getFunction(functionName, null, null, null));
|
assertTrue(function == edm.getUnboundFunction(functionName, null));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -76,7 +76,7 @@ public class UriResourceImplTest {
|
||||||
assertEquals("", impl.toString());
|
assertEquals("", impl.toString());
|
||||||
|
|
||||||
// action
|
// action
|
||||||
EdmAction action = edm.getAction(ActionProvider.nameUARTETParam, null, null);
|
EdmAction action = edm.getUnboundAction(ActionProvider.nameUARTETParam);
|
||||||
impl.setAction(action);
|
impl.setAction(action);
|
||||||
assertEquals(action, impl.getAction());
|
assertEquals(action, impl.getAction());
|
||||||
assertEquals(ActionProvider.nameUARTETParam.getName(), impl.toString());
|
assertEquals(ActionProvider.nameUARTETParam.getName(), impl.toString());
|
||||||
|
|
|
@ -135,7 +135,7 @@ public class ExpressionTest {
|
||||||
EdmEntityType entityType = edm.getEntityType(EntityTypeProvider.nameETKeyNav);
|
EdmEntityType entityType = edm.getEntityType(EntityTypeProvider.nameETKeyNav);
|
||||||
|
|
||||||
// UriResourceImplTyped
|
// UriResourceImplTyped
|
||||||
EdmAction action = edm.getAction(ActionProvider.nameUARTPrimParam, null, null);
|
EdmAction action = edm.getUnboundAction(ActionProvider.nameUARTPrimParam);
|
||||||
UriInfoResource uriInfo = new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
UriInfoResource uriInfo = new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
||||||
new UriResourceActionImpl().setAction(action)).asUriInfoResource();
|
new UriResourceActionImpl().setAction(action)).asUriInfoResource();
|
||||||
expression.setResourcePath(uriInfo);
|
expression.setResourcePath(uriInfo);
|
||||||
|
@ -149,21 +149,21 @@ public class ExpressionTest {
|
||||||
assertEquals(false, expression.isCollection());
|
assertEquals(false, expression.isCollection());
|
||||||
|
|
||||||
// UriResourceImplTyped check collection = true case
|
// UriResourceImplTyped check collection = true case
|
||||||
action = edm.getAction(ActionProvider.nameUARTPrimCollParam, null, null);
|
action = edm.getUnboundAction(ActionProvider.nameUARTPrimCollParam);
|
||||||
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
||||||
new UriResourceActionImpl().setAction(action))
|
new UriResourceActionImpl().setAction(action))
|
||||||
.asUriInfoResource());
|
.asUriInfoResource());
|
||||||
assertEquals(true, expression.isCollection());
|
assertEquals(true, expression.isCollection());
|
||||||
|
|
||||||
// UriResourceImplTyped with filter
|
// UriResourceImplTyped with filter
|
||||||
action = edm.getAction(ActionProvider.nameUARTPrimParam, null, null);
|
action = edm.getUnboundAction(ActionProvider.nameUARTPrimParam);
|
||||||
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
||||||
new UriResourceActionImpl().setAction(action).setTypeFilter(entityType))
|
new UriResourceActionImpl().setAction(action).setTypeFilter(entityType))
|
||||||
.asUriInfoResource());
|
.asUriInfoResource());
|
||||||
assertEquals(entityType, expression.getType());
|
assertEquals(entityType, expression.getType());
|
||||||
|
|
||||||
// UriResourceImplKeyPred
|
// UriResourceImplKeyPred
|
||||||
EdmFunction function = edm.getFunction(FunctionProvider.nameUFCRTETKeyNav, null, null, null);
|
EdmFunction function = edm.getUnboundFunction(FunctionProvider.nameUFCRTETKeyNav, null);
|
||||||
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
||||||
new UriResourceFunctionImpl().setFunction(function))
|
new UriResourceFunctionImpl().setFunction(function))
|
||||||
.asUriInfoResource());
|
.asUriInfoResource());
|
||||||
|
@ -171,8 +171,7 @@ public class ExpressionTest {
|
||||||
|
|
||||||
// UriResourceImplKeyPred typeFilter on entry
|
// UriResourceImplKeyPred typeFilter on entry
|
||||||
EdmEntityType entityBaseType = edm.getEntityType(EntityTypeProvider.nameETBaseTwoKeyNav);
|
EdmEntityType entityBaseType = edm.getEntityType(EntityTypeProvider.nameETBaseTwoKeyNav);
|
||||||
function = edm.getFunction(FunctionProvider.nameUFCRTESTwoKeyNavParam, null, null,
|
function = edm.getUnboundFunction(FunctionProvider.nameUFCRTESTwoKeyNavParam, Arrays.asList("ParameterInt16"));
|
||||||
Arrays.asList(("ParameterInt16")));
|
|
||||||
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
||||||
new UriResourceFunctionImpl().setFunction(function).setEntryTypeFilter(entityBaseType))
|
new UriResourceFunctionImpl().setFunction(function).setEntryTypeFilter(entityBaseType))
|
||||||
.asUriInfoResource());
|
.asUriInfoResource());
|
||||||
|
@ -180,8 +179,7 @@ public class ExpressionTest {
|
||||||
|
|
||||||
// UriResourceImplKeyPred typeFilter on entry
|
// UriResourceImplKeyPred typeFilter on entry
|
||||||
entityBaseType = edm.getEntityType(EntityTypeProvider.nameETBaseTwoKeyNav);
|
entityBaseType = edm.getEntityType(EntityTypeProvider.nameETBaseTwoKeyNav);
|
||||||
function = edm.getFunction(FunctionProvider.nameUFCRTESTwoKeyNavParam, null, null,
|
function = edm.getUnboundFunction(FunctionProvider.nameUFCRTESTwoKeyNavParam, Arrays.asList("ParameterInt16"));
|
||||||
Arrays.asList(("ParameterInt16")));
|
|
||||||
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.resource).addResourcePart(
|
||||||
new UriResourceFunctionImpl().setFunction(function).setCollectionTypeFilter(entityBaseType))
|
new UriResourceFunctionImpl().setFunction(function).setCollectionTypeFilter(entityBaseType))
|
||||||
.asUriInfoResource());
|
.asUriInfoResource());
|
||||||
|
@ -189,8 +187,7 @@ public class ExpressionTest {
|
||||||
|
|
||||||
// no typed
|
// no typed
|
||||||
entityBaseType = edm.getEntityType(EntityTypeProvider.nameETBaseTwoKeyNav);
|
entityBaseType = edm.getEntityType(EntityTypeProvider.nameETBaseTwoKeyNav);
|
||||||
function = edm.getFunction(FunctionProvider.nameUFCRTESTwoKeyNavParam, null, null,
|
function = edm.getUnboundFunction(FunctionProvider.nameUFCRTESTwoKeyNavParam, Arrays.asList("ParameterInt16"));
|
||||||
Arrays.asList(("ParameterInt16")));
|
|
||||||
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.all));
|
expression.setResourcePath(new UriInfoImpl().setKind(UriInfoKind.all));
|
||||||
assertEquals(null, expression.getType());
|
assertEquals(null, expression.getType());
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue