[OLINGO-573] Merge branch 'master' into OLINGO-573
This commit is contained in:
commit
3f79ced17a
|
@ -277,7 +277,7 @@ public class EntityInvocationHandler extends AbstractStructuredInvocationHandler
|
||||||
/**
|
/**
|
||||||
* Gets the current ETag defined into the wrapped entity.
|
* Gets the current ETag defined into the wrapped entity.
|
||||||
*
|
*
|
||||||
* @return
|
* @return the current etag
|
||||||
*/
|
*/
|
||||||
public String getETag() {
|
public String getETag() {
|
||||||
return getEntity().getETag();
|
return getEntity().getETag();
|
||||||
|
|
|
@ -1463,7 +1463,7 @@ public abstract class AbstractServices {
|
||||||
* @param path
|
* @param path
|
||||||
* @param format
|
* @param format
|
||||||
* @param changes
|
* @param changes
|
||||||
* @return
|
* @return response
|
||||||
*/
|
*/
|
||||||
@PUT
|
@PUT
|
||||||
@Path("/{entitySetName}({entityId})/{path:.*}/$value")
|
@Path("/{entitySetName}({entityId})/{path:.*}/$value")
|
||||||
|
@ -1491,7 +1491,7 @@ public abstract class AbstractServices {
|
||||||
* @param path
|
* @param path
|
||||||
* @param format
|
* @param format
|
||||||
* @param changes
|
* @param changes
|
||||||
* @return
|
* @return response
|
||||||
*/
|
*/
|
||||||
@MERGE
|
@MERGE
|
||||||
@Path("/{entitySetName}({entityId})/{path:.*}")
|
@Path("/{entitySetName}({entityId})/{path:.*}")
|
||||||
|
@ -1519,7 +1519,7 @@ public abstract class AbstractServices {
|
||||||
* @param path
|
* @param path
|
||||||
* @param format
|
* @param format
|
||||||
* @param changes
|
* @param changes
|
||||||
* @return
|
* @return response
|
||||||
*/
|
*/
|
||||||
@PATCH
|
@PATCH
|
||||||
@Path("/{entitySetName}({entityId})/{path:.*}")
|
@Path("/{entitySetName}({entityId})/{path:.*}")
|
||||||
|
@ -1587,7 +1587,7 @@ public abstract class AbstractServices {
|
||||||
* @param path
|
* @param path
|
||||||
* @param format
|
* @param format
|
||||||
* @param changes
|
* @param changes
|
||||||
* @return
|
* @return response
|
||||||
*/
|
*/
|
||||||
@PUT
|
@PUT
|
||||||
@Path("/{entitySetName}({entityId})/{path:.*}")
|
@Path("/{entitySetName}({entityId})/{path:.*}")
|
||||||
|
@ -1650,7 +1650,7 @@ public abstract class AbstractServices {
|
||||||
* @param entityId
|
* @param entityId
|
||||||
* @param path
|
* @param path
|
||||||
* @param format
|
* @param format
|
||||||
* @return
|
* @return response
|
||||||
*/
|
*/
|
||||||
@DELETE
|
@DELETE
|
||||||
@Path("/{entitySetName}({entityId})/{path:.*}/$value")
|
@Path("/{entitySetName}({entityId})/{path:.*}/$value")
|
||||||
|
|
|
@ -28,9 +28,7 @@ import org.apache.olingo.commons.api.http.HttpMethod;
|
||||||
/**
|
/**
|
||||||
* Abstract representation of an OData request. Get instance by using factories.
|
* Abstract representation of an OData request. Get instance by using factories.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.communication.request.cud.v3.CUDRequestFactory
|
|
||||||
* @see org.apache.olingo.client.api.communication.request.cud.CUDRequestFactory
|
* @see org.apache.olingo.client.api.communication.request.cud.CUDRequestFactory
|
||||||
* @see org.apache.olingo.client.api.communication.request.batch.v3.BatchRequestFactory
|
|
||||||
* @see org.apache.olingo.client.api.communication.request.batch.BatchRequestFactory
|
* @see org.apache.olingo.client.api.communication.request.batch.BatchRequestFactory
|
||||||
* @see org.apache.olingo.client.api.communication.request.invoke.InvokeRequestFactory
|
* @see org.apache.olingo.client.api.communication.request.invoke.InvokeRequestFactory
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -33,7 +33,7 @@ import org.apache.olingo.client.api.communication.response.ODataReferenceAddingR
|
||||||
* If the request addresses an navigation property, which references a single entity, the reference will
|
* If the request addresses an navigation property, which references a single entity, the reference will
|
||||||
* be changed to the value provided by the request. [OData-Protocol 4.0 - 11.4.6.3]
|
* be changed to the value provided by the request. [OData-Protocol 4.0 - 11.4.6.3]
|
||||||
*/
|
*/
|
||||||
public interface ODataReferenceAddingRequest
|
public interface ODataReferenceAddingRequest extends ODataBasicRequest<ODataReferenceAddingResponse>,
|
||||||
extends ODataBasicRequest<ODataReferenceAddingResponse>, ODataBatchableRequest {
|
ODataBatchableRequest {
|
||||||
//No additional methods needed for now.
|
//No additional methods needed for now.
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ import org.apache.olingo.client.api.communication.request.batch.ODataBatchRespon
|
||||||
/**
|
/**
|
||||||
* This class implements a response to a batch request.
|
* This class implements a response to a batch request.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.communication.request.batch.CommonODataBatchRequest
|
* @see org.apache.olingo.client.api.communication.request.batch.ODataBatchRequest
|
||||||
*/
|
*/
|
||||||
public interface ODataBatchResponse extends ODataResponse {
|
public interface ODataBatchResponse extends ODataResponse {
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ package org.apache.olingo.client.api.communication.response;
|
||||||
* If the request was successful, the service response has status code 204 and
|
* If the request was successful, the service response has status code 204 and
|
||||||
* the body has to be empty.
|
* the body has to be empty.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.communication.request.cud.api.request.cud.v4.ODataReferenceAddingRequest
|
* @see org.apache.olingo.client.api.communication.request.cud.ODataReferenceAddingRequest
|
||||||
*/
|
*/
|
||||||
public interface ODataReferenceAddingResponse extends ODataResponse {
|
public interface ODataReferenceAddingResponse extends ODataResponse {
|
||||||
//No additional methods needed for now.
|
//No additional methods needed for now.
|
||||||
|
|
|
@ -175,7 +175,7 @@ public interface URIBuilder {
|
||||||
* @return current URIBuilder instance
|
* @return current URIBuilder instance
|
||||||
* @see QueryOption#FILTER
|
* @see QueryOption#FILTER
|
||||||
* @see URIFilter
|
* @see URIFilter
|
||||||
* @see org.apache.olingo.client.api.uri.CommonFilterFactory
|
* @see org.apache.olingo.client.api.uri.FilterFactory
|
||||||
*/
|
*/
|
||||||
URIBuilder filter(URIFilter filter);
|
URIBuilder filter(URIFilter filter);
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,7 @@ package org.apache.olingo.client.api.uri;
|
||||||
/**
|
/**
|
||||||
* Interface for any available filter; obtain instances via <tt>FilterFactory</tt>.
|
* Interface for any available filter; obtain instances via <tt>FilterFactory</tt>.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.uri.CommonFilterFactory
|
* @see org.apache.olingo.client.api.uri.FilterFactory
|
||||||
*/
|
*/
|
||||||
public interface URIFilter {
|
public interface URIFilter {
|
||||||
|
|
||||||
|
|
|
@ -47,9 +47,7 @@ import org.apache.olingo.commons.api.http.HttpMethod;
|
||||||
/**
|
/**
|
||||||
* Abstract representation of an OData request. Get instance by using factories.
|
* Abstract representation of an OData request. Get instance by using factories.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.communication.request.cud.v3.CUDRequestFactory
|
|
||||||
* @see org.apache.olingo.client.api.communication.request.cud.CUDRequestFactory
|
* @see org.apache.olingo.client.api.communication.request.cud.CUDRequestFactory
|
||||||
* @see org.apache.olingo.client.api.communication.request.batch.v3.BatchRequestFactory
|
|
||||||
* @see org.apache.olingo.client.api.communication.request.batch.BatchRequestFactory
|
* @see org.apache.olingo.client.api.communication.request.batch.BatchRequestFactory
|
||||||
* @see org.apache.olingo.client.api.communication.request.invoke.InvokeRequestFactory
|
* @see org.apache.olingo.client.api.communication.request.invoke.InvokeRequestFactory
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.apache.olingo.client.api.uri.FilterArg;
|
||||||
/**
|
/**
|
||||||
* Filter property path; obtain instances via <tt>FilterArgFactory</tt>.
|
* Filter property path; obtain instances via <tt>FilterArgFactory</tt>.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.uri.CommonFilterArgFactory
|
* @see org.apache.olingo.client.api.uri.FilterArgFactory
|
||||||
*/
|
*/
|
||||||
public class FilterConst implements FilterArg {
|
public class FilterConst implements FilterArg {
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.apache.olingo.client.api.uri.FilterArg;
|
||||||
/**
|
/**
|
||||||
* Filter value literals; obtain instances via <tt>FilterArgFactory</tt>.
|
* Filter value literals; obtain instances via <tt>FilterArgFactory</tt>.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.uri.v3.FilterArgFactory
|
* @see org.apache.olingo.client.api.uri.FilterArgFactory
|
||||||
*/
|
*/
|
||||||
public class FilterLiteral implements FilterArg {
|
public class FilterLiteral implements FilterArg {
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.apache.olingo.client.api.uri.FilterArg;
|
||||||
/**
|
/**
|
||||||
* Filter property path; obtain instances via <tt>FilterArgFactory</tt>.
|
* Filter property path; obtain instances via <tt>FilterArgFactory</tt>.
|
||||||
*
|
*
|
||||||
* @see org.apache.olingo.client.api.uri.CommonFilterArgFactory
|
* @see org.apache.olingo.client.api.uri.FilterArgFactory
|
||||||
*/
|
*/
|
||||||
public class FilterProperty implements FilterArg {
|
public class FilterProperty implements FilterArg {
|
||||||
|
|
||||||
|
|
|
@ -179,7 +179,6 @@ public final class URIUtils {
|
||||||
/**
|
/**
|
||||||
* Turns primitive values into their respective URI representation.
|
* Turns primitive values into their respective URI representation.
|
||||||
*
|
*
|
||||||
* @param version OData protocol version
|
|
||||||
* @param obj primitive value
|
* @param obj primitive value
|
||||||
* @return URI representation
|
* @return URI representation
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -23,7 +23,6 @@ import java.util.Map;
|
||||||
/**
|
/**
|
||||||
* OData complex property value.
|
* OData complex property value.
|
||||||
*
|
*
|
||||||
* @param <OP> The actual ODataProperty interface.
|
|
||||||
*/
|
*/
|
||||||
public interface ODataComplexValue extends ODataValue, ODataLinked, ODataAnnotatable, Iterable<ODataProperty> {
|
public interface ODataComplexValue extends ODataValue, ODataLinked, ODataAnnotatable, Iterable<ODataProperty> {
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,6 @@ public class ODataInlineEntity extends ODataLink {
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*
|
*
|
||||||
* @param version OData service version.
|
|
||||||
* @param uri edit link.
|
* @param uri edit link.
|
||||||
* @param type type.
|
* @param type type.
|
||||||
* @param title title.
|
* @param title title.
|
||||||
|
@ -45,7 +44,6 @@ public class ODataInlineEntity extends ODataLink {
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*
|
*
|
||||||
* @param version OData service version.
|
|
||||||
* @param baseURI base URI.
|
* @param baseURI base URI.
|
||||||
* @param href href.
|
* @param href href.
|
||||||
* @param type type.
|
* @param type type.
|
||||||
|
|
|
@ -105,7 +105,6 @@ public class ODataLink extends ODataItem implements ODataAnnotatable {
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*
|
*
|
||||||
* @param version OData service version.
|
|
||||||
* @param uri URI.
|
* @param uri URI.
|
||||||
* @param type type.
|
* @param type type.
|
||||||
* @param title title.
|
* @param title title.
|
||||||
|
|
|
@ -73,7 +73,6 @@ public enum ODataLinkType {
|
||||||
* Gets
|
* Gets
|
||||||
* <code>LinkType</code> instance from the given rel and type.
|
* <code>LinkType</code> instance from the given rel and type.
|
||||||
*
|
*
|
||||||
* @param version OData protocol version.
|
|
||||||
* @param rel rel.
|
* @param rel rel.
|
||||||
* @param type type.
|
* @param type type.
|
||||||
* @return <code>ODataLinkType</code> object.
|
* @return <code>ODataLinkType</code> object.
|
||||||
|
|
|
@ -32,6 +32,8 @@ public interface EdmOperation extends EdmType, EdmAnnotatable {
|
||||||
EdmParameter getParameter(String name);
|
EdmParameter getParameter(String name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* A list of all parameter names. If this is a bound action or function the first parameter name in the list is the
|
||||||
|
* binding parameter
|
||||||
* @return a list of all parameter names
|
* @return a list of all parameter names
|
||||||
*/
|
*/
|
||||||
List<String> getParameterNames();
|
List<String> getParameterNames();
|
||||||
|
|
|
@ -81,7 +81,6 @@ public enum EdmPrimitiveTypeKind {
|
||||||
/**
|
/**
|
||||||
* Gets <tt>EdmPrimitiveTypeKind</tt> from a full-qualified type name, for the given OData protocol version.
|
* Gets <tt>EdmPrimitiveTypeKind</tt> from a full-qualified type name, for the given OData protocol version.
|
||||||
*
|
*
|
||||||
* @param version OData protocol version.
|
|
||||||
* @param fqn full-qualified type name.
|
* @param fqn full-qualified type name.
|
||||||
* @return <tt>EdmPrimitiveTypeKind</tt> object.
|
* @return <tt>EdmPrimitiveTypeKind</tt> object.
|
||||||
*/
|
*/
|
||||||
|
@ -93,7 +92,6 @@ public enum EdmPrimitiveTypeKind {
|
||||||
* Gets <tt>EdmPrimitiveTypeKind</tt> from a full type expression (as <tt>Edm.Int32</tt>), for the given OData
|
* Gets <tt>EdmPrimitiveTypeKind</tt> from a full type expression (as <tt>Edm.Int32</tt>), for the given OData
|
||||||
* protocol version.
|
* protocol version.
|
||||||
*
|
*
|
||||||
* @param version OData protocol version.
|
|
||||||
* @param fqn string value type.
|
* @param fqn string value type.
|
||||||
* @return <tt>EdmPrimitiveTypeKind</tt> object.
|
* @return <tt>EdmPrimitiveTypeKind</tt> object.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -23,6 +23,6 @@ package org.apache.olingo.commons.api.edm.constants;
|
||||||
*/
|
*/
|
||||||
public enum EdmTypeKind {
|
public enum EdmTypeKind {
|
||||||
|
|
||||||
UNDEFINED, PRIMITIVE, ENUM, DEFINITION, COMPLEX, ENTITY, NAVIGATION, ACTION, FUNCTION, SYSTEM
|
PRIMITIVE, ENUM, DEFINITION, COMPLEX, ENTITY, NAVIGATION, ACTION, FUNCTION
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -131,7 +131,7 @@ public class Schema extends AbstractEdmItem implements Annotatable{
|
||||||
/**
|
/**
|
||||||
* All actions with the given name
|
* All actions with the given name
|
||||||
* @param name
|
* @param name
|
||||||
* @return
|
* @return a list of actions
|
||||||
*/
|
*/
|
||||||
public List<Action> getActions(final String name) {
|
public List<Action> getActions(final String name) {
|
||||||
return getAllByName(name, getActions());
|
return getAllByName(name, getActions());
|
||||||
|
@ -149,7 +149,7 @@ public class Schema extends AbstractEdmItem implements Annotatable{
|
||||||
/**
|
/**
|
||||||
* All functions with the given name
|
* All functions with the given name
|
||||||
* @param name
|
* @param name
|
||||||
* @return
|
* @return a list of functions
|
||||||
*/
|
*/
|
||||||
public List<Function> getFunctions(final String name) {
|
public List<Function> getFunctions(final String name) {
|
||||||
return getAllByName(name, getFunctions());
|
return getAllByName(name, getFunctions());
|
||||||
|
|
|
@ -57,7 +57,6 @@ public enum ODataFormat {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets format as {@link ContentType}.
|
* Gets format as {@link ContentType}.
|
||||||
* @param version OData service version.
|
|
||||||
* @return format as ContentType.
|
* @return format as ContentType.
|
||||||
*/
|
*/
|
||||||
public ContentType getContentType() {
|
public ContentType getContentType() {
|
||||||
|
|
|
@ -56,14 +56,14 @@ public class JsonDeltaDeserializer extends JsonDeserializer {
|
||||||
delta.setBaseURI(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA));
|
delta.setBaseURI(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonCount)) {
|
if (tree.hasNonNull(Constants.JSON_COUNT)) {
|
||||||
delta.setCount(tree.get(jsonCount).asInt());
|
delta.setCount(tree.get(Constants.JSON_COUNT).asInt());
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonNextLink)) {
|
if (tree.hasNonNull(Constants.JSON_NEXT_LINK)) {
|
||||||
delta.setNext(URI.create(tree.get(jsonNextLink).textValue()));
|
delta.setNext(URI.create(tree.get(Constants.JSON_NEXT_LINK).textValue()));
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonDeltaLink)) {
|
if (tree.hasNonNull(Constants.JSON_DELTA_LINK)) {
|
||||||
delta.setDeltaLink(URI.create(tree.get(jsonDeltaLink).textValue()));
|
delta.setDeltaLink(URI.create(tree.get(Constants.JSON_DELTA_LINK).textValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(Constants.VALUE)) {
|
if (tree.hasNonNull(Constants.VALUE)) {
|
||||||
|
|
|
@ -72,36 +72,6 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
|
|
||||||
protected final boolean serverMode;
|
protected final boolean serverMode;
|
||||||
|
|
||||||
protected String jsonType = Constants.JSON_TYPE;
|
|
||||||
|
|
||||||
protected String jsonId = Constants.JSON_ID;
|
|
||||||
|
|
||||||
protected String jsonETag = Constants.JSON_ETAG;
|
|
||||||
|
|
||||||
protected String jsonReadLink = Constants.JSON_READ_LINK;
|
|
||||||
|
|
||||||
protected String jsonEditLink = Constants.JSON_EDIT_LINK;
|
|
||||||
|
|
||||||
protected String jsonMediaEditLink = Constants.JSON_MEDIA_EDIT_LINK;
|
|
||||||
|
|
||||||
protected String jsonMediaReadLink = Constants.JSON_MEDIA_READ_LINK;
|
|
||||||
|
|
||||||
protected String jsonMediaContentType = Constants.JSON_MEDIA_CONTENT_TYPE;
|
|
||||||
|
|
||||||
protected String jsonMediaETag = Constants.JSON_MEDIA_ETAG;
|
|
||||||
|
|
||||||
protected String jsonAssociationLink = Constants.JSON_ASSOCIATION_LINK;
|
|
||||||
|
|
||||||
protected String jsonNavigationLink = Constants.JSON_NAVIGATION_LINK;
|
|
||||||
|
|
||||||
protected String jsonCount = Constants.JSON_COUNT;
|
|
||||||
|
|
||||||
protected String jsonNextLink = Constants.JSON_NEXT_LINK;
|
|
||||||
|
|
||||||
protected String jsonDeltaLink = Constants.JSON_DELTA_LINK;
|
|
||||||
|
|
||||||
protected String jsonError = Constants.JSON_ERROR;
|
|
||||||
|
|
||||||
private JsonGeoValueDeserializer geoDeserializer;
|
private JsonGeoValueDeserializer geoDeserializer;
|
||||||
|
|
||||||
private JsonParser parser;
|
private JsonParser parser;
|
||||||
|
@ -163,7 +133,7 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
private void clientLinks(final Map.Entry<String, JsonNode> field, final Linked linked, final Set<String> toRemove,
|
private void clientLinks(final Map.Entry<String, JsonNode> field, final Linked linked, final Set<String> toRemove,
|
||||||
final JsonNode tree, final ObjectCodec codec) throws IOException {
|
final JsonNode tree, final ObjectCodec codec) throws IOException {
|
||||||
|
|
||||||
if (field.getKey().endsWith(jsonNavigationLink)) {
|
if (field.getKey().endsWith(Constants.JSON_NAVIGATION_LINK)) {
|
||||||
final LinkImpl link = new LinkImpl();
|
final LinkImpl link = new LinkImpl();
|
||||||
link.setTitle(getTitle(field));
|
link.setTitle(getTitle(field));
|
||||||
link.setRel(Constants.NS_NAVIGATION_LINK_REL + getTitle(field));
|
link.setRel(Constants.NS_NAVIGATION_LINK_REL + getTitle(field));
|
||||||
|
@ -176,8 +146,8 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
linked.getNavigationLinks().add(link);
|
linked.getNavigationLinks().add(link);
|
||||||
|
|
||||||
toRemove.add(field.getKey());
|
toRemove.add(field.getKey());
|
||||||
toRemove.add(setInline(field.getKey(), jsonNavigationLink, tree, codec, link));
|
toRemove.add(setInline(field.getKey(), Constants.JSON_NAVIGATION_LINK, tree, codec, link));
|
||||||
} else if (field.getKey().endsWith(jsonAssociationLink)) {
|
} else if (field.getKey().endsWith(Constants.JSON_ASSOCIATION_LINK)) {
|
||||||
final LinkImpl link = new LinkImpl();
|
final LinkImpl link = new LinkImpl();
|
||||||
link.setTitle(getTitle(field));
|
link.setTitle(getTitle(field));
|
||||||
link.setRel(Constants.NS_ASSOCIATION_LINK_REL + getTitle(field));
|
link.setRel(Constants.NS_ASSOCIATION_LINK_REL + getTitle(field));
|
||||||
|
@ -193,7 +163,7 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
final JsonNode tree, final ObjectCodec codec) throws IOException {
|
final JsonNode tree, final ObjectCodec codec) throws IOException {
|
||||||
|
|
||||||
if (field.getKey().endsWith(Constants.JSON_BIND_LINK_SUFFIX)
|
if (field.getKey().endsWith(Constants.JSON_BIND_LINK_SUFFIX)
|
||||||
|| field.getKey().endsWith(jsonNavigationLink)) {
|
|| field.getKey().endsWith(Constants.JSON_NAVIGATION_LINK)) {
|
||||||
|
|
||||||
if (field.getValue().isValueNode()) {
|
if (field.getValue().isValueNode()) {
|
||||||
final String suffix = field.getKey().replaceAll("^.*@", "@");
|
final String suffix = field.getKey().replaceAll("^.*@", "@");
|
||||||
|
@ -280,7 +250,7 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
if (annotatable != null) {
|
if (annotatable != null) {
|
||||||
annotatable.getAnnotations().add(entityAnnot);
|
annotatable.getAnnotations().add(entityAnnot);
|
||||||
}
|
}
|
||||||
} else if (type == null && field.getKey().endsWith(getJSONAnnotation(jsonType))) {
|
} else if (type == null && field.getKey().endsWith(getJSONAnnotation(Constants.JSON_TYPE))) {
|
||||||
type = field.getValue().asText();
|
type = field.getValue().asText();
|
||||||
} else if (annotation == null && customAnnotation.matches() && !"odata".equals(customAnnotation.group(2))) {
|
} else if (annotation == null && customAnnotation.matches() && !"odata".equals(customAnnotation.group(2))) {
|
||||||
annotation = new AnnotationImpl();
|
annotation = new AnnotationImpl();
|
||||||
|
@ -354,8 +324,8 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
values.add(child.asText());
|
values.add(child.asText());
|
||||||
}
|
}
|
||||||
} else if (child.isContainerNode()) {
|
} else if (child.isContainerNode()) {
|
||||||
if (child.has(jsonType)) {
|
if (child.has(Constants.JSON_TYPE)) {
|
||||||
((ObjectNode) child).remove(jsonType);
|
((ObjectNode) child).remove(Constants.JSON_TYPE);
|
||||||
}
|
}
|
||||||
final Object value = fromComplex((ObjectNode) child, codec);
|
final Object value = fromComplex((ObjectNode) child, codec);
|
||||||
valueType = ValueType.COLLECTION_COMPLEX;
|
valueType = ValueType.COLLECTION_COMPLEX;
|
||||||
|
@ -387,9 +357,9 @@ public class JsonDeserializer implements ODataDeserializer {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COMPLEX:
|
case COMPLEX:
|
||||||
if (node.has(jsonType)) {
|
if (node.has(Constants.JSON_TYPE)) {
|
||||||
valuable.setType(node.get(jsonType).asText());
|
valuable.setType(node.get(Constants.JSON_TYPE).asText());
|
||||||
((ObjectNode) node).remove(jsonType);
|
((ObjectNode) node).remove(Constants.JSON_TYPE);
|
||||||
}
|
}
|
||||||
final Object value = fromComplex((ObjectNode) node, codec);
|
final Object value = fromComplex((ObjectNode) node, codec);
|
||||||
valuable.setValue(ValueType.COMPLEX, value);
|
valuable.setValue(ValueType.COMPLEX, value);
|
||||||
|
|
|
@ -91,56 +91,57 @@ public class JsonEntityDeserializer extends JsonDeserializer {
|
||||||
metadataETag = null;
|
metadataETag = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonETag)) {
|
if (tree.hasNonNull(Constants.JSON_ETAG)) {
|
||||||
entity.setETag(tree.get(jsonETag).textValue());
|
entity.setETag(tree.get(Constants.JSON_ETAG).textValue());
|
||||||
tree.remove(jsonETag);
|
tree.remove(Constants.JSON_ETAG);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonType)) {
|
if (tree.hasNonNull(Constants.JSON_TYPE)) {
|
||||||
entity.setType(new EdmTypeInfo.Builder().setTypeExpression(tree.get(jsonType).textValue()).build().internal());
|
entity.setType(new EdmTypeInfo.Builder().setTypeExpression(tree.get(Constants.JSON_TYPE).textValue()).build()
|
||||||
tree.remove(jsonType);
|
.internal());
|
||||||
|
tree.remove(Constants.JSON_TYPE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonId)) {
|
if (tree.hasNonNull(Constants.JSON_ID)) {
|
||||||
entity.setId(URI.create(tree.get(jsonId).textValue()));
|
entity.setId(URI.create(tree.get(Constants.JSON_ID).textValue()));
|
||||||
tree.remove(jsonId);
|
tree.remove(Constants.JSON_ID);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonReadLink)) {
|
if (tree.hasNonNull(Constants.JSON_READ_LINK)) {
|
||||||
final LinkImpl link = new LinkImpl();
|
final LinkImpl link = new LinkImpl();
|
||||||
link.setRel(Constants.SELF_LINK_REL);
|
link.setRel(Constants.SELF_LINK_REL);
|
||||||
link.setHref(tree.get(jsonReadLink).textValue());
|
link.setHref(tree.get(Constants.JSON_READ_LINK).textValue());
|
||||||
entity.setSelfLink(link);
|
entity.setSelfLink(link);
|
||||||
|
|
||||||
tree.remove(jsonReadLink);
|
tree.remove(Constants.JSON_READ_LINK);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonEditLink)) {
|
if (tree.hasNonNull(Constants.JSON_EDIT_LINK)) {
|
||||||
final LinkImpl link = new LinkImpl();
|
final LinkImpl link = new LinkImpl();
|
||||||
if (serverMode) {
|
if (serverMode) {
|
||||||
link.setRel(Constants.EDIT_LINK_REL);
|
link.setRel(Constants.EDIT_LINK_REL);
|
||||||
}
|
}
|
||||||
link.setHref(tree.get(jsonEditLink).textValue());
|
link.setHref(tree.get(Constants.JSON_EDIT_LINK).textValue());
|
||||||
entity.setEditLink(link);
|
entity.setEditLink(link);
|
||||||
|
|
||||||
tree.remove(jsonEditLink);
|
tree.remove(Constants.JSON_EDIT_LINK);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonMediaReadLink)) {
|
if (tree.hasNonNull(Constants.JSON_MEDIA_READ_LINK)) {
|
||||||
entity.setMediaContentSource(URI.create(tree.get(jsonMediaReadLink).textValue()));
|
entity.setMediaContentSource(URI.create(tree.get(Constants.JSON_MEDIA_READ_LINK).textValue()));
|
||||||
tree.remove(jsonMediaReadLink);
|
tree.remove(Constants.JSON_MEDIA_READ_LINK);
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonMediaEditLink)) {
|
if (tree.hasNonNull(Constants.JSON_MEDIA_EDIT_LINK)) {
|
||||||
entity.setMediaContentSource(URI.create(tree.get(jsonMediaEditLink).textValue()));
|
entity.setMediaContentSource(URI.create(tree.get(Constants.JSON_MEDIA_EDIT_LINK).textValue()));
|
||||||
tree.remove(jsonMediaEditLink);
|
tree.remove(Constants.JSON_MEDIA_EDIT_LINK);
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonMediaContentType)) {
|
if (tree.hasNonNull(Constants.JSON_MEDIA_CONTENT_TYPE)) {
|
||||||
entity.setMediaContentType(tree.get(jsonMediaContentType).textValue());
|
entity.setMediaContentType(tree.get(Constants.JSON_MEDIA_CONTENT_TYPE).textValue());
|
||||||
tree.remove(jsonMediaContentType);
|
tree.remove(Constants.JSON_MEDIA_CONTENT_TYPE);
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonMediaETag)) {
|
if (tree.hasNonNull(Constants.JSON_MEDIA_ETAG)) {
|
||||||
entity.setMediaETag(tree.get(jsonMediaETag).textValue());
|
entity.setMediaETag(tree.get(Constants.JSON_MEDIA_ETAG).textValue());
|
||||||
tree.remove(jsonMediaETag);
|
tree.remove(Constants.JSON_MEDIA_ETAG);
|
||||||
}
|
}
|
||||||
|
|
||||||
final Set<String> toRemove = new HashSet<String>();
|
final Set<String> toRemove = new HashSet<String>();
|
||||||
|
@ -151,7 +152,7 @@ public class JsonEntityDeserializer extends JsonDeserializer {
|
||||||
final Matcher customAnnotation = CUSTOM_ANNOTATION.matcher(field.getKey());
|
final Matcher customAnnotation = CUSTOM_ANNOTATION.matcher(field.getKey());
|
||||||
|
|
||||||
links(field, entity, toRemove, tree, parser.getCodec());
|
links(field, entity, toRemove, tree, parser.getCodec());
|
||||||
if (field.getKey().endsWith(getJSONAnnotation(jsonMediaEditLink))) {
|
if (field.getKey().endsWith(getJSONAnnotation(Constants.JSON_MEDIA_EDIT_LINK))) {
|
||||||
final LinkImpl link = new LinkImpl();
|
final LinkImpl link = new LinkImpl();
|
||||||
link.setTitle(getTitle(field));
|
link.setTitle(getTitle(field));
|
||||||
link.setRel(Constants.NS_MEDIA_EDIT_LINK_REL + getTitle(field));
|
link.setRel(Constants.NS_MEDIA_EDIT_LINK_REL + getTitle(field));
|
||||||
|
@ -159,14 +160,15 @@ public class JsonEntityDeserializer extends JsonDeserializer {
|
||||||
link.setType(ODataLinkType.MEDIA_EDIT.toString());
|
link.setType(ODataLinkType.MEDIA_EDIT.toString());
|
||||||
entity.getMediaEditLinks().add(link);
|
entity.getMediaEditLinks().add(link);
|
||||||
|
|
||||||
if (tree.has(link.getTitle() + getJSONAnnotation(jsonMediaETag))) {
|
if (tree.has(link.getTitle() + getJSONAnnotation(Constants.JSON_MEDIA_ETAG))) {
|
||||||
link.setMediaETag(tree.get(link.getTitle() + getJSONAnnotation(jsonMediaETag)).asText());
|
link.setMediaETag(tree.get(link.getTitle() + getJSONAnnotation(Constants.JSON_MEDIA_ETAG)).asText());
|
||||||
toRemove.add(link.getTitle() + getJSONAnnotation(jsonMediaETag));
|
toRemove.add(link.getTitle() + getJSONAnnotation(Constants.JSON_MEDIA_ETAG));
|
||||||
}
|
}
|
||||||
|
|
||||||
toRemove.add(field.getKey());
|
toRemove.add(field.getKey());
|
||||||
toRemove.add(setInline(field.getKey(), getJSONAnnotation(jsonMediaEditLink), tree, parser.getCodec(), link));
|
toRemove.add(setInline(field.getKey(), getJSONAnnotation(Constants.JSON_MEDIA_EDIT_LINK), tree, parser
|
||||||
} else if (field.getKey().endsWith(getJSONAnnotation(jsonMediaContentType))) {
|
.getCodec(), link));
|
||||||
|
} else if (field.getKey().endsWith(getJSONAnnotation(Constants.JSON_MEDIA_CONTENT_TYPE))) {
|
||||||
final String linkTitle = getTitle(field);
|
final String linkTitle = getTitle(field);
|
||||||
for (Link link : entity.getMediaEditLinks()) {
|
for (Link link : entity.getMediaEditLinks()) {
|
||||||
if (linkTitle.equals(link.getTitle())) {
|
if (linkTitle.equals(link.getTitle())) {
|
||||||
|
|
|
@ -79,17 +79,17 @@ public class JsonEntitySetDeserializer extends JsonDeserializer {
|
||||||
metadataETag = null;
|
metadataETag = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(jsonCount)) {
|
if (tree.hasNonNull(Constants.JSON_COUNT)) {
|
||||||
entitySet.setCount(tree.get(jsonCount).asInt());
|
entitySet.setCount(tree.get(Constants.JSON_COUNT).asInt());
|
||||||
tree.remove(jsonCount);
|
tree.remove(Constants.JSON_COUNT);
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonNextLink)) {
|
if (tree.hasNonNull(Constants.JSON_NEXT_LINK)) {
|
||||||
entitySet.setNext(URI.create(tree.get(jsonNextLink).textValue()));
|
entitySet.setNext(URI.create(tree.get(Constants.JSON_NEXT_LINK).textValue()));
|
||||||
tree.remove(jsonNextLink);
|
tree.remove(Constants.JSON_NEXT_LINK);
|
||||||
}
|
}
|
||||||
if (tree.hasNonNull(jsonDeltaLink)) {
|
if (tree.hasNonNull(Constants.JSON_DELTA_LINK)) {
|
||||||
entitySet.setDeltaLink(URI.create(tree.get(jsonDeltaLink).textValue()));
|
entitySet.setDeltaLink(URI.create(tree.get(Constants.JSON_DELTA_LINK).textValue()));
|
||||||
tree.remove(jsonDeltaLink);
|
tree.remove(Constants.JSON_DELTA_LINK);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.hasNonNull(Constants.VALUE)) {
|
if (tree.hasNonNull(Constants.VALUE)) {
|
||||||
|
|
|
@ -43,8 +43,8 @@ public class JsonODataErrorDeserializer extends JsonDeserializer {
|
||||||
final ODataError error = new ODataError();
|
final ODataError error = new ODataError();
|
||||||
|
|
||||||
final ObjectNode tree = parser.getCodec().readTree(parser);
|
final ObjectNode tree = parser.getCodec().readTree(parser);
|
||||||
if (tree.has(jsonError)) {
|
if (tree.has(Constants.JSON_ERROR)) {
|
||||||
final JsonNode errorNode = tree.get(jsonError);
|
final JsonNode errorNode = tree.get(Constants.JSON_ERROR);
|
||||||
|
|
||||||
if (errorNode.has(Constants.ERROR_CODE)) {
|
if (errorNode.has(Constants.ERROR_CODE)) {
|
||||||
error.setCode(errorNode.get(Constants.ERROR_CODE).textValue());
|
error.setCode(errorNode.get(Constants.ERROR_CODE).textValue());
|
||||||
|
|
|
@ -75,9 +75,10 @@ public class JsonPropertyDeserializer extends JsonDeserializer {
|
||||||
contextURL = null;
|
contextURL = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.has(jsonType)) {
|
if (tree.has(Constants.JSON_TYPE)) {
|
||||||
property.setType(new EdmTypeInfo.Builder().setTypeExpression(tree.get(jsonType).textValue()).build().internal());
|
property.setType(new EdmTypeInfo.Builder().setTypeExpression(tree.get(Constants.JSON_TYPE).textValue()).build()
|
||||||
tree.remove(jsonType);
|
.internal());
|
||||||
|
tree.remove(Constants.JSON_TYPE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tree.has(Constants.JSON_NULL) && tree.get(Constants.JSON_NULL).asBoolean()) {
|
if (tree.has(Constants.JSON_NULL) && tree.get(Constants.JSON_NULL).asBoolean()) {
|
||||||
|
|
|
@ -45,7 +45,9 @@ public class DeserializerException extends ODataTranslatedException {
|
||||||
/** parameter: navigationPropertyName */NAVIGATION_PROPERTY_NOT_FOUND,
|
/** parameter: navigationPropertyName */NAVIGATION_PROPERTY_NOT_FOUND,
|
||||||
/** parameter: annotationName */INVALID_ANNOTATION_TYPE,
|
/** parameter: annotationName */INVALID_ANNOTATION_TYPE,
|
||||||
/** parameter: annotationName */INVALID_NULL_ANNOTATION,
|
/** parameter: annotationName */INVALID_NULL_ANNOTATION,
|
||||||
/** parameter: binding link */INVALID_ENTITY_BINDING_LINK;
|
/** parameter: binding link */INVALID_ENTITY_BINDING_LINK,
|
||||||
|
/** parameter: action parameter name */INVALID_ACTION_PARAMETER_TYPE,
|
||||||
|
/** parameter: parameterName */ INVALID_NULL_PARAMETER;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getKey() {
|
public String getKey() {
|
||||||
|
|
|
@ -53,7 +53,7 @@ public interface FixedFormatSerializer {
|
||||||
* Serializes a batch response
|
* Serializes a batch response
|
||||||
* @param batchResponses
|
* @param batchResponses
|
||||||
* @param boundary
|
* @param boundary
|
||||||
* @return
|
* @return response as an input stream
|
||||||
* @throws BatchSerializerException
|
* @throws BatchSerializerException
|
||||||
*/
|
*/
|
||||||
InputStream batchResponse(List<ODataResponsePart> batchResponses, String boundary) throws BatchSerializerException;
|
InputStream batchResponse(List<ODataResponsePart> batchResponses, String boundary) throws BatchSerializerException;
|
||||||
|
|
|
@ -186,7 +186,7 @@ public class ODataJsonDeserializer implements ODataDeserializer {
|
||||||
public List<Parameter> actionParameters(InputStream stream, final EdmAction edmAction) throws DeserializerException {
|
public List<Parameter> actionParameters(InputStream stream, final EdmAction edmAction) throws DeserializerException {
|
||||||
try {
|
try {
|
||||||
ObjectNode tree = parseJsonTree(stream);
|
ObjectNode tree = parseJsonTree(stream);
|
||||||
ArrayList<Parameter> parameters = new ArrayList<Parameter>();
|
List<Parameter> parameters = new ArrayList<Parameter>();
|
||||||
consumeParameters(edmAction, tree, parameters);
|
consumeParameters(edmAction, tree, parameters);
|
||||||
assertJsonNodeIsEmpty(tree);
|
assertJsonNodeIsEmpty(tree);
|
||||||
return parameters;
|
return parameters;
|
||||||
|
@ -211,30 +211,51 @@ public class ODataJsonDeserializer implements ODataDeserializer {
|
||||||
return tree;
|
return tree;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void consumeParameters(final EdmAction edmAction, ObjectNode node, ArrayList<Parameter> parameters)
|
private void consumeParameters(final EdmAction edmAction, ObjectNode node, List<Parameter> parameters)
|
||||||
throws DeserializerException {
|
throws DeserializerException {
|
||||||
for (final String name : edmAction.getParameterNames()) {
|
List<String> parameterNames = edmAction.getParameterNames();
|
||||||
|
if (edmAction.isBound()) {
|
||||||
|
// The binding parameter must not occur in the payload.
|
||||||
|
parameterNames = parameterNames.subList(1, parameterNames.size());
|
||||||
|
}
|
||||||
|
for (final String name : parameterNames) {
|
||||||
final EdmParameter edmParameter = edmAction.getParameter(name);
|
final EdmParameter edmParameter = edmAction.getParameter(name);
|
||||||
ParameterImpl parameter = new ParameterImpl();
|
ParameterImpl parameter = new ParameterImpl();
|
||||||
parameter.setName(name);
|
parameter.setName(name);
|
||||||
JsonNode jsonNode = node.get(name);
|
JsonNode jsonNode = node.get(name);
|
||||||
if (jsonNode == null) {
|
|
||||||
|
switch (edmParameter.getType().getKind()) {
|
||||||
|
case PRIMITIVE:
|
||||||
|
case DEFINITION:
|
||||||
|
case ENUM:
|
||||||
|
if (jsonNode == null || jsonNode.isNull()) {
|
||||||
if (!edmParameter.isNullable()) {
|
if (!edmParameter.isNullable()) {
|
||||||
// TODO: new message key.
|
|
||||||
throw new DeserializerException("Non-nullable parameter not present or null",
|
throw new DeserializerException("Non-nullable parameter not present or null",
|
||||||
DeserializerException.MessageKeys.INVALID_NULL_PROPERTY, name);
|
DeserializerException.MessageKeys.INVALID_NULL_PARAMETER, name);
|
||||||
}
|
}
|
||||||
|
if (edmParameter.isCollection()) {
|
||||||
|
throw new DeserializerException("Collection must not be null for parameter: " + name,
|
||||||
|
DeserializerException.MessageKeys.INVALID_NULL_PARAMETER, name);
|
||||||
|
}
|
||||||
|
parameter.setValue(ValueType.PRIMITIVE, null);
|
||||||
} else {
|
} else {
|
||||||
Property consumePropertyNode =
|
Property consumePropertyNode =
|
||||||
consumePropertyNode(edmParameter.getName(), edmParameter.getType(), edmParameter.isCollection(),
|
consumePropertyNode(edmParameter.getName(), edmParameter.getType(), edmParameter.isCollection(),
|
||||||
edmParameter.isNullable(), edmParameter.getMaxLength(), edmParameter.getPrecision(), edmParameter
|
edmParameter.isNullable(), edmParameter.getMaxLength(), edmParameter.getPrecision(), edmParameter
|
||||||
.getScale(),
|
.getScale(), true, edmParameter.getMapping(), jsonNode);
|
||||||
true, edmParameter.getMapping(),
|
|
||||||
jsonNode);
|
|
||||||
parameter.setValue(consumePropertyNode.getValueType(), consumePropertyNode.getValue());
|
parameter.setValue(consumePropertyNode.getValueType(), consumePropertyNode.getValue());
|
||||||
parameters.add(parameter);
|
parameters.add(parameter);
|
||||||
node.remove(name);
|
node.remove(name);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case COMPLEX:
|
||||||
|
case ENTITY:
|
||||||
|
throw new DeserializerException("Entity an complex parameters currently not Implemented",
|
||||||
|
DeserializerException.MessageKeys.NOT_IMPLEMENTED);
|
||||||
|
default:
|
||||||
|
throw new DeserializerException("Invalid type kind " + edmParameter.getType().getKind().toString()
|
||||||
|
+ " for action parameter: " + name, DeserializerException.MessageKeys.INVALID_ACTION_PARAMETER_TYPE, name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -147,9 +147,12 @@ public class ODataJsonSerializer implements ODataSerializer {
|
||||||
json.writeNumberField(Constants.JSON_COUNT, entitySet.getCount());
|
json.writeNumberField(Constants.JSON_COUNT, entitySet.getCount());
|
||||||
}
|
}
|
||||||
json.writeFieldName(Constants.VALUE);
|
json.writeFieldName(Constants.VALUE);
|
||||||
writeEntitySet(metadata, entityType, entitySet, options == null ? null : options.getExpand(),
|
if(options == null) {
|
||||||
options == null ? null : options.getSelect(),
|
writeEntitySet(metadata, entityType, entitySet, null, null, false, json);
|
||||||
options == null ? false : options.onlyReferences(), json);
|
} else {
|
||||||
|
writeEntitySet(metadata, entityType, entitySet,
|
||||||
|
options.getExpand(), options.getSelect(), options.onlyReferences(), json);
|
||||||
|
}
|
||||||
if (entitySet.getNext() != null) {
|
if (entitySet.getNext() != null) {
|
||||||
json.writeStringField(Constants.JSON_NEXT_LINK, entitySet.getNext().toASCIIString());
|
json.writeStringField(Constants.JSON_NEXT_LINK, entitySet.getNext().toASCIIString());
|
||||||
}
|
}
|
||||||
|
@ -242,7 +245,8 @@ public class ODataJsonSerializer implements ODataSerializer {
|
||||||
|
|
||||||
protected EdmEntityType resolveEntityType(ServiceMetadata metadata, EdmEntityType baseType,
|
protected EdmEntityType resolveEntityType(ServiceMetadata metadata, EdmEntityType baseType,
|
||||||
String derivedTypeName) throws SerializerException {
|
String derivedTypeName) throws SerializerException {
|
||||||
if (baseType.getFullQualifiedName().getFullQualifiedNameAsString().equals(derivedTypeName)) {
|
if (derivedTypeName == null ||
|
||||||
|
baseType.getFullQualifiedName().getFullQualifiedNameAsString().equals(derivedTypeName)) {
|
||||||
return baseType;
|
return baseType;
|
||||||
}
|
}
|
||||||
EdmEntityType derivedType = metadata.getEdm().getEntityType(new FullQualifiedName(derivedTypeName));
|
EdmEntityType derivedType = metadata.getEdm().getEntityType(new FullQualifiedName(derivedTypeName));
|
||||||
|
@ -265,7 +269,8 @@ public class ODataJsonSerializer implements ODataSerializer {
|
||||||
|
|
||||||
protected EdmComplexType resolveComplexType(ServiceMetadata metadata, EdmComplexType baseType,
|
protected EdmComplexType resolveComplexType(ServiceMetadata metadata, EdmComplexType baseType,
|
||||||
String derivedTypeName) throws SerializerException {
|
String derivedTypeName) throws SerializerException {
|
||||||
if (baseType.getFullQualifiedName().getFullQualifiedNameAsString().equals(derivedTypeName)) {
|
if (derivedTypeName == null ||
|
||||||
|
baseType.getFullQualifiedName().getFullQualifiedNameAsString().equals(derivedTypeName)) {
|
||||||
return baseType;
|
return baseType;
|
||||||
}
|
}
|
||||||
EdmComplexType derivedType = metadata.getEdm().getComplexType(new FullQualifiedName(derivedTypeName));
|
EdmComplexType derivedType = metadata.getEdm().getComplexType(new FullQualifiedName(derivedTypeName));
|
||||||
|
|
|
@ -117,6 +117,8 @@ DeserializerException.UNKNOWN_PRIMITIVE_TYPE=Unknown primitive type '%1$s' for p
|
||||||
DeserializerException.NAVIGATION_PROPERTY_NOT_FOUND=Can`t find navigation property with name: '%1$s'.
|
DeserializerException.NAVIGATION_PROPERTY_NOT_FOUND=Can`t find navigation property with name: '%1$s'.
|
||||||
DeserializerException.INVALID_ANNOTATION_TYPE=The annotation '%1$s' has the wrong JSON type.
|
DeserializerException.INVALID_ANNOTATION_TYPE=The annotation '%1$s' has the wrong JSON type.
|
||||||
DeserializerException.INVALID_ENTITY_BINDING_LINK=The binding link '%1$s' is malformed.
|
DeserializerException.INVALID_ENTITY_BINDING_LINK=The binding link '%1$s' is malformed.
|
||||||
|
DeserializerException.INVALID_ACTION_PARAMETER_TYPE=The action parameter '%1$s' must be either primitive, complex or an entity or a collection of those types.
|
||||||
|
DeserializerException.INVALID_NULL_PARAMETER=The parameter '%1$s' must not be null.
|
||||||
|
|
||||||
BatchDeserializerException.INVALID_BOUNDARY=Invalid boundary at line '%1$s'.
|
BatchDeserializerException.INVALID_BOUNDARY=Invalid boundary at line '%1$s'.
|
||||||
BatchDeserializerException.INVALID_CHANGESET_METHOD=Invalid method: a ChangeSet cannot contain retrieve requests at line '%1$s'.
|
BatchDeserializerException.INVALID_CHANGESET_METHOD=Invalid method: a ChangeSet cannot contain retrieve requests at line '%1$s'.
|
||||||
|
|
|
@ -37,10 +37,10 @@ public class EdmTypeImplTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getterTest() {
|
public void getterTest() {
|
||||||
EdmType type = new EdmTypeImplTester(new FullQualifiedName("namespace", "name"), EdmTypeKind.UNDEFINED);
|
EdmType type = new EdmTypeImplTester(new FullQualifiedName("namespace", "name"), EdmTypeKind.PRIMITIVE);
|
||||||
assertEquals("name", type.getName());
|
assertEquals("name", type.getName());
|
||||||
assertEquals("namespace", type.getNamespace());
|
assertEquals("namespace", type.getNamespace());
|
||||||
assertEquals(EdmTypeKind.UNDEFINED, type.getKind());
|
assertEquals(EdmTypeKind.PRIMITIVE, type.getKind());
|
||||||
EdmAnnotatable an = (EdmAnnotatable) type;
|
EdmAnnotatable an = (EdmAnnotatable) type;
|
||||||
assertNotNull(an.getAnnotations().get(0));
|
assertNotNull(an.getAnnotations().get(0));
|
||||||
}
|
}
|
||||||
|
|
|
@ -92,8 +92,7 @@ public class DataCreator {
|
||||||
EntitySet entitySet = new EntitySetImpl();
|
EntitySet entitySet = new EntitySetImpl();
|
||||||
|
|
||||||
for (int i = 1; i <= 503; i++) {
|
for (int i = 1; i <= 503; i++) {
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", i))
|
||||||
.addProperty(createPrimitive("PropertyInt16", i))
|
|
||||||
.addProperty(createPrimitive("PropertyString", "Number:" + i)));
|
.addProperty(createPrimitive("PropertyString", "Number:" + i)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,32 +111,20 @@ public class DataCreator {
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
private Entity createETKeyNavEntity(int propertyInt16, String propertyString) {
|
private Entity createETKeyNavEntity(int propertyInt16, String propertyString) {
|
||||||
return new EntityImpl()
|
return new EntityImpl().addProperty(createPrimitive("PropertyInt16", propertyInt16))
|
||||||
.addProperty(createPrimitive("PropertyInt16", propertyInt16))
|
|
||||||
.addProperty(createPrimitive("PropertyString", propertyString))
|
.addProperty(createPrimitive("PropertyString", propertyString))
|
||||||
.addProperty(createComplex("PropertyCompNav",
|
.addProperty(createComplex("PropertyCompNav", createPrimitive("PropertyInt16", 1)))
|
||||||
createPrimitive("PropertyInt16", 1)))
|
.addProperty(createKeyNavAllPrimComplexValue("PropertyCompAllPrim")).addProperty(
|
||||||
.addProperty(createKeyNavAllPrimComplexValue("PropertyCompAllPrim"))
|
createComplex("PropertyCompTwoPrim", createPrimitive("PropertyInt16", 16),
|
||||||
.addProperty(createComplex("PropertyCompTwoPrim",
|
createPrimitive("PropertyString", "Test123"))).addProperty(
|
||||||
createPrimitive("PropertyInt16", 16),
|
createPrimitiveCollection("CollPropertyString", "Employee1@company.example", "Employee2@company.example",
|
||||||
createPrimitive("PropertyString", "Test123")))
|
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyString",
|
|
||||||
"Employee1@company.example",
|
|
||||||
"Employee2@company.example",
|
|
||||||
"Employee3@company.example"))
|
"Employee3@company.example"))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyInt16", 1000, 2000, 30112))
|
.addProperty(createPrimitiveCollection("CollPropertyInt16", 1000, 2000, 30112)).addProperty(
|
||||||
.addProperty(createComplexCollection("CollPropertyComp",
|
createComplexCollection("CollPropertyComp",
|
||||||
Arrays.asList(
|
Arrays.asList(createPrimitive("PropertyInt16", 1), createKeyNavAllPrimComplexValue("PropertyComp")),
|
||||||
createPrimitive("PropertyInt16", 1),
|
Arrays.asList(createPrimitive("PropertyInt16", 2), createKeyNavAllPrimComplexValue("PropertyComp")),
|
||||||
createKeyNavAllPrimComplexValue("PropertyComp")),
|
Arrays.asList(createPrimitive("PropertyInt16", 3), createKeyNavAllPrimComplexValue("PropertyComp"))))
|
||||||
Arrays.asList(
|
.addProperty(createComplex("PropertyCompCompNav", createPrimitive("PropertyString", "1"),
|
||||||
createPrimitive("PropertyInt16", 2),
|
|
||||||
createKeyNavAllPrimComplexValue("PropertyComp")),
|
|
||||||
Arrays.asList(
|
|
||||||
createPrimitive("PropertyInt16", 3),
|
|
||||||
createKeyNavAllPrimComplexValue("PropertyComp"))))
|
|
||||||
.addProperty(createComplex("PropertyCompCompNav",
|
|
||||||
createPrimitive("PropertyString", "1"),
|
|
||||||
createComplex("PropertyCompNav", createPrimitive("PropertyInt16", 1))));
|
createComplex("PropertyCompNav", createPrimitive("PropertyInt16", 1))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,55 +141,40 @@ public class DataCreator {
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
private Entity createESTwoKeyNavEntity(int propertyInt16, String propertyString) {
|
private Entity createESTwoKeyNavEntity(int propertyInt16, String propertyString) {
|
||||||
return new EntityImpl()
|
return new EntityImpl().addProperty(createPrimitive("PropertyInt16", propertyInt16))
|
||||||
.addProperty(createPrimitive("PropertyInt16", propertyInt16))
|
.addProperty(createPrimitive("PropertyString", propertyString)).addProperty(
|
||||||
.addProperty(createPrimitive("PropertyString", propertyString))
|
createComplex("PropertyComp", createPrimitive("PropertyInt16", 11),
|
||||||
.addProperty(createComplex("PropertyComp",
|
createComplex("PropertyComp", createPrimitive("PropertyString", "StringValue"),
|
||||||
createPrimitive("PropertyInt16", 11),
|
|
||||||
createComplex("PropertyComp",
|
|
||||||
createPrimitive("PropertyString", "StringValue"),
|
|
||||||
createPrimitive("PropertyBinary", new byte[] { 1, 35, 69, 103, -119, -85, -51, -17 }),
|
createPrimitive("PropertyBinary", new byte[] { 1, 35, 69, 103, -119, -85, -51, -17 }),
|
||||||
createPrimitive("PropertyBoolean", true),
|
createPrimitive("PropertyBoolean", true), createPrimitive("PropertyByte", 255),
|
||||||
createPrimitive("PropertyByte", 255),
|
|
||||||
createPrimitive("PropertyDate", getDateTime(2012, 12, 3, 7, 16, 23)),
|
createPrimitive("PropertyDate", getDateTime(2012, 12, 3, 7, 16, 23)),
|
||||||
createPrimitive("PropertyDecimal", 34),
|
createPrimitive("PropertyDecimal", 34), createPrimitive("PropertySingle", 179000000000000000000D),
|
||||||
createPrimitive("PropertySingle", 179000000000000000000D),
|
createPrimitive("PropertyDouble", -179000000000000000000D), createPrimitive("PropertyDuration", 6),
|
||||||
createPrimitive("PropertyDouble", -179000000000000000000D),
|
|
||||||
createPrimitive("PropertyDuration", 6),
|
|
||||||
createPrimitive("PropertyGuid", UUID.fromString("01234567-89ab-cdef-0123-456789abcdef")),
|
createPrimitive("PropertyGuid", UUID.fromString("01234567-89ab-cdef-0123-456789abcdef")),
|
||||||
createPrimitive("PropertyInt16", Short.MAX_VALUE),
|
createPrimitive("PropertyInt16", Short.MAX_VALUE),
|
||||||
createPrimitive("PropertyInt32", Integer.MAX_VALUE),
|
createPrimitive("PropertyInt32", Integer.MAX_VALUE),
|
||||||
createPrimitive("PropertyInt64", Long.MAX_VALUE),
|
createPrimitive("PropertyInt64", Long.MAX_VALUE), createPrimitive("PropertySByte", Byte.MAX_VALUE),
|
||||||
createPrimitive("PropertySByte", Byte.MAX_VALUE),
|
createPrimitive("PropertyTimeOfDay", getTime(21, 5, 59))))).addProperty(
|
||||||
createPrimitive("PropertyTimeOfDay", getTime(21, 5, 59)))))
|
createComplex("PropertyCompNav", createPrimitive("PropertyInt16", 1),
|
||||||
.addProperty(createComplex("PropertyCompNav",
|
|
||||||
createPrimitive("PropertyInt16", 1),
|
|
||||||
createKeyNavAllPrimComplexValue("PropertyComp")))
|
createKeyNavAllPrimComplexValue("PropertyComp")))
|
||||||
.addProperty(createComplexCollection("CollPropertyComp"))
|
.addProperty(createComplexCollection("CollPropertyComp"))
|
||||||
.addProperty(createComplexCollection("CollPropertyCompNav",
|
.addProperty(createComplexCollection("CollPropertyCompNav", Arrays.asList(createPrimitive("PropertyInt16", 1))))
|
||||||
Arrays.asList(createPrimitive("PropertyInt16", 1))))
|
.addProperty(createPrimitiveCollection("CollPropertyString", 1, 2)).addProperty(
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyString", 1, 2))
|
createComplex("PropertyCompTwoPrim", createPrimitive("PropertyInt16", 11),
|
||||||
.addProperty(createComplex("PropertyCompTwoPrim", createPrimitive("PropertyInt16", 11),
|
|
||||||
createPrimitive("PropertyString", "11")));
|
createPrimitive("PropertyString", "11")));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Property createKeyNavAllPrimComplexValue(final String name) {
|
private Property createKeyNavAllPrimComplexValue(final String name) {
|
||||||
return createComplex(name,
|
return createComplex(name, createPrimitive("PropertyString", "First Resource - positive values"),
|
||||||
createPrimitive("PropertyString", "First Resource - positive values"),
|
|
||||||
createPrimitive("PropertyBinary", new byte[] { 1, 35, 69, 103, -119, -85, -51, -17 }),
|
createPrimitive("PropertyBinary", new byte[] { 1, 35, 69, 103, -119, -85, -51, -17 }),
|
||||||
createPrimitive("PropertyBoolean", true),
|
createPrimitive("PropertyBoolean", true), createPrimitive("PropertyByte", 255),
|
||||||
createPrimitive("PropertyByte", 255),
|
|
||||||
createPrimitive("PropertyDate", getDateTime(2012, 12, 3, 7, 16, 23)),
|
createPrimitive("PropertyDate", getDateTime(2012, 12, 3, 7, 16, 23)),
|
||||||
createPrimitive("PropertyDateTimeOffset", getTimestamp(2012, 12, 3, 7, 16, 23, 0)),
|
createPrimitive("PropertyDateTimeOffset", getTimestamp(2012, 12, 3, 7, 16, 23, 0)),
|
||||||
createPrimitive("PropertyDecimal", 34),
|
createPrimitive("PropertyDecimal", 34), createPrimitive("PropertySingle", 179000000000000000000D),
|
||||||
createPrimitive("PropertySingle", 179000000000000000000D),
|
createPrimitive("PropertyDouble", -179000000000000000000D), createPrimitive("PropertyDuration", 6),
|
||||||
createPrimitive("PropertyDouble", -179000000000000000000D),
|
|
||||||
createPrimitive("PropertyDuration", 6),
|
|
||||||
createPrimitive("PropertyGuid", UUID.fromString("01234567-89ab-cdef-0123-456789abcdef")),
|
createPrimitive("PropertyGuid", UUID.fromString("01234567-89ab-cdef-0123-456789abcdef")),
|
||||||
createPrimitive("PropertyInt16", Short.MAX_VALUE),
|
createPrimitive("PropertyInt16", Short.MAX_VALUE), createPrimitive("PropertyInt32", Integer.MAX_VALUE),
|
||||||
createPrimitive("PropertyInt32", Integer.MAX_VALUE),
|
createPrimitive("PropertyInt64", Long.MAX_VALUE), createPrimitive("PropertySByte", Byte.MAX_VALUE),
|
||||||
createPrimitive("PropertyInt64", Long.MAX_VALUE),
|
|
||||||
createPrimitive("PropertySByte", Byte.MAX_VALUE),
|
|
||||||
createPrimitive("PropertyTimeOfDay", getTime(21, 5, 59)));
|
createPrimitive("PropertyTimeOfDay", getTime(21, 5, 59)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,8 +182,7 @@ public class DataCreator {
|
||||||
private EntitySet createESCompCollComp() {
|
private EntitySet createESCompCollComp() {
|
||||||
final EntitySet entitySet = new EntitySetImpl();
|
final EntitySet entitySet = new EntitySetImpl();
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE))
|
||||||
.addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE))
|
|
||||||
.addProperty(createComplex("PropertyComp", createComplexCollection("CollPropertyComp", Arrays
|
.addProperty(createComplex("PropertyComp", createComplexCollection("CollPropertyComp", Arrays
|
||||||
.asList(createPrimitive("PropertyInt16", 555),
|
.asList(createPrimitive("PropertyInt16", 555),
|
||||||
createPrimitive("PropertyString", "1 Test Complex in Complex Property")), Arrays
|
createPrimitive("PropertyString", "1 Test Complex in Complex Property")), Arrays
|
||||||
|
@ -220,9 +191,8 @@ public class DataCreator {
|
||||||
.asList(createPrimitive("PropertyInt16", 777),
|
.asList(createPrimitive("PropertyInt16", 777),
|
||||||
createPrimitive("PropertyString", "3 Test Complex in Complex Property"))))));
|
createPrimitive("PropertyString", "3 Test Complex in Complex Property"))))));
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", 12345)).addProperty(
|
||||||
.addProperty(createPrimitive("PropertyInt16", 12345))
|
createComplex("PropertyComp", createComplexCollection("CollPropertyComp", Arrays
|
||||||
.addProperty(createComplex("PropertyComp", createComplexCollection("CollPropertyComp", Arrays
|
|
||||||
.asList(createPrimitive("PropertyInt16", 888),
|
.asList(createPrimitive("PropertyInt16", 888),
|
||||||
createPrimitive("PropertyString", "11 Test Complex in Complex Property")), Arrays
|
createPrimitive("PropertyString", "11 Test Complex in Complex Property")), Arrays
|
||||||
.asList(createPrimitive("PropertyInt16", 999),
|
.asList(createPrimitive("PropertyInt16", 999),
|
||||||
|
@ -236,20 +206,16 @@ public class DataCreator {
|
||||||
private EntitySet createESTwoPrim() {
|
private EntitySet createESTwoPrim() {
|
||||||
EntitySet entitySet = new EntitySetImpl();
|
EntitySet entitySet = new EntitySetImpl();
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", 32766))
|
||||||
.addProperty(createPrimitive("PropertyInt16", 32766))
|
|
||||||
.addProperty(createPrimitive("PropertyString", "Test String1")));
|
.addProperty(createPrimitive("PropertyString", "Test String1")));
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", -365))
|
||||||
.addProperty(createPrimitive("PropertyInt16", -365))
|
|
||||||
.addProperty(createPrimitive("PropertyString", "Test String2")));
|
.addProperty(createPrimitive("PropertyString", "Test String2")));
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", -32766))
|
||||||
.addProperty(createPrimitive("PropertyInt16", -32766))
|
|
||||||
.addProperty(createPrimitive("PropertyString", null)));
|
.addProperty(createPrimitive("PropertyString", null)));
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE))
|
||||||
.addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE))
|
|
||||||
.addProperty(createPrimitive("PropertyString", "Test String4")));
|
.addProperty(createPrimitive("PropertyString", "Test String4")));
|
||||||
|
|
||||||
return entitySet;
|
return entitySet;
|
||||||
|
@ -289,16 +255,11 @@ public class DataCreator {
|
||||||
.addProperty(createPrimitive("PropertyGuid", UUID.fromString("76543201-23ab-cdef-0123-456789dddfff")))
|
.addProperty(createPrimitive("PropertyGuid", UUID.fromString("76543201-23ab-cdef-0123-456789dddfff")))
|
||||||
.addProperty(createPrimitive("PropertyTimeOfDay", getTime(23, 49, 14))));
|
.addProperty(createPrimitive("PropertyTimeOfDay", getTime(23, 49, 14))));
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", 0))
|
||||||
.addProperty(createPrimitive("PropertyInt16", 0))
|
.addProperty(createPrimitive("PropertyString", "")).addProperty(createPrimitive("PropertyBoolean", false))
|
||||||
.addProperty(createPrimitive("PropertyString", ""))
|
.addProperty(createPrimitive("PropertyByte", 0)).addProperty(createPrimitive("PropertySByte", 0))
|
||||||
.addProperty(createPrimitive("PropertyBoolean", false))
|
.addProperty(createPrimitive("PropertyInt32", 0)).addProperty(createPrimitive("PropertyInt64", 0))
|
||||||
.addProperty(createPrimitive("PropertyByte", 0))
|
.addProperty(createPrimitive("PropertySingle", 0)).addProperty(createPrimitive("PropertyDouble", 0))
|
||||||
.addProperty(createPrimitive("PropertySByte", 0))
|
|
||||||
.addProperty(createPrimitive("PropertyInt32", 0))
|
|
||||||
.addProperty(createPrimitive("PropertyInt64", 0))
|
|
||||||
.addProperty(createPrimitive("PropertySingle", 0))
|
|
||||||
.addProperty(createPrimitive("PropertyDouble", 0))
|
|
||||||
.addProperty(createPrimitive("PropertyDecimal", 0))
|
.addProperty(createPrimitive("PropertyDecimal", 0))
|
||||||
.addProperty(createPrimitive("PropertyBinary", new byte[] {}))
|
.addProperty(createPrimitive("PropertyBinary", new byte[] {}))
|
||||||
.addProperty(createPrimitive("PropertyDate", getDateTime(1970, 1, 1, 0, 0, 0)))
|
.addProperty(createPrimitive("PropertyDate", getDateTime(1970, 1, 1, 0, 0, 0)))
|
||||||
|
@ -315,24 +276,17 @@ public class DataCreator {
|
||||||
|
|
||||||
Entity entity = new EntityImpl();
|
Entity entity = new EntityImpl();
|
||||||
entity.addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE));
|
entity.addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE));
|
||||||
entity.addProperty(createComplex("PropertyComp",
|
entity.addProperty(createComplex("PropertyComp", createPrimitive("PropertyString", "First Resource - first"),
|
||||||
createPrimitive("PropertyString", "First Resource - first"),
|
|
||||||
createPrimitive("PropertyBinary",
|
createPrimitive("PropertyBinary",
|
||||||
new byte[] { 0x01, 0x23, 0x45, 0x67, (byte) 0x89, (byte) 0xAB, (byte) 0xCD, (byte) 0xEF }),
|
new byte[] { 0x01, 0x23, 0x45, 0x67, (byte) 0x89, (byte) 0xAB, (byte) 0xCD, (byte) 0xEF }),
|
||||||
createPrimitive("PropertyBoolean", true),
|
createPrimitive("PropertyBoolean", true), createPrimitive("PropertyByte", 255),
|
||||||
createPrimitive("PropertyByte", 255),
|
|
||||||
createPrimitive("PropertyDate", getDateTime(2012, 10, 3, 0, 0, 0)),
|
createPrimitive("PropertyDate", getDateTime(2012, 10, 3, 0, 0, 0)),
|
||||||
createPrimitive("PropertyDateTimeOffset", getTimestamp(2012, 10, 3, 7, 16, 23, 123456700)),
|
createPrimitive("PropertyDateTimeOffset", getTimestamp(2012, 10, 3, 7, 16, 23, 123456700)),
|
||||||
createPrimitive("PropertyDecimal", 34.27),
|
createPrimitive("PropertyDecimal", 34.27), createPrimitive("PropertySingle", 1.79000000E+20),
|
||||||
createPrimitive("PropertySingle", 1.79000000E+20),
|
createPrimitive("PropertyDouble", -1.7900000000000000E+19), createPrimitive("PropertyDuration", 6),
|
||||||
createPrimitive("PropertyDouble", -1.7900000000000000E+19),
|
createPrimitive("PropertyGuid", GUID), createPrimitive("PropertyInt16", Short.MAX_VALUE),
|
||||||
createPrimitive("PropertyDuration", 6),
|
createPrimitive("PropertyInt32", Integer.MAX_VALUE), createPrimitive("PropertyInt64", Long.MAX_VALUE),
|
||||||
createPrimitive("PropertyGuid", GUID),
|
createPrimitive("PropertySByte", Byte.MAX_VALUE), createPrimitive("PropertyTimeOfDay", getTime(1, 0, 1))));
|
||||||
createPrimitive("PropertyInt16", Short.MAX_VALUE),
|
|
||||||
createPrimitive("PropertyInt32", Integer.MAX_VALUE),
|
|
||||||
createPrimitive("PropertyInt64", Long.MAX_VALUE),
|
|
||||||
createPrimitive("PropertySByte", Byte.MAX_VALUE),
|
|
||||||
createPrimitive("PropertyTimeOfDay", getTime(1, 0, 1))));
|
|
||||||
entitySet.getEntities().add(entity);
|
entitySet.getEntities().add(entity);
|
||||||
|
|
||||||
entity = new EntityImpl();
|
entity = new EntityImpl();
|
||||||
|
@ -372,10 +326,9 @@ public class DataCreator {
|
||||||
private EntitySet createESCollAllPrim() {
|
private EntitySet createESCollAllPrim() {
|
||||||
EntitySet entitySet = new EntitySetImpl();
|
EntitySet entitySet = new EntitySetImpl();
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", 1)).addProperty(
|
||||||
.addProperty(createPrimitive("PropertyInt16", 1))
|
createPrimitiveCollection("CollPropertyString", "Employee1@company.example", "Employee2@company.example",
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyString",
|
"Employee3@company.example"))
|
||||||
"Employee1@company.example", "Employee2@company.example", "Employee3@company.example"))
|
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyBoolean", true, false, true))
|
.addProperty(createPrimitiveCollection("CollPropertyBoolean", true, false, true))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyByte", 50, 200, 249))
|
.addProperty(createPrimitiveCollection("CollPropertyByte", 50, 200, 249))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertySByte", -120, 120, 126))
|
.addProperty(createPrimitiveCollection("CollPropertySByte", -120, 120, 126))
|
||||||
|
@ -383,28 +336,22 @@ public class DataCreator {
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyInt32", 23232323, 11223355, 10000001))
|
.addProperty(createPrimitiveCollection("CollPropertyInt32", 23232323, 11223355, 10000001))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyInt64", 929292929292L, 333333333333L, 444444444444L))
|
.addProperty(createPrimitiveCollection("CollPropertyInt64", 929292929292L, 333333333333L, 444444444444L))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertySingle", 1.79000000E+03, 2.66000000E+04, 3.21000000E+03))
|
.addProperty(createPrimitiveCollection("CollPropertySingle", 1.79000000E+03, 2.66000000E+04, 3.21000000E+03))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyDouble",
|
.addProperty(createPrimitiveCollection("CollPropertyDouble", -1.7900000000000000E+04, -2.7800000000000000E+07,
|
||||||
-1.7900000000000000E+04, -2.7800000000000000E+07, 3.2100000000000000E+03))
|
3.2100000000000000E+03)).addProperty(createPrimitiveCollection("CollPropertyDecimal", 12, -2, 1234))
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyDecimal", 12, -2, 1234))
|
.addProperty(
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyBinary",
|
createPrimitiveCollection("CollPropertyBinary", new byte[] { (byte) 0xAB, (byte) 0xCD, (byte) 0xEF }, new
|
||||||
new byte[] { (byte) 0xAB, (byte) 0xCD, (byte) 0xEF },
|
byte[] { 0x01, 0x23, 0x45 },
|
||||||
new byte[] { 0x01, 0x23, 0x45 },
|
new byte[] { 0x54, 0x67, (byte) 0x89 })).addProperty(
|
||||||
new byte[] { 0x54, 0x67, (byte) 0x89 }))
|
createPrimitiveCollection("CollPropertyDate", getDateTime(1958, 12, 3, 0, 0, 0),
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyDate",
|
getDateTime(1999, 8, 5, 0, 0, 0), getDateTime(2013, 6, 25, 0, 0, 0))).addProperty(
|
||||||
getDateTime(1958, 12, 3, 0, 0, 0),
|
createPrimitiveCollection("CollPropertyDateTimeOffset", getDateTime(2015, 8, 12, 3, 8, 34),
|
||||||
getDateTime(1999, 8, 5, 0, 0, 0),
|
getDateTime(1970, 3, 28, 12, 11, 10), getDateTime(1948, 2, 17, 9, 9, 9)))
|
||||||
getDateTime(2013, 6, 25, 0, 0, 0)))
|
.addProperty(createPrimitiveCollection("CollPropertyDuration", 13, 19680, 3600)).addProperty(
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyDateTimeOffset",
|
createPrimitiveCollection("CollPropertyGuid", UUID.fromString("ffffff67-89ab-cdef-0123-456789aaaaaa"),
|
||||||
getDateTime(2015, 8, 12, 3, 8, 34),
|
|
||||||
getDateTime(1970, 3, 28, 12, 11, 10),
|
|
||||||
getDateTime(1948, 2, 17, 9, 9, 9)))
|
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyDuration", 13, 19680, 3600))
|
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyGuid",
|
|
||||||
UUID.fromString("ffffff67-89ab-cdef-0123-456789aaaaaa"),
|
|
||||||
UUID.fromString("eeeeee67-89ab-cdef-0123-456789bbbbbb"),
|
UUID.fromString("eeeeee67-89ab-cdef-0123-456789bbbbbb"),
|
||||||
UUID.fromString("cccccc67-89ab-cdef-0123-456789cccccc")))
|
UUID.fromString("cccccc67-89ab-cdef-0123-456789cccccc"))).addProperty(
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyTimeOfDay",
|
createPrimitiveCollection("CollPropertyTimeOfDay", getTime(4, 14, 13), getTime(23, 59, 59),
|
||||||
getTime(4, 14, 13), getTime(23, 59, 59), getTime(1, 12, 33))));
|
getTime(1, 12, 33))));
|
||||||
|
|
||||||
Entity entity = new EntityImpl();
|
Entity entity = new EntityImpl();
|
||||||
entity.getProperties().addAll(entitySet.getEntities().get(0).getProperties());
|
entity.getProperties().addAll(entitySet.getEntities().get(0).getProperties());
|
||||||
|
@ -420,39 +367,31 @@ public class DataCreator {
|
||||||
}
|
}
|
||||||
|
|
||||||
private EntitySet createESMixPrimCollComp() {
|
private EntitySet createESMixPrimCollComp() {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked") final Property complexCollection = createComplexCollection("CollPropertyComp",
|
||||||
final Property complexCollection = createComplexCollection("CollPropertyComp",
|
|
||||||
Arrays.asList(createPrimitive("PropertyInt16", 123), createPrimitive("PropertyString", "TEST 1")),
|
Arrays.asList(createPrimitive("PropertyInt16", 123), createPrimitive("PropertyString", "TEST 1")),
|
||||||
Arrays.asList(createPrimitive("PropertyInt16", 456), createPrimitive("PropertyString", "TEST 2")),
|
Arrays.asList(createPrimitive("PropertyInt16", 456), createPrimitive("PropertyString", "TEST 2")),
|
||||||
Arrays.asList(createPrimitive("PropertyInt16", 789), createPrimitive("PropertyString", "TEST 3")));
|
Arrays.asList(createPrimitive("PropertyInt16", 789), createPrimitive("PropertyString", "TEST 3")));
|
||||||
|
|
||||||
EntitySet entitySet = new EntitySetImpl();
|
EntitySet entitySet = new EntitySetImpl();
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE))
|
||||||
.addProperty(createPrimitive("PropertyInt16", Short.MAX_VALUE))
|
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyString",
|
|
||||||
"Employee1@company.example", "Employee2@company.example", "Employee3@company.example"))
|
|
||||||
.addProperty(createComplex("PropertyComp",
|
|
||||||
createPrimitive("PropertyInt16", 111),
|
|
||||||
createPrimitive("PropertyString", "TEST A")))
|
|
||||||
.addProperty(complexCollection));
|
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
|
||||||
.addProperty(createPrimitive("PropertyInt16", 7))
|
|
||||||
.addProperty(
|
.addProperty(
|
||||||
createPrimitiveCollection("CollPropertyString", "Employee1@company.example", "Employee2@company.example",
|
createPrimitiveCollection("CollPropertyString", "Employee1@company.example", "Employee2@company.example",
|
||||||
"Employee3@company.example"))
|
"Employee3@company.example")).addProperty(
|
||||||
.addProperty(createComplex("PropertyComp", createPrimitive("PropertyInt16", 222),
|
createComplex("PropertyComp", createPrimitive("PropertyInt16", 111),
|
||||||
createPrimitive("PropertyString", "TEST B")))
|
createPrimitive("PropertyString", "TEST A"))).addProperty(complexCollection));
|
||||||
.addProperty(complexCollection));
|
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", 7)).addProperty(
|
||||||
.addProperty(createPrimitive("PropertyInt16", 0))
|
createPrimitiveCollection("CollPropertyString", "Employee1@company.example", "Employee2@company.example",
|
||||||
.addProperty(createPrimitiveCollection("CollPropertyString", "Employee1@company.example",
|
"Employee3@company.example")).addProperty(
|
||||||
"Employee2@company.example", "Employee3@company.example"))
|
createComplex("PropertyComp", createPrimitive("PropertyInt16", 222),
|
||||||
.addProperty(createComplex("PropertyComp", createPrimitive("PropertyInt16", 333),
|
createPrimitive("PropertyString", "TEST B"))).addProperty(complexCollection));
|
||||||
createPrimitive("PropertyString", "TEST C")))
|
|
||||||
.addProperty(complexCollection));
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyInt16", 0)).addProperty(
|
||||||
|
createPrimitiveCollection("CollPropertyString", "Employee1@company.example", "Employee2@company.example",
|
||||||
|
"Employee3@company.example")).addProperty(
|
||||||
|
createComplex("PropertyComp", createPrimitive("PropertyInt16", 333),
|
||||||
|
createPrimitive("PropertyString", "TEST C"))).addProperty(complexCollection));
|
||||||
|
|
||||||
return entitySet;
|
return entitySet;
|
||||||
}
|
}
|
||||||
|
@ -472,19 +411,15 @@ public class DataCreator {
|
||||||
.addProperty(createPrimitive("PropertyDuration", 6)).addProperty(createPrimitive("PropertyGuid", GUID))
|
.addProperty(createPrimitive("PropertyDuration", 6)).addProperty(createPrimitive("PropertyGuid", GUID))
|
||||||
.addProperty(createPrimitive("PropertyTimeOfDay", getTime(2, 48, 21))));
|
.addProperty(createPrimitive("PropertyTimeOfDay", getTime(2, 48, 21))));
|
||||||
|
|
||||||
entitySet.getEntities().add(new EntityImpl()
|
entitySet.getEntities().add(new EntityImpl().addProperty(createPrimitive("PropertyString", "Second"))
|
||||||
.addProperty(createPrimitive("PropertyString", "Second"))
|
.addProperty(createPrimitive("PropertyBoolean", true)).addProperty(createPrimitive("PropertyByte", 254))
|
||||||
.addProperty(createPrimitive("PropertyBoolean", true))
|
.addProperty(createPrimitive("PropertySByte", 124)).addProperty(createPrimitive("PropertyInt16", 32764))
|
||||||
.addProperty(createPrimitive("PropertyByte", 254))
|
|
||||||
.addProperty(createPrimitive("PropertySByte", 124))
|
|
||||||
.addProperty(createPrimitive("PropertyInt16", 32764))
|
|
||||||
.addProperty(createPrimitive("PropertyInt32", 2147483644))
|
.addProperty(createPrimitive("PropertyInt32", 2147483644))
|
||||||
.addProperty(createPrimitive("PropertyInt64", 9223372036854775804L))
|
.addProperty(createPrimitive("PropertyInt64", 9223372036854775804L))
|
||||||
.addProperty(createPrimitive("PropertyDecimal", 34))
|
.addProperty(createPrimitive("PropertyDecimal", 34))
|
||||||
.addProperty(createPrimitive("PropertyDate", getDateTime(2012, 12, 3, 0, 0, 0)))
|
.addProperty(createPrimitive("PropertyDate", getDateTime(2012, 12, 3, 0, 0, 0)))
|
||||||
.addProperty(createPrimitive("PropertyDateTimeOffset", getDateTime(2012, 12, 3, 7, 16, 23)))
|
.addProperty(createPrimitive("PropertyDateTimeOffset", getDateTime(2012, 12, 3, 7, 16, 23)))
|
||||||
.addProperty(createPrimitive("PropertyDuration", 6))
|
.addProperty(createPrimitive("PropertyDuration", 6)).addProperty(createPrimitive("PropertyGuid", GUID))
|
||||||
.addProperty(createPrimitive("PropertyGuid", GUID))
|
|
||||||
.addProperty(createPrimitive("PropertyTimeOfDay", getTime(2, 48, 21))));
|
.addProperty(createPrimitive("PropertyTimeOfDay", getTime(2, 48, 21))));
|
||||||
|
|
||||||
return entitySet;
|
return entitySet;
|
||||||
|
@ -496,8 +431,7 @@ public class DataCreator {
|
||||||
Entity entity = new EntityImpl();
|
Entity entity = new EntityImpl();
|
||||||
entity.addProperty(createPrimitive("PropertyInt16", 1));
|
entity.addProperty(createPrimitive("PropertyInt16", 1));
|
||||||
entity.addProperty(createComplex("PropertyComp",
|
entity.addProperty(createComplex("PropertyComp",
|
||||||
createComplex("PropertyComp",
|
createComplex("PropertyComp", createPrimitive("PropertyInt16", 123),
|
||||||
createPrimitive("PropertyInt16", 123),
|
|
||||||
createPrimitive("PropertyString", "String 1"))));
|
createPrimitive("PropertyString", "String 1"))));
|
||||||
entitySet.getEntities().add(entity);
|
entitySet.getEntities().add(entity);
|
||||||
|
|
||||||
|
@ -514,26 +448,22 @@ public class DataCreator {
|
||||||
private EntitySet createESMedia() {
|
private EntitySet createESMedia() {
|
||||||
EntitySet entitySet = new EntitySetImpl();
|
EntitySet entitySet = new EntitySetImpl();
|
||||||
|
|
||||||
Entity entity = new EntityImpl()
|
Entity entity = new EntityImpl().addProperty(createPrimitive("PropertyInt16", 1))
|
||||||
.addProperty(createPrimitive("PropertyInt16", 1))
|
|
||||||
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("darkturquoise")));
|
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("darkturquoise")));
|
||||||
entity.setMediaContentType("image/svg+xml");
|
entity.setMediaContentType("image/svg+xml");
|
||||||
entitySet.getEntities().add(entity);
|
entitySet.getEntities().add(entity);
|
||||||
|
|
||||||
entity = new EntityImpl()
|
entity = new EntityImpl().addProperty(createPrimitive("PropertyInt16", 2))
|
||||||
.addProperty(createPrimitive("PropertyInt16", 2))
|
|
||||||
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("royalblue")));
|
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("royalblue")));
|
||||||
entity.setMediaContentType("image/svg+xml");
|
entity.setMediaContentType("image/svg+xml");
|
||||||
entitySet.getEntities().add(entity);
|
entitySet.getEntities().add(entity);
|
||||||
|
|
||||||
entity = new EntityImpl()
|
entity = new EntityImpl().addProperty(createPrimitive("PropertyInt16", 3))
|
||||||
.addProperty(createPrimitive("PropertyInt16", 3))
|
|
||||||
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("crimson")));
|
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("crimson")));
|
||||||
entity.setMediaContentType("image/svg+xml");
|
entity.setMediaContentType("image/svg+xml");
|
||||||
entitySet.getEntities().add(entity);
|
entitySet.getEntities().add(entity);
|
||||||
|
|
||||||
entity = new EntityImpl()
|
entity = new EntityImpl().addProperty(createPrimitive("PropertyInt16", 4))
|
||||||
.addProperty(createPrimitive("PropertyInt16", 4))
|
|
||||||
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("black")));
|
.addProperty(createPrimitive(DataProvider.MEDIA_PROPERTY_NAME, createImage("black")));
|
||||||
entity.setMediaContentType("image/svg+xml");
|
entity.setMediaContentType("image/svg+xml");
|
||||||
entitySet.getEntities().add(entity);
|
entitySet.getEntities().add(entity);
|
||||||
|
@ -545,9 +475,7 @@ public class DataCreator {
|
||||||
return ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
|
return ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
|
||||||
+ "<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" viewBox=\"0 0 100 100\">\n"
|
+ "<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" viewBox=\"0 0 100 100\">\n"
|
||||||
+ " <g stroke=\"darkmagenta\" stroke-width=\"16\" fill=\"" + color + "\">\n"
|
+ " <g stroke=\"darkmagenta\" stroke-width=\"16\" fill=\"" + color + "\">\n"
|
||||||
+ " <circle cx=\"50\" cy=\"50\" r=\"42\"/>\n"
|
+ " <circle cx=\"50\" cy=\"50\" r=\"42\"/>\n" + " </g>\n" + "</svg>\n").getBytes(Charset.forName("UTF-8"));
|
||||||
+ " </g>\n"
|
|
||||||
+ "</svg>\n").getBytes(Charset.forName("UTF-8"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void linkESTwoPrim(Map<String, EntitySet> data) {
|
private void linkESTwoPrim(Map<String, EntitySet> data) {
|
||||||
|
@ -566,8 +494,8 @@ public class DataCreator {
|
||||||
setLinks(entitySet.getEntities().get(0), "NavPropertyETTwoPrimMany", targetEntities.get(1));
|
setLinks(entitySet.getEntities().get(0), "NavPropertyETTwoPrimMany", targetEntities.get(1));
|
||||||
setLink(entitySet.getEntities().get(0), "NavPropertyETTwoPrimOne", targetEntities.get(3));
|
setLink(entitySet.getEntities().get(0), "NavPropertyETTwoPrimOne", targetEntities.get(3));
|
||||||
|
|
||||||
setLinks(entitySet.getEntities().get(2), "NavPropertyETTwoPrimMany",
|
setLinks(entitySet.getEntities().get(2), "NavPropertyETTwoPrimMany", targetEntities.get(0), targetEntities.get(2),
|
||||||
targetEntities.get(0), targetEntities.get(2), targetEntities.get(3));
|
targetEntities.get(3));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void linkESKeyNav(Map<String, EntitySet> data) {
|
private void linkESKeyNav(Map<String, EntitySet> data) {
|
||||||
|
@ -613,12 +541,9 @@ public class DataCreator {
|
||||||
setLink(entitySet.getEntities().get(3), "NavPropertyETKeyNavOne", esKeyNavTargets.get(2));
|
setLink(entitySet.getEntities().get(3), "NavPropertyETKeyNavOne", esKeyNavTargets.get(2));
|
||||||
|
|
||||||
// NavPropertyETKeyNavMany
|
// NavPropertyETKeyNavMany
|
||||||
setLinks(entitySet.getEntities().get(0), "NavPropertyETKeyNavMany",
|
setLinks(entitySet.getEntities().get(0), "NavPropertyETKeyNavMany", esKeyNavTargets.get(0), esKeyNavTargets.get(1));
|
||||||
esKeyNavTargets.get(0), esKeyNavTargets.get(1));
|
setLinks(entitySet.getEntities().get(1), "NavPropertyETKeyNavMany", esKeyNavTargets.get(0), esKeyNavTargets.get(1));
|
||||||
setLinks(entitySet.getEntities().get(1), "NavPropertyETKeyNavMany",
|
setLinks(entitySet.getEntities().get(2), "NavPropertyETKeyNavMany", esKeyNavTargets.get(1), esKeyNavTargets.get(2));
|
||||||
esKeyNavTargets.get(0), esKeyNavTargets.get(1));
|
|
||||||
setLinks(entitySet.getEntities().get(2), "NavPropertyETKeyNavMany",
|
|
||||||
esKeyNavTargets.get(1), esKeyNavTargets.get(2));
|
|
||||||
|
|
||||||
// NavPropertyETTwoKeyNavOne
|
// NavPropertyETTwoKeyNavOne
|
||||||
setLink(entitySet.getEntities().get(0), "NavPropertyETTwoKeyNavOne", esTwoKeyNavTargets.get(0));
|
setLink(entitySet.getEntities().get(0), "NavPropertyETTwoKeyNavOne", esTwoKeyNavTargets.get(0));
|
||||||
|
@ -626,8 +551,8 @@ public class DataCreator {
|
||||||
setLink(entitySet.getEntities().get(3), "NavPropertyETTwoKeyNavOne", esTwoKeyNavTargets.get(2));
|
setLink(entitySet.getEntities().get(3), "NavPropertyETTwoKeyNavOne", esTwoKeyNavTargets.get(2));
|
||||||
|
|
||||||
// NavPropertyETTwoKeyNavMany
|
// NavPropertyETTwoKeyNavMany
|
||||||
setLinks(entitySet.getEntities().get(0), "NavPropertyETTwoKeyNavMany",
|
setLinks(entitySet.getEntities().get(0), "NavPropertyETTwoKeyNavMany", esTwoKeyNavTargets.get(0),
|
||||||
esTwoKeyNavTargets.get(0), esTwoKeyNavTargets.get(1));
|
esTwoKeyNavTargets.get(1));
|
||||||
setLinks(entitySet.getEntities().get(1), "NavPropertyETTwoKeyNavMany", esTwoKeyNavTargets.get(0));
|
setLinks(entitySet.getEntities().get(1), "NavPropertyETTwoKeyNavMany", esTwoKeyNavTargets.get(0));
|
||||||
setLinks(entitySet.getEntities().get(2), "NavPropertyETTwoKeyNavMany", esTwoKeyNavTargets.get(1));
|
setLinks(entitySet.getEntities().get(2), "NavPropertyETTwoKeyNavMany", esTwoKeyNavTargets.get(1));
|
||||||
}
|
}
|
||||||
|
@ -640,6 +565,10 @@ public class DataCreator {
|
||||||
return new PropertyImpl(null, name, ValueType.COLLECTION_PRIMITIVE, Arrays.asList(values));
|
return new PropertyImpl(null, name, ValueType.COLLECTION_PRIMITIVE, Arrays.asList(values));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static Property createComplex(final String name, String type, final Property... properties) {
|
||||||
|
return createComplex(name, properties);
|
||||||
|
}
|
||||||
|
|
||||||
protected static Property createComplex(final String name, final Property... properties) {
|
protected static Property createComplex(final String name, final Property... properties) {
|
||||||
ComplexValue complexValue = new ComplexValueImpl();
|
ComplexValue complexValue = new ComplexValueImpl();
|
||||||
for (final Property property : properties) {
|
for (final Property property : properties) {
|
||||||
|
@ -648,6 +577,11 @@ public class DataCreator {
|
||||||
return new PropertyImpl(null, name, ValueType.COMPLEX, complexValue);
|
return new PropertyImpl(null, name, ValueType.COMPLEX, complexValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static Property createComplexCollection(final String name, String type, final List<Property>...
|
||||||
|
propertiesList) {
|
||||||
|
return createComplexCollection(name, propertiesList);
|
||||||
|
}
|
||||||
|
|
||||||
protected static Property createComplexCollection(final String name, final List<Property>... propertiesList) {
|
protected static Property createComplexCollection(final String name, final List<Property>... propertiesList) {
|
||||||
List<ComplexValue> complexCollection = new ArrayList<ComplexValue>();
|
List<ComplexValue> complexCollection = new ArrayList<ComplexValue>();
|
||||||
for (final List<Property> properties : propertiesList) {
|
for (final List<Property> properties : propertiesList) {
|
||||||
|
|
|
@ -49,9 +49,12 @@ public class ActionProvider {
|
||||||
public static final FullQualifiedName nameBAETTwoKeyNavRTETTwoKeyNav =
|
public static final FullQualifiedName nameBAETTwoKeyNavRTETTwoKeyNav =
|
||||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETTwoKeyNavRTETTwoKeyNav");
|
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETTwoKeyNavRTETTwoKeyNav");
|
||||||
|
|
||||||
public static final FullQualifiedName nameBAETAllPrimRT =
|
public static final FullQualifiedName nameBAESAllPrimRT =
|
||||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAESAllPrimRT");
|
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAESAllPrimRT");
|
||||||
|
|
||||||
|
public static final FullQualifiedName nameBAETAllPrimRT =
|
||||||
|
new FullQualifiedName(SchemaProvider.NAMESPACE, "BAETAllPrimRT");
|
||||||
|
|
||||||
// Unbound Actions
|
// Unbound Actions
|
||||||
public static final FullQualifiedName nameUARTString = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
public static final FullQualifiedName nameUARTString = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
||||||
"UARTString");
|
"UARTString");
|
||||||
|
@ -75,76 +78,70 @@ public class ActionProvider {
|
||||||
public static final FullQualifiedName nameUARTTwoParam =
|
public static final FullQualifiedName nameUARTTwoParam =
|
||||||
new FullQualifiedName(SchemaProvider.NAMESPACE, "UARTTwoParam");
|
new FullQualifiedName(SchemaProvider.NAMESPACE, "UARTTwoParam");
|
||||||
|
|
||||||
|
|
||||||
public List<Action> getActions(final FullQualifiedName actionName) throws ODataException {
|
public List<Action> getActions(final FullQualifiedName actionName) throws ODataException {
|
||||||
if (actionName.equals(nameUARTString)) {
|
if (actionName.equals(nameUARTString)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTString.getName())
|
new Action().setName(nameUARTString.getName())
|
||||||
.setReturnType(new ReturnType().setType(PropertyProvider.nameString))
|
.setReturnType(new ReturnType().setType(PropertyProvider.nameString)));
|
||||||
);
|
|
||||||
} else if (actionName.equals(nameUARTCollStringTwoParam)) {
|
} else if (actionName.equals(nameUARTCollStringTwoParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTCollStringTwoParam.getName())
|
new Action().setName(nameUARTCollStringTwoParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Arrays.asList(
|
||||||
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16),
|
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16),
|
||||||
new Parameter().setName("ParameterDuration").setType(PropertyProvider.nameDuration)))
|
new Parameter().setName("ParameterDuration").setType(PropertyProvider.nameDuration)))
|
||||||
.setReturnType(new ReturnType().setType(PropertyProvider.nameString).setCollection(true))
|
.setReturnType(new ReturnType().setType(PropertyProvider.nameString).setCollection(true)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUARTCTTwoPrimParam)) {
|
} else if (actionName.equals(nameUARTCTTwoPrimParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTCTTwoPrimParam.getName())
|
new Action().setName(nameUARTCTTwoPrimParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Collections.singletonList(
|
||||||
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)
|
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)
|
||||||
.setNullable(false)))
|
.setNullable(false)))
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(ComplexTypeProvider.nameCTTwoPrim).setNullable(false))
|
new ReturnType().setType(ComplexTypeProvider.nameCTTwoPrim).setNullable(false)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUARTCollCTTwoPrimParam)) {
|
} else if (actionName.equals(nameUARTCollCTTwoPrimParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTCollCTTwoPrimParam.getName())
|
new Action().setName(nameUARTCollCTTwoPrimParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Collections.singletonList(
|
||||||
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)))
|
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)))
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(ComplexTypeProvider.nameCTTwoPrim).setCollection(true))
|
new ReturnType().setType(ComplexTypeProvider.nameCTTwoPrim).setCollection(true)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUARTETTwoKeyTwoPrimParam)) {
|
} else if (actionName.equals(nameUARTETTwoKeyTwoPrimParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTETTwoKeyTwoPrimParam.getName())
|
new Action().setName(nameUARTETTwoKeyTwoPrimParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Collections.singletonList(
|
||||||
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)))
|
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)))
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETTwoKeyTwoPrim))
|
new ReturnType().setType(EntityTypeProvider.nameETTwoKeyTwoPrim)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUARTCollETKeyNavParam)) {
|
} else if (actionName.equals(nameUARTCollETKeyNavParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTCollETKeyNavParam.getName())
|
new Action().setName(nameUARTCollETKeyNavParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Collections.singletonList(
|
||||||
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)))
|
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16)))
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETKeyNav).setCollection(true))
|
new ReturnType().setType(EntityTypeProvider.nameETKeyNav).setCollection(true)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUARTETAllPrimParam)) {
|
} else if (actionName.equals(nameUARTETAllPrimParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTETAllPrimParam.getName())
|
new Action().setName(nameUARTETAllPrimParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Collections.singletonList(
|
||||||
new Parameter().setName("ParameterDate").setType(PropertyProvider.nameDate)))
|
new Parameter().setName("ParameterDate").setType(PropertyProvider.nameDate)))
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETAllPrim))
|
new ReturnType().setType(EntityTypeProvider.nameETAllPrim)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUARTCollETAllPrimParam)) {
|
} else if (actionName.equals(nameUARTCollETAllPrimParam)) {
|
||||||
return Arrays.asList(
|
return Collections.singletonList(
|
||||||
new Action().setName(nameUARTCollETAllPrimParam.getName())
|
new Action().setName(nameUARTCollETAllPrimParam.getName())
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Collections.singletonList(
|
||||||
new Parameter().setName("ParameterTimeOfDay")
|
new Parameter().setName("ParameterTimeOfDay")
|
||||||
.setType(PropertyProvider.nameTimeOfDay)))
|
.setType(PropertyProvider.nameTimeOfDay)))
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETAllPrim).setCollection(true))
|
new ReturnType().setType(EntityTypeProvider.nameETAllPrim).setCollection(true)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameUART)) {
|
} else if (actionName.equals(nameUART)) {
|
||||||
return Collections.singletonList(new Action().setName(nameUART.getName()));
|
return Collections.singletonList(new Action().setName(nameUART.getName()));
|
||||||
|
@ -186,26 +183,22 @@ public class ActionProvider {
|
||||||
} else if (actionName.equals(nameBAESAllPrimRTETAllPrim)) {
|
} else if (actionName.equals(nameBAESAllPrimRTETAllPrim)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Action().setName("BAESAllPrimRTETAllPrim")
|
new Action().setName("BAESAllPrimRTETAllPrim")
|
||||||
.setParameters(
|
.setParameters(Arrays.asList(
|
||||||
Arrays.asList(
|
|
||||||
new Parameter().setName("ParameterESAllPrim").setType(EntityTypeProvider.nameETAllPrim)
|
new Parameter().setName("ParameterESAllPrim").setType(EntityTypeProvider.nameETAllPrim)
|
||||||
.setCollection(true).setNullable(false)))
|
.setCollection(true).setNullable(false)))
|
||||||
.setBound(true)
|
.setBound(true)
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETAllPrim))
|
new ReturnType().setType(EntityTypeProvider.nameETAllPrim)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameBAESTwoKeyNavRTESTwoKeyNav)) {
|
} else if (actionName.equals(nameBAESTwoKeyNavRTESTwoKeyNav)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Action().setName("BAESTwoKeyNavRTESTwoKeyNav")
|
new Action().setName("BAESTwoKeyNavRTESTwoKeyNav")
|
||||||
.setParameters(
|
.setParameters(Arrays.asList(
|
||||||
Arrays.asList(
|
|
||||||
new Parameter().setName("ParameterETTwoKeyNav").setType(EntityTypeProvider.nameETTwoKeyNav)
|
new Parameter().setName("ParameterETTwoKeyNav").setType(EntityTypeProvider.nameETTwoKeyNav)
|
||||||
.setCollection(true).setNullable(false)))
|
.setCollection(true).setNullable(false)))
|
||||||
.setBound(true)
|
.setBound(true)
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETTwoKeyNav).setCollection(true))
|
new ReturnType().setType(EntityTypeProvider.nameETTwoKeyNav).setCollection(true)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if(actionName.equals(nameBAESTwoKeyNavRTESKeyNav)) {
|
} else if(actionName.equals(nameBAESTwoKeyNavRTESKeyNav)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
|
@ -216,10 +209,10 @@ public class ActionProvider {
|
||||||
new Parameter().setName("ParameterETTwoKeyNav")
|
new Parameter().setName("ParameterETTwoKeyNav")
|
||||||
.setType(EntityTypeProvider.nameETTwoKeyNav)
|
.setType(EntityTypeProvider.nameETTwoKeyNav)
|
||||||
.setCollection(true)
|
.setCollection(true)
|
||||||
.setNullable(false)
|
.setNullable(false)))
|
||||||
))
|
.setReturnType(
|
||||||
.setReturnType(new ReturnType().setType(EntityTypeProvider.nameETKeyNav).setCollection(true))
|
new ReturnType().setType(EntityTypeProvider.nameETKeyNav).setCollection(true)));
|
||||||
);
|
|
||||||
} else if (actionName.equals(nameBAETBaseTwoKeyNavRTETBaseTwoKeyNav)) {
|
} else if (actionName.equals(nameBAETBaseTwoKeyNavRTETBaseTwoKeyNav)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Action().setName("BAETBaseTwoKeyNavRTETBaseTwoKeyNav")
|
new Action().setName("BAETBaseTwoKeyNavRTETBaseTwoKeyNav")
|
||||||
|
@ -228,20 +221,19 @@ public class ActionProvider {
|
||||||
.setNullable(false)))
|
.setNullable(false)))
|
||||||
.setBound(true)
|
.setBound(true)
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETTwoKeyNav))
|
new ReturnType().setType(EntityTypeProvider.nameETTwoKeyNav)));
|
||||||
);
|
|
||||||
|
|
||||||
} else if (actionName.equals(nameBAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav)) {
|
} else if (actionName.equals(nameBAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Action().setName("BAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav")
|
new Action().setName("BAETTwoBaseTwoKeyNavRTETBaseTwoKeyNav")
|
||||||
.setParameters(
|
.setParameters(Arrays.asList(
|
||||||
Arrays.asList(
|
new Parameter().setName("ParameterETTwoBaseTwoKeyNav")
|
||||||
new Parameter().setName("ParameterETTwoBaseTwoKeyNav").setType(
|
.setType(EntityTypeProvider.nameETTwoBaseTwoKeyNav)
|
||||||
EntityTypeProvider.nameETTwoBaseTwoKeyNav).setNullable(false)))
|
.setNullable(false)))
|
||||||
.setBound(true)
|
.setBound(true)
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
new ReturnType().setType(EntityTypeProvider.nameETBaseTwoKeyNav))
|
new ReturnType().setType(EntityTypeProvider.nameETBaseTwoKeyNav)));
|
||||||
);
|
|
||||||
} else if(actionName.equals(nameBAETAllPrimRT)) {
|
} else if(actionName.equals(nameBAETAllPrimRT)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Action().setName("BAETAllPrimRT")
|
new Action().setName("BAETAllPrimRT")
|
||||||
|
@ -250,8 +242,10 @@ public class ActionProvider {
|
||||||
new Parameter().setName("ParameterETAllPrim")
|
new Parameter().setName("ParameterETAllPrim")
|
||||||
.setNullable(false)
|
.setNullable(false)
|
||||||
.setType(EntityTypeProvider.nameETAllPrim)
|
.setType(EntityTypeProvider.nameETAllPrim)
|
||||||
)),
|
)));
|
||||||
new Action().setName("BAETAllPrimRT")
|
} else if(actionName.equals(nameBAESAllPrimRT)) {
|
||||||
|
return Arrays.asList(
|
||||||
|
new Action().setName("BAESAllPrimRT")
|
||||||
.setBound(true)
|
.setBound(true)
|
||||||
.setParameters(Arrays.asList(
|
.setParameters(Arrays.asList(
|
||||||
new Parameter().setName("ParameterETAllPrim")
|
new Parameter().setName("ParameterETAllPrim")
|
||||||
|
|
|
@ -98,6 +98,8 @@ public class ContainerProvider {
|
||||||
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESCompMixPrimCollComp"));
|
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESCompMixPrimCollComp"));
|
||||||
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESFourKeyAlias"));
|
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESFourKeyAlias"));
|
||||||
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESMixEnumDefCollComp"));
|
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESMixEnumDefCollComp"));
|
||||||
|
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESTwoBaseTwoKeyNav"));
|
||||||
|
entitySets.add(prov.getEntitySet(ContainerProvider.nameContainer, "ESKeyNavCont"));
|
||||||
|
|
||||||
// Singletons
|
// Singletons
|
||||||
List<Singleton> singletons = new ArrayList<Singleton>();
|
List<Singleton> singletons = new ArrayList<Singleton>();
|
||||||
|
@ -135,6 +137,7 @@ public class ContainerProvider {
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCTAllPrimTwoParam"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCTAllPrimTwoParam"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTESMixPrimCollCompTwoParam"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTESMixPrimCollCompTwoParam"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollETMixPrimCollCompTwoParam"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollETMixPrimCollCompTwoParam"));
|
||||||
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FINRTCollETMixPrimCollCompTwoParam"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollCTTwoPrim"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollCTTwoPrim"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTESMedia"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTESMedia"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollESMedia"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollESMedia"));
|
||||||
|
@ -144,6 +147,8 @@ public class ContainerProvider {
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTString"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTString"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollESTwoKeyNavParam"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollESTwoKeyNavParam"));
|
||||||
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollCTTwoPrimParam"));
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollCTTwoPrimParam"));
|
||||||
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FINRTCollCTNavFiveProp"));
|
||||||
|
functionImports.add(prov.getFunctionImport(ContainerProvider.nameContainer, "FICRTCollESKeyNavContParam"));
|
||||||
|
|
||||||
return container;
|
return container;
|
||||||
}
|
}
|
||||||
|
@ -363,9 +368,6 @@ public class ContainerProvider {
|
||||||
new NavigationPropertyBinding()
|
new NavigationPropertyBinding()
|
||||||
.setPath("CollPropertyCompNav/NavPropertyETMediaMany")
|
.setPath("CollPropertyCompNav/NavPropertyETMediaMany")
|
||||||
.setTarget("ESMedia"),
|
.setTarget("ESMedia"),
|
||||||
new NavigationPropertyBinding()
|
|
||||||
.setPath("CollPropertyCompNav/NavPropertyETTwoKeyNavMany")
|
|
||||||
.setTarget("ESTwoKeyNav"),
|
|
||||||
new NavigationPropertyBinding()
|
new NavigationPropertyBinding()
|
||||||
.setPath("NavPropertyETTwoBaseTwoKeyNavOne")
|
.setPath("NavPropertyETTwoBaseTwoKeyNavOne")
|
||||||
.setTarget("ESBaseTwoKeyNav"),
|
.setTarget("ESBaseTwoKeyNav"),
|
||||||
|
@ -564,6 +566,12 @@ public class ContainerProvider {
|
||||||
.setFunction(FunctionProvider.nameUFCRTESMixPrimCollCompTwoParam)
|
.setFunction(FunctionProvider.nameUFCRTESMixPrimCollCompTwoParam)
|
||||||
.setIncludeInServiceDocument(true);
|
.setIncludeInServiceDocument(true);
|
||||||
|
|
||||||
|
} else if(name.equals("FINRTCollETMixPrimCollCompTwoParam")) {
|
||||||
|
return new FunctionImport()
|
||||||
|
.setName(name)
|
||||||
|
.setFunction(FunctionProvider.nameUFNRTCollETMixPrimCollCompTwoParam)
|
||||||
|
.setIncludeInServiceDocument(true);
|
||||||
|
|
||||||
} else if (name.equals("FICRTCollETMixPrimCollCompTwoParam")) {
|
} else if (name.equals("FICRTCollETMixPrimCollCompTwoParam")) {
|
||||||
return new FunctionImport()
|
return new FunctionImport()
|
||||||
.setName(name)
|
.setName(name)
|
||||||
|
@ -626,6 +634,18 @@ public class ContainerProvider {
|
||||||
.setFunction(FunctionProvider.nameUFCRTCollCTTwoPrimParam)
|
.setFunction(FunctionProvider.nameUFCRTCollCTTwoPrimParam)
|
||||||
.setIncludeInServiceDocument(true);
|
.setIncludeInServiceDocument(true);
|
||||||
|
|
||||||
|
} else if(name.equals("FINRTCollCTNavFiveProp")) {
|
||||||
|
return new FunctionImport()
|
||||||
|
.setName(name)
|
||||||
|
.setFunction(FunctionProvider.nameUFNRTCollCTNavFiveProp)
|
||||||
|
.setIncludeInServiceDocument(true);
|
||||||
|
|
||||||
|
} else if(name.equals("FICRTCollESKeyNavContParam")) {
|
||||||
|
return new FunctionImport()
|
||||||
|
.setName(name)
|
||||||
|
.setFunction(FunctionProvider.nameUFCRTCollETKeyNavContParam)
|
||||||
|
.setEntitySet("ESKeyNavCont")
|
||||||
|
.setIncludeInServiceDocument(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -176,6 +176,9 @@ public class FunctionProvider {
|
||||||
public static final FullQualifiedName nameUFNRTCollCTNavFiveProp = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
public static final FullQualifiedName nameUFNRTCollCTNavFiveProp = new FullQualifiedName(SchemaProvider.NAMESPACE,
|
||||||
"UFNRTCollCTNavFiveProp");
|
"UFNRTCollCTNavFiveProp");
|
||||||
|
|
||||||
|
public static final FullQualifiedName nameUFNRTCollETMixPrimCollCompTwoParam
|
||||||
|
= new FullQualifiedName(SchemaProvider.NAMESPACE, "UFNRTCollETMixPrimCollCompTwoParam");
|
||||||
|
|
||||||
public List<Function> getFunctions(final FullQualifiedName functionName) throws ODataException {
|
public List<Function> getFunctions(final FullQualifiedName functionName) throws ODataException {
|
||||||
|
|
||||||
if (functionName.equals(nameUFNRTInt16)) {
|
if (functionName.equals(nameUFNRTInt16)) {
|
||||||
|
@ -332,6 +335,20 @@ public class FunctionProvider {
|
||||||
new ReturnType().setType(ComplexTypeProvider.nameCTAllPrim).setNullable(false))
|
new ReturnType().setType(ComplexTypeProvider.nameCTAllPrim).setNullable(false))
|
||||||
);
|
);
|
||||||
|
|
||||||
|
} else if(functionName.equals(nameUFNRTCollETMixPrimCollCompTwoParam)) {
|
||||||
|
return Arrays.asList(
|
||||||
|
new Function()
|
||||||
|
.setName("UFNRTCollETMixPrimCollCompTwoParam")
|
||||||
|
.setParameters(Arrays.asList(
|
||||||
|
new Parameter().setName("ParameterString").setType(PropertyProvider.nameString).setNullable(false),
|
||||||
|
new Parameter().setName("ParameterInt16").setType(PropertyProvider.nameInt16).setNullable(false)))
|
||||||
|
.setComposable(false)
|
||||||
|
.setBound(false)
|
||||||
|
.setReturnType(
|
||||||
|
new ReturnType().setType(ComplexTypeProvider.nameCTMixPrimCollComp)
|
||||||
|
.setNullable(false)
|
||||||
|
.setCollection(true))
|
||||||
|
);
|
||||||
} else if (functionName.equals(nameUFCRTCTTwoPrimParam)) {
|
} else if (functionName.equals(nameUFCRTCTTwoPrimParam)) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
new Function()
|
new Function()
|
||||||
|
@ -855,7 +872,7 @@ public class FunctionProvider {
|
||||||
Arrays.asList(
|
Arrays.asList(
|
||||||
new Parameter().setName("BindingParam").setType(EntityTypeProvider.nameETTwoKeyNav)
|
new Parameter().setName("BindingParam").setType(EntityTypeProvider.nameETTwoKeyNav)
|
||||||
.setCollection(true).setNullable(false),
|
.setCollection(true).setNullable(false),
|
||||||
new Parameter().setName("ParameterComplex").setType(ComplexTypeProvider.nameCTTwoPrim)
|
new Parameter().setName("ParameterComp").setType(ComplexTypeProvider.nameCTTwoPrim)
|
||||||
.setNullable(false)))
|
.setNullable(false)))
|
||||||
.setComposable(true)
|
.setComposable(true)
|
||||||
.setReturnType(
|
.setReturnType(
|
||||||
|
|
|
@ -733,7 +733,7 @@ public class PropertyProvider {
|
||||||
.setType(EntityTypeProvider.nameETKeyNav);
|
.setType(EntityTypeProvider.nameETKeyNav);
|
||||||
|
|
||||||
public static final NavigationProperty navPropertyETTwoKeyNavContOneCT_ETTwoKeyNav = new NavigationProperty()
|
public static final NavigationProperty navPropertyETTwoKeyNavContOneCT_ETTwoKeyNav = new NavigationProperty()
|
||||||
.setName("NavPropertyETKeyNavContOne")
|
.setName("NavPropertyETTwoKeyNavContOne")
|
||||||
.setContainsTarget(true)
|
.setContainsTarget(true)
|
||||||
.setType(EntityTypeProvider.nameETTwoKeyNav);
|
.setType(EntityTypeProvider.nameETTwoKeyNav);
|
||||||
|
|
||||||
|
|
|
@ -185,6 +185,7 @@ public class SchemaProvider {
|
||||||
functions.addAll(prov.getFunctions(FunctionProvider.nameBFCESTwoKeyNavRTStringParam));
|
functions.addAll(prov.getFunctions(FunctionProvider.nameBFCESTwoKeyNavRTStringParam));
|
||||||
functions.addAll(prov.getFunctions(FunctionProvider.nameBFCESKeyNavRTETKeyNavParam));
|
functions.addAll(prov.getFunctions(FunctionProvider.nameBFCESKeyNavRTETKeyNavParam));
|
||||||
functions.addAll(prov.getFunctions(FunctionProvider.nameBFCCTPrimCompRTETTwoKeyNavParam));
|
functions.addAll(prov.getFunctions(FunctionProvider.nameBFCCTPrimCompRTETTwoKeyNavParam));
|
||||||
|
functions.addAll(prov.getFunctions(FunctionProvider.nameUFNRTCollETMixPrimCollCompTwoParam));
|
||||||
// functions.addAll(prov.getFunctions(FunctionProvider.nameBFCCTPrimCompRTESTwoKeyNavParam));
|
// functions.addAll(prov.getFunctions(FunctionProvider.nameBFCCTPrimCompRTESTwoKeyNavParam));
|
||||||
|
|
||||||
// EntityContainer
|
// EntityContainer
|
||||||
|
|
|
@ -57,6 +57,29 @@ public class ODataJsonDeserializerActionParametersTest extends AbstractODataDese
|
||||||
assertEquals(BigDecimal.valueOf(3669753), parameter.getValue());
|
assertEquals(BigDecimal.valueOf(3669753), parameter.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void boundEmpty() throws Exception {
|
||||||
|
final String input = "{}";
|
||||||
|
final List<Parameter> parameters = deserialize(input, "BAETAllPrimRT", "ETAllPrim");
|
||||||
|
assertNotNull(parameters);
|
||||||
|
assertTrue(parameters.isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = DeserializerException.class)
|
||||||
|
public void bindingParameter() throws Exception {
|
||||||
|
deserialize("{\"ParameterETAllPrim\":{\"PropertyInt16\":42}}", "BAETAllPrimRT", "ETAllPrim");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = DeserializerException.class)
|
||||||
|
public void wrongName() throws Exception {
|
||||||
|
deserialize("{\"ParameterWrong\":null}", "UARTParam");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = DeserializerException.class)
|
||||||
|
public void nullNotNullable() throws Exception {
|
||||||
|
deserialize("{\"ParameterInt16\":null}", "UARTCTTwoPrimParam");
|
||||||
|
}
|
||||||
|
|
||||||
@Test(expected = DeserializerException.class)
|
@Test(expected = DeserializerException.class)
|
||||||
public void missingParameter() throws Exception {
|
public void missingParameter() throws Exception {
|
||||||
deserialize("{}", "UARTCTTwoPrimParam");
|
deserialize("{}", "UARTCTTwoPrimParam");
|
||||||
|
@ -77,4 +100,12 @@ public class ODataJsonDeserializerActionParametersTest extends AbstractODataDese
|
||||||
.actionParameters(new ByteArrayInputStream(input.getBytes()),
|
.actionParameters(new ByteArrayInputStream(input.getBytes()),
|
||||||
edm.getUnboundAction(new FullQualifiedName("Namespace1_Alias", actionName)));
|
edm.getUnboundAction(new FullQualifiedName("Namespace1_Alias", actionName)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<Parameter> deserialize(final String input, final String actionName, final String typeName)
|
||||||
|
throws DeserializerException {
|
||||||
|
return OData.newInstance().createDeserializer(ODataFormat.JSON)
|
||||||
|
.actionParameters(new ByteArrayInputStream(input.getBytes()),
|
||||||
|
edm.getBoundAction(new FullQualifiedName("Namespace1_Alias", actionName),
|
||||||
|
new FullQualifiedName("Namespace1_Alias", typeName), false));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -286,7 +286,7 @@ public class FilterValidator implements TestValidator {
|
||||||
* Validates the serialized filterTree against a given filterString
|
* Validates the serialized filterTree against a given filterString
|
||||||
* The given expected filterString is compressed before to allow better readable code in the unit tests
|
* The given expected filterString is compressed before to allow better readable code in the unit tests
|
||||||
* @param toBeCompr
|
* @param toBeCompr
|
||||||
* @return
|
* @return {@link FilterValidator}
|
||||||
*/
|
*/
|
||||||
public FilterValidator isCompr(final String toBeCompr) {
|
public FilterValidator isCompr(final String toBeCompr) {
|
||||||
return is(compress(toBeCompr));
|
return is(compress(toBeCompr));
|
||||||
|
|
|
@ -57,7 +57,7 @@ public class ParserValidator {
|
||||||
* Used in fast LL Parsing:
|
* Used in fast LL Parsing:
|
||||||
* Don't stop the parsing process when the slower full context parsing (with prediction mode SLL) is
|
* Don't stop the parsing process when the slower full context parsing (with prediction mode SLL) is
|
||||||
* required
|
* required
|
||||||
* @return
|
* @return {@link ParserValidator}
|
||||||
*/
|
*/
|
||||||
public ParserValidator aFC() {
|
public ParserValidator aFC() {
|
||||||
allowFullContext = true;
|
allowFullContext = true;
|
||||||
|
@ -68,7 +68,7 @@ public class ParserValidator {
|
||||||
* Used in fast LL Parsing:
|
* Used in fast LL Parsing:
|
||||||
* Allows ContextSensitifity Errors which occur often when using the slower full context parsing
|
* Allows ContextSensitifity Errors which occur often when using the slower full context parsing
|
||||||
* and indicate that there is a context sensitivity ( which may not be an error).
|
* and indicate that there is a context sensitivity ( which may not be an error).
|
||||||
* @return
|
* @return {@link ParserValidator}
|
||||||
*/
|
*/
|
||||||
public ParserValidator aCS() {
|
public ParserValidator aCS() {
|
||||||
allowContextSensitifity = true;
|
allowContextSensitifity = true;
|
||||||
|
@ -78,7 +78,7 @@ public class ParserValidator {
|
||||||
/**
|
/**
|
||||||
* Used in fast LL Parsing:
|
* Used in fast LL Parsing:
|
||||||
* Allows ambiguities
|
* Allows ambiguities
|
||||||
* @return
|
* @return {@link ParserValidator}
|
||||||
*/
|
*/
|
||||||
public ParserValidator aAM() {
|
public ParserValidator aAM() {
|
||||||
allowAmbiguity = true;
|
allowAmbiguity = true;
|
||||||
|
|
Loading…
Reference in New Issue