[OLINGO-852] less warnings + general clean-up

Signed-off-by: Christian Amend <christian.amend@sap.com>
This commit is contained in:
Klaus Straubinger 2016-02-04 12:28:35 +01:00 committed by Christian Amend
parent 110c7b0e5a
commit 5d7c1287f0
68 changed files with 2230 additions and 3058 deletions

View File

@ -69,7 +69,7 @@ abstract class AbstractInvocationHandler implements InvocationHandler {
return service.getContext(); return service.getContext();
} }
protected boolean isSelfMethod(final Method method, final Object[] args) { protected boolean isSelfMethod(final Method method) {
final Method[] selfMethods = getClass().getMethods(); final Method[] selfMethods = getClass().getMethods();
boolean result = false; boolean result = false;
@ -161,7 +161,7 @@ abstract class AbstractInvocationHandler implements InvocationHandler {
CoreUtils.addProperties(getClient(), handler.getPropertyChanges(), template); CoreUtils.addProperties(getClient(), handler.getPropertyChanges(), template);
final Object key = CoreUtils.getKey(getClient(), handler, handler.getUUID().getType(), template); final Object key = CoreUtils.getKey(getClient(), handler, handler.getUUID().getType(), template);
entityURI = CoreUtils.buildEditLink(getClient(), baseURI.toASCIIString(), template, key).build(); entityURI = CoreUtils.buildEditLink(getClient(), baseURI.toASCIIString(), key).build();
template.setEditLink(entityURI); template.setEditLink(entityURI);
} else { } else {
entityURI = handler.getEntityURI(); entityURI = handler.getEntityURI();
@ -182,32 +182,25 @@ abstract class AbstractInvocationHandler implements InvocationHandler {
} }
} }
protected static URIBuilder buildEntitySetURI( protected static URIBuilder buildEntitySetURI(final Class<?> ref, final AbstractService<?> service) {
final Class<?> ref,
final AbstractService<?> service) {
final String containerNS;
final String entitySetName; final String entitySetName;
Annotation ann = ref.getAnnotation(EntitySet.class); Annotation ann = ref.getAnnotation(EntitySet.class);
if (ann instanceof EntitySet) { if (ann instanceof EntitySet) {
containerNS = EntitySet.class.cast(ann).container();
entitySetName = EntitySet.class.cast(ann).name(); entitySetName = EntitySet.class.cast(ann).name();
} else { } else {
ann = ref.getAnnotation(Singleton.class); ann = ref.getAnnotation(Singleton.class);
if (ann instanceof Singleton) { if (ann instanceof Singleton) {
containerNS = Singleton.class.cast(ann).container();
entitySetName = Singleton.class.cast(ann).name(); entitySetName = Singleton.class.cast(ann).name();
} else { } else {
containerNS = null;
entitySetName = null; entitySetName = null;
} }
} }
return buildEntitySetURI(containerNS, entitySetName, service); return buildEntitySetURI(entitySetName, service);
} }
protected static URIBuilder buildEntitySetURI( protected static URIBuilder buildEntitySetURI(final String entitySetName, final AbstractService<?> service) {
final String containerNS, final String entitySetName, final AbstractService<?> service) {
final URIBuilder uriBuilder = service.getClient().newURIBuilder(); final URIBuilder uriBuilder = service.getClient().newURIBuilder();
final StringBuilder entitySetSegment = new StringBuilder(); final StringBuilder entitySetSegment = new StringBuilder();

View File

@ -210,7 +210,7 @@ public abstract class AbstractStructuredInvocationHandler extends AbstractInvoca
|| "refs".equals(method.getName())) { || "refs".equals(method.getName())) {
invokeSelfMethod(method, args); invokeSelfMethod(method, args);
return proxy; return proxy;
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else if ("load".equals(method.getName()) && ArrayUtils.isEmpty(args)) { } else if ("load".equals(method.getName()) && ArrayUtils.isEmpty(args)) {
load(); load();

View File

@ -55,7 +55,7 @@ public class AnnotatationsInvocationHandler extends AbstractInvocationHandler {
@Override @Override
public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable { public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable {
if (isSelfMethod(method, args)) { if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else if (method.getName().startsWith("get") && method.getName().endsWith("Annotations")) { } else if (method.getName().startsWith("get") && method.getName().endsWith("Annotations")) {
final Method getter = proxy.getClass().getInterfaces()[0].getMethod(method.getName()); final Method getter = proxy.getClass().getInterfaces()[0].getMethod(method.getName());

View File

@ -80,7 +80,7 @@ public class ComplexCollectionInvocationHandler<T extends ComplexType<?>>
invokeSelfMethod(method, args); invokeSelfMethod(method, args);
return proxy; return proxy;
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) { } else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) {
final Class<?> returnType = method.getReturnType(); final Class<?> returnType = method.getReturnType();

View File

@ -63,11 +63,7 @@ public class ComplexInvocationHandler extends AbstractStructuredInvocationHandle
return new ImmutablePair<ClientComplexValue, Class<?>>(complex, complexTypeRef); return new ImmutablePair<ClientComplexValue, Class<?>>(complex, complexTypeRef);
} }
public static ComplexInvocationHandler getInstance( public static ComplexInvocationHandler getInstance(final EntityInvocationHandler handler, final Class<?> typeRef) {
final String propertyName,
final EntityInvocationHandler handler,
final Class<?> typeRef) {
final Pair<ClientComplexValue, Class<?>> init = init(typeRef, handler.service); final Pair<ClientComplexValue, Class<?>> init = init(typeRef, handler.service);
return new ComplexInvocationHandler(init.getLeft(), init.getRight(), handler); return new ComplexInvocationHandler(init.getLeft(), init.getRight(), handler);
} }

View File

@ -59,7 +59,7 @@ public class EdmStreamValueHandler extends AbstractInvocationHandler {
load(); load();
return proxy; return proxy;
} else { } else {
if (isSelfMethod(method, args)) { if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else { } else {
throw new NoSuchMethodException(method.getName()); throw new NoSuchMethodException(method.getName());

View File

@ -62,7 +62,7 @@ public class EntityCollectionInvocationHandler<T extends EntityType<?>>
|| "execute".equals(method.getName())) { || "execute".equals(method.getName())) {
invokeSelfMethod(method, args); invokeSelfMethod(method, args);
return proxy; return proxy;
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) { } else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) {
final Class<?> returnType = method.getReturnType(); final Class<?> returnType = method.getReturnType();

View File

@ -80,7 +80,7 @@ public final class EntityContainerInvocationHandler extends AbstractInvocationHa
@Override @Override
public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable { public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable {
if (isSelfMethod(method, args)) { if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else if ("flush".equals(method.getName()) && ArrayUtils.isEmpty(args)) { } else if ("flush".equals(method.getName()) && ArrayUtils.isEmpty(args)) {
service.getPersistenceManager().flush(); service.getPersistenceManager().flush();
@ -114,7 +114,7 @@ public final class EntityContainerInvocationHandler extends AbstractInvocationHa
final Class<?> typeRef = method.getReturnType(); final Class<?> typeRef = method.getReturnType();
final Singleton singleton = method.getAnnotation(Singleton.class); final Singleton singleton = method.getAnnotation(Singleton.class);
final URI uri = buildEntitySetURI(singleton.container(), singleton.name(), service).build(); final URI uri = buildEntitySetURI(singleton.name(), service).build();
final EntityUUID uuid = new EntityUUID(uri, typeRef); final EntityUUID uuid = new EntityUUID(uri, typeRef);
LOG.debug("Ask for singleton '{}'", typeRef.getSimpleName()); LOG.debug("Ask for singleton '{}'", typeRef.getSimpleName());

View File

@ -191,7 +191,7 @@ public class EntityInvocationHandler extends AbstractStructuredInvocationHandler
this.uri = getClient().newURIBuilder(baseURI.toASCIIString()); this.uri = getClient().newURIBuilder(baseURI.toASCIIString());
} else if (key != null) { } else if (key != null) {
final URIBuilder uriBuilder = final URIBuilder uriBuilder =
CoreUtils.buildEditLink(getClient(), entitySetURI.toASCIIString(), entity, key); CoreUtils.buildEditLink(getClient(), entitySetURI.toASCIIString(), key);
this.uri = uriBuilder; this.uri = uriBuilder;
this.baseURI = this.uri.build(); this.baseURI = this.uri.build();
@ -219,7 +219,7 @@ public class EntityInvocationHandler extends AbstractStructuredInvocationHandler
if (this.uri == null) { if (this.uri == null) {
final URIBuilder uriBuilder = final URIBuilder uriBuilder =
entity.getEditLink() == null entity.getEditLink() == null
? CoreUtils.buildEditLink(getClient(), getUUID().getEntitySetURI().toASCIIString(), entity, key) ? CoreUtils.buildEditLink(getClient(), getUUID().getEntitySetURI().toASCIIString(), key)
: getClient().newURIBuilder(entity.getEditLink().toASCIIString()); : getClient().newURIBuilder(entity.getEditLink().toASCIIString());
this.uri = uriBuilder; this.uri = uriBuilder;
@ -252,7 +252,7 @@ public class EntityInvocationHandler extends AbstractStructuredInvocationHandler
if (this.uri == null) { if (this.uri == null) {
final URIBuilder uriBuilder = final URIBuilder uriBuilder =
getEntity().getEditLink() == null getEntity().getEditLink() == null
? CoreUtils.buildEditLink(getClient(), entitySetURI.toASCIIString(), getEntity(), key) ? CoreUtils.buildEditLink(getClient(), entitySetURI.toASCIIString(), key)
: getClient().newURIBuilder(getEntity().getEditLink().toASCIIString()); : getClient().newURIBuilder(getEntity().getEditLink().toASCIIString());
this.uri = uriBuilder; this.uri = uriBuilder;

View File

@ -84,7 +84,7 @@ public class EntitySetInvocationHandler<
invokeSelfMethod(method, args); invokeSelfMethod(method, args);
return proxy; return proxy;
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else { } else {
throw new NoSuchMethodException(method.getName()); throw new NoSuchMethodException(method.getName());

View File

@ -276,7 +276,7 @@ public class InvokerInvocationHandler<T, O extends Operations> extends AbstractI
return Proxy.newProxyInstance( return Proxy.newProxyInstance(
Thread.currentThread().getContextClassLoader(), Thread.currentThread().getContextClassLoader(),
new Class<?>[] {operationRef}, handler); new Class<?>[] {operationRef}, handler);
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else { } else {
throw new NoSuchMethodException(method.getName()); throw new NoSuchMethodException(method.getName());

View File

@ -133,7 +133,7 @@ final class OperationInvocationHandler extends AbstractInvocationHandler {
@Override @Override
@SuppressWarnings({"unchecked", "rawtypes"}) @SuppressWarnings({"unchecked", "rawtypes"})
public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable { public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable {
if (isSelfMethod(method, args)) { if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else { } else {
final Operation operation = method.getAnnotation(Operation.class); final Operation operation = method.getAnnotation(Operation.class);

View File

@ -75,7 +75,7 @@ public class PrimitiveCollectionInvocationHandler<T extends Serializable>
invokeSelfMethod(method, args); invokeSelfMethod(method, args);
return proxy; return proxy;
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) { } else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) {
final Class<?> returnType = method.getReturnType(); final Class<?> returnType = method.getReturnType();

View File

@ -75,7 +75,7 @@ public class StructuredComposableInvokerInvocationHandler<T, O extends Operation
return super.invoke(proxy, method, args); return super.invoke(proxy, method, args);
} else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) { } else if ("operations".equals(method.getName()) && ArrayUtils.isEmpty(args)) {
return super.invoke(proxy, method, args); return super.invoke(proxy, method, args);
} else if (isSelfMethod(method, args)) { } else if (isSelfMethod(method)) {
return invokeSelfMethod(method, args); return invokeSelfMethod(method, args);
} else { } else {
throw new NoSuchMethodException(method.getName()); throw new NoSuchMethodException(method.getName());

View File

@ -378,7 +378,6 @@ public final class CoreUtils {
public static URIBuilder buildEditLink( public static URIBuilder buildEditLink(
final EdmEnabledODataClient client, final EdmEnabledODataClient client,
final String entitySetURI, final String entitySetURI,
final ClientEntity entity,
final Object key) { final Object key) {
if (key == null) { if (key == null) {
@ -506,7 +505,7 @@ public final class CoreUtils {
final Object complex = Proxy.newProxyInstance( final Object complex = Proxy.newProxyInstance(
Thread.currentThread().getContextClassLoader(), Thread.currentThread().getContextClassLoader(),
new Class<?>[] { getter.getReturnType() }, new Class<?>[] { getter.getReturnType() },
ComplexInvocationHandler.getInstance(property.getName(), typeHandler, getter.getReturnType())); ComplexInvocationHandler.getInstance(typeHandler, getter.getReturnType()));
populate(client, typeHandler, complex, Property.class, property.getValue().asComplex().iterator()); populate(client, typeHandler, complex, Property.class, property.getValue().asComplex().iterator());
setPropertyValue(bean, getter, complex); setPropertyValue(bean, getter, complex);
@ -530,7 +529,7 @@ public final class CoreUtils {
final Object collItem = Proxy.newProxyInstance( final Object collItem = Proxy.newProxyInstance(
Thread.currentThread().getContextClassLoader(), Thread.currentThread().getContextClassLoader(),
new Class<?>[] { collItemClass }, new Class<?>[] { collItemClass },
ComplexInvocationHandler.getInstance(property.getName(), typeHandler, collItemClass)); ComplexInvocationHandler.getInstance(typeHandler, collItemClass));
populate(client, typeHandler, collItem, Property.class, value.asComplex().iterator()); populate(client, typeHandler, collItem, Property.class, value.asComplex().iterator());
collection.add(collItem); collection.add(collItem);

File diff suppressed because it is too large Load Diff

View File

@ -40,7 +40,6 @@ import javax.ws.rs.core.UriInfo;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.apache.olingo.fit.metadata.Metadata; import org.apache.olingo.fit.metadata.Metadata;
import org.apache.olingo.fit.methods.PATCH; import org.apache.olingo.fit.methods.PATCH;
import org.apache.olingo.fit.utils.Accept; import org.apache.olingo.fit.utils.Accept;
@ -54,7 +53,7 @@ import org.springframework.stereotype.Service;
public class Demo extends Services { public class Demo extends Services {
public Demo() throws IOException { public Demo() throws IOException {
super(new Metadata(FSManager.instance(ODataServiceVersion.V40). super(new Metadata(FSManager.instance().
readRes("demo" + StringUtils.capitalize(Constants.get(ConstantKey.METADATA)), Accept.XML))); readRes("demo" + StringUtils.capitalize(Constants.get(ConstantKey.METADATA)), Accept.XML)));
} }
@ -166,9 +165,8 @@ public class Demo extends Services {
@HeaderParam("Prefer") @DefaultValue(StringUtils.EMPTY) final String prefer, @HeaderParam("Prefer") @DefaultValue(StringUtils.EMPTY) final String prefer,
@PathParam("entitySetName") final String entitySetName, @PathParam("entitySetName") final String entitySetName,
@PathParam("entityId") final String entityId, @PathParam("entityId") final String entityId,
@QueryParam("$format") @DefaultValue(StringUtils.EMPTY) final String format,
final String value) { final String value) {
return super.replaceMediaEntity(uriInfo, prefer, entitySetName, entityId, format, value); return super.replaceMediaEntity(uriInfo, prefer, entitySetName, entityId, value);
} }
} }

View File

@ -40,7 +40,6 @@ import javax.ws.rs.core.UriInfo;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.apache.olingo.fit.metadata.Metadata; import org.apache.olingo.fit.metadata.Metadata;
import org.apache.olingo.fit.utils.Accept; import org.apache.olingo.fit.utils.Accept;
import org.apache.olingo.fit.utils.ConstantKey; import org.apache.olingo.fit.utils.ConstantKey;
@ -53,8 +52,8 @@ import org.springframework.stereotype.Service;
public class OpenType extends Services { public class OpenType extends Services {
public OpenType() throws IOException { public OpenType() throws IOException {
super(new Metadata(FSManager.instance(ODataServiceVersion.V40). super(new Metadata(FSManager.instance()
readRes("openType" + StringUtils.capitalize(Constants.get(ConstantKey.METADATA)), Accept.XML))); .readRes("openType" + StringUtils.capitalize(Constants.get(ConstantKey.METADATA)), Accept.XML)));
} }
private Response replaceServiceName(final Response response) { private Response replaceServiceName(final Response response) {

File diff suppressed because it is too large Load Diff

View File

@ -27,7 +27,6 @@ import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.apache.olingo.fit.metadata.Metadata; import org.apache.olingo.fit.metadata.Metadata;
import org.apache.olingo.fit.utils.Accept; import org.apache.olingo.fit.utils.Accept;
import org.apache.olingo.fit.utils.ConstantKey; import org.apache.olingo.fit.utils.ConstantKey;
@ -43,8 +42,8 @@ public class Vocabularies {
private final XMLUtilities xml; private final XMLUtilities xml;
public Vocabularies() throws IOException { public Vocabularies() throws IOException {
Metadata metadata = new Metadata(FSManager.instance(ODataServiceVersion.V40).readRes( Metadata metadata = new Metadata(FSManager.instance()
"vocabularies-" + Constants.get(ConstantKey.METADATA), Accept.XML)); .readRes("vocabularies-" + Constants.get(ConstantKey.METADATA), Accept.XML));
xml = new XMLUtilities(metadata); xml = new XMLUtilities(metadata);
} }
@ -55,8 +54,7 @@ public class Vocabularies {
try { try {
return xml.createResponse( return xml.createResponse(
null, null,
FSManager.instance(ODataServiceVersion.V40).readRes( FSManager.instance().readRes("vocabularies-" + Constants.get(ConstantKey.METADATA), Accept.XML),
"vocabularies-" + Constants.get(ConstantKey.METADATA), Accept.XML),
null, null,
Accept.XML); Accept.XML);
} catch (Exception e) { } catch (Exception e) {
@ -71,7 +69,7 @@ public class Vocabularies {
try { try {
return xml.createResponse( return xml.createResponse(
null, null,
FSManager.instance(ODataServiceVersion.V40).readFile(vocabulary, null), FSManager.instance().readFile(vocabulary, null),
null, null,
Accept.XML); Accept.XML);
} catch (Exception e) { } catch (Exception e) {

View File

@ -24,18 +24,10 @@ import java.util.Map;
public class EntitySet extends AbstractMetadataElement { public class EntitySet extends AbstractMetadataElement {
private final String name; private final String name;
private String type; private String type;
private final boolean singleton; private final boolean singleton;
// --------------------------
// V4 only
// --------------------------
private final Map<String, String> binding; private final Map<String, String> binding;
// --------------------------
public EntitySet(final String name, final boolean singleton) { public EntitySet(final String name, final boolean singleton) {
this.name = name; this.name = name;
this.singleton = singleton; this.singleton = singleton;

View File

@ -19,14 +19,13 @@
package org.apache.olingo.fit.rest; package org.apache.olingo.fit.rest;
import javax.ws.rs.container.ContainerRequestContext; import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerRequestFilter;
import javax.ws.rs.ext.Provider; import javax.ws.rs.ext.Provider;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.cxf.rs.security.oauth2.filters.OAuthRequestFilter; import org.apache.cxf.rs.security.oauth2.filters.OAuthRequestFilter;
@Provider @Provider
public class OAuth2RequestFilter extends OAuthRequestFilter implements ContainerRequestFilter { public class OAuth2RequestFilter extends OAuthRequestFilter {
@Override @Override
public void filter(final ContainerRequestContext context) { public void filter(final ContainerRequestContext context) {

View File

@ -21,7 +21,6 @@ package org.apache.olingo.fit.serializer;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.nio.charset.CharsetDecoder;
import java.nio.charset.CodingErrorAction; import java.nio.charset.CodingErrorAction;
import javax.xml.stream.XMLEventReader; import javax.xml.stream.XMLEventReader;
@ -32,19 +31,15 @@ import org.apache.olingo.commons.api.Constants;
public class FITAtomDeserializer extends AtomDeserializer { public class FITAtomDeserializer extends AtomDeserializer {
private static final Charset ENCODING = Charset.forName(Constants.UTF8);
public FITAtomDeserializer() { public FITAtomDeserializer() {
super(); super();
} }
@Override @Override
protected XMLEventReader getReader(final InputStream input) throws XMLStreamException { protected XMLEventReader getReader(final InputStream input) throws XMLStreamException {
final CharsetDecoder decoder = ENCODING.newDecoder(); return FACTORY.createXMLEventReader(new InputStreamReader(input,
decoder.onMalformedInput(CodingErrorAction.IGNORE); Charset.forName(Constants.UTF8).newDecoder()
decoder.onUnmappableCharacter(CodingErrorAction.IGNORE); .onMalformedInput(CodingErrorAction.IGNORE)
.onUnmappableCharacter(CodingErrorAction.IGNORE)));
return FACTORY.createXMLEventReader(new InputStreamReader(input, decoder));
} }
} }

View File

@ -34,7 +34,6 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.UUID; import java.util.UUID;
import java.util.regex.Pattern;
import javax.ws.rs.NotFoundException; import javax.ws.rs.NotFoundException;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
@ -70,38 +69,19 @@ public abstract class AbstractUtilities {
*/ */
protected static final Logger LOG = LoggerFactory.getLogger(AbstractUtilities.class); protected static final Logger LOG = LoggerFactory.getLogger(AbstractUtilities.class);
protected static final Pattern ENTITY_URI_PATTERN = Pattern.compile(".*\\/.*\\(.*\\)");
/**
* Batch/Changeset content type.
*/
public static final String MULTIPART_CONTENT_TYPE = "multipart/mixed";
/**
* Batch item content type.
*/
public static final String ITEM_CONTENT_TYPE = "application/http";
/**
* Boundary key.
*/
public static final String BOUNDARY = "boundary";
protected final Metadata metadata; protected final Metadata metadata;
protected final FSManager fsManager; protected final FSManager fsManager;
protected final ODataDeserializer atomDeserializer; protected final ODataDeserializer atomDeserializer;
protected final ODataDeserializer jsonDeserializer; protected final ODataDeserializer jsonDeserializer;
protected final ODataSerializer atomSerializer; protected final ODataSerializer atomSerializer;
protected final ODataSerializer jsonSerializer; protected final ODataSerializer jsonSerializer;
public AbstractUtilities(final Metadata metadata) throws IOException { public AbstractUtilities(final Metadata metadata) throws IOException {
this.metadata = metadata; this.metadata = metadata;
fsManager = FSManager.instance(ODataServiceVersion.V40); fsManager = FSManager.instance();
atomDeserializer = new FITAtomDeserializer(); atomDeserializer = new FITAtomDeserializer();
jsonDeserializer = new JsonDeserializer(true); jsonDeserializer = new JsonDeserializer(true);
atomSerializer = new AtomSerializer(true); atomSerializer = new AtomSerializer(true);

View File

@ -20,33 +20,31 @@ package org.apache.olingo.fit.utils;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.apache.commons.lang3.StringUtils; import org.apache.olingo.commons.api.format.ContentType;
import org.apache.http.entity.ContentType;
import org.apache.olingo.fit.UnsupportedMediaTypeException; import org.apache.olingo.fit.UnsupportedMediaTypeException;
public enum Accept { public enum Accept {
TEXT(ContentType.TEXT_PLAIN.getMimeType(), ".txt"), TEXT(ContentType.TEXT_PLAIN, ".txt"),
XML(ContentType.APPLICATION_XML.getMimeType(), ".xml"), XML(ContentType.APPLICATION_XML, ".xml"),
ATOM(ContentType.APPLICATION_ATOM_XML.getMimeType(), ".xml"), ATOM(ContentType.APPLICATION_ATOM_XML, ".xml"),
JSON(ContentType.APPLICATION_JSON.getMimeType() + ";odata.metadata=minimal", ".full.json"), JSON(ContentType.JSON, ".full.json"),
JSON_NOMETA(ContentType.APPLICATION_JSON.getMimeType() + ";odata.metadata=none", ".full.json"), JSON_NOMETA(ContentType.JSON_NO_METADATA, ".full.json"),
JSON_FULLMETA(ContentType.APPLICATION_JSON.getMimeType() + ";odata.metadata=full", ".full.json"); JSON_FULLMETA(ContentType.JSON_FULL_METADATA, ".full.json");
private final String contentTypeV4;
private final String fileExtension;
private static Pattern allTypesPattern = Pattern.compile("(.*,)?\\*/\\*([,;].*)?"); private static Pattern allTypesPattern = Pattern.compile("(.*,)?\\*/\\*([,;].*)?");
Accept(final String contentTypeV4, final String fileExtension) { private final ContentType contentType;
this.contentTypeV4 = contentTypeV4; private final String fileExtension;
Accept(final ContentType contentType, final String fileExtension) {
this.contentType = contentType;
this.fileExtension = fileExtension; this.fileExtension = fileExtension;
} }
@Override @Override
public String toString() { public String toString() {
return contentTypeV4; return contentType.toContentTypeString();
} }
public String getExtension() { public String getExtension() {
@ -58,15 +56,14 @@ public enum Accept {
} }
public static Accept parse(final String contentType, final Accept def) { public static Accept parse(final String contentType, final Accept def) {
if (StringUtils.isBlank(contentType) || allTypesPattern.matcher(contentType).matches()) { if (contentType == null || contentType.isEmpty() || allTypesPattern.matcher(contentType).matches()) {
return def; return def;
} else if (contentType.startsWith(JSON_NOMETA.toString())) { } else if (contentType.startsWith(JSON_NOMETA.toString())) {
return JSON_NOMETA; return JSON_NOMETA;
} else if (contentType.startsWith(JSON_FULLMETA.toString())) { } else if (contentType.startsWith(JSON_FULLMETA.toString())) {
return JSON_FULLMETA; return JSON_FULLMETA;
} else if (contentType.startsWith(JSON.toString()) } else if (contentType.startsWith(JSON.toString())
|| contentType.startsWith(ContentType.APPLICATION_JSON.getMimeType())) { || contentType.startsWith(ContentType.APPLICATION_JSON.toContentTypeString())) {
return JSON; return JSON;
} else if (contentType.startsWith(XML.toString())) { } else if (contentType.startsWith(XML.toString())) {
return XML; return XML;

View File

@ -27,7 +27,6 @@ import java.net.URI;
import java.util.AbstractMap.SimpleEntry; import java.util.AbstractMap.SimpleEntry;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.EnumMap;
import java.util.HashMap; import java.util.HashMap;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
@ -40,7 +39,6 @@ import org.apache.commons.lang3.tuple.Pair;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.apache.olingo.fit.metadata.Metadata; import org.apache.olingo.fit.metadata.Metadata;
import org.codehaus.plexus.util.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -59,9 +57,6 @@ public abstract class Commons {
*/ */
protected static final Logger LOG = LoggerFactory.getLogger(Commons.class); protected static final Logger LOG = LoggerFactory.getLogger(Commons.class);
private static final EnumMap<ODataServiceVersion, Metadata> METADATA =
new EnumMap<ODataServiceVersion, Metadata>(ODataServiceVersion.class);
protected static final Pattern MULTIKEY_PATTERN = Pattern.compile("(.*=.*,?)+"); protected static final Pattern MULTIKEY_PATTERN = Pattern.compile("(.*=.*,?)+");
protected static final Map<String, Integer> SEQUENCE = new HashMap<String, Integer>(); protected static final Map<String, Integer> SEQUENCE = new HashMap<String, Integer>();
@ -99,14 +94,11 @@ public abstract class Commons {
new ImmutablePair<String, EdmPrimitiveTypeKind>("ID", EdmPrimitiveTypeKind.Guid)); new ImmutablePair<String, EdmPrimitiveTypeKind>("ID", EdmPrimitiveTypeKind.Guid));
} }
public static Metadata getMetadata(final ODataServiceVersion version) { private static final Metadata METADATA =
if (!METADATA.containsKey(version)) { new Metadata(Commons.class.getResourceAsStream("/" + ODataServiceVersion.V40.name() + "/metadata.xml"));
final InputStream is = Commons.class.getResourceAsStream("/" + version.name() + "/metadata.xml");
METADATA.put(version, new Metadata(is)); public static Metadata getMetadata() {
} return METADATA;
return METADATA.get(version);
} }
public static Map<String, Pair<String, EdmPrimitiveTypeKind>> getMediaContent() { public static Map<String, Pair<String, EdmPrimitiveTypeKind>> getMediaContent() {
@ -115,13 +107,13 @@ public abstract class Commons {
public static String getEntityURI(final String entitySetName, final String entityKey) { public static String getEntityURI(final String entitySetName, final String entityKey) {
// expected singleton in case of null key // expected singleton in case of null key
return entitySetName + (StringUtils.isNotBlank(entityKey) ? "(" + entityKey + ")" : ""); return entitySetName + (entityKey == null || entityKey.isEmpty() ? "" : "(" + entityKey + ")");
} }
public static String getEntityBasePath(final String entitySetName, final String entityKey) { public static String getEntityBasePath(final String entitySetName, final String entityKey) {
// expected singleton in case of null key // expected singleton in case of null key
return entitySetName + File.separatorChar return entitySetName + File.separatorChar
+ (StringUtils.isNotBlank(entityKey) ? getEntityKey(entityKey) + File.separatorChar : ""); + (entityKey == null || entityKey.isEmpty() ? "" : getEntityKey(entityKey) + File.separatorChar);
} }
public static String getLinksURI(final String entitySetName, final String entityId, final String linkName) public static String getLinksURI(final String entitySetName, final String entityId, final String linkName)
@ -138,7 +130,7 @@ public abstract class Commons {
public static String getLinksPath(final String basePath, final String linkName, final Accept accept) public static String getLinksPath(final String basePath, final String linkName, final Accept accept)
throws IOException { throws IOException {
try { try {
return FSManager.instance(ODataServiceVersion.V40) return FSManager.instance()
.getAbsolutePath(basePath + Constants.get(ConstantKey.LINKS_FILE_PATH) .getAbsolutePath(basePath + Constants.get(ConstantKey.LINKS_FILE_PATH)
+ File.separatorChar + linkName, accept); + File.separatorChar + linkName, accept);
} catch (Exception e) { } catch (Exception e) {
@ -281,7 +273,7 @@ public abstract class Commons {
public static String getETag(final String basePath) throws Exception { public static String getETag(final String basePath) throws Exception {
try { try {
final InputStream is = FSManager.instance(ODataServiceVersion.V40).readFile(basePath + "etag", Accept.TEXT); final InputStream is = FSManager.instance().readFile(basePath + "etag", Accept.TEXT);
if (is.available() <= 0) { if (is.available() <= 0) {
return null; return null;
} else { } else {

View File

@ -25,20 +25,13 @@ public enum ConstantKey {
ODATA_COUNT_NAME, ODATA_COUNT_NAME,
ODATA_METADATA_PREFIX, ODATA_METADATA_PREFIX,
ODATA_METADATA_ENTITY_SUFFIX, ODATA_METADATA_ENTITY_SUFFIX,
ATOM_DEF_TYPE,
ATOM_PROPERTY_PREFIX, ATOM_PROPERTY_PREFIX,
ATOM_METADATA_PREFIX,
ATOM_METADATA_NS,
ATOM_DATASERVICE_NS,
ATOM_LINK_ENTRY, ATOM_LINK_ENTRY,
ATOM_LINK_FEED, ATOM_LINK_FEED,
ATOM_LINK_REL, ATOM_LINK_REL,
TYPE,
INLINE_LOCAL, INLINE_LOCAL,
INLINE_FILE_PATH,
LINKS_FILE_PATH, LINKS_FILE_PATH,
INLINE, INLINE,
CONTENT,
PROPERTIES, PROPERTIES,
LINK, LINK,
DATASERVICES_NS, DATASERVICES_NS,
@ -66,6 +59,5 @@ public enum ConstantKey {
JSON_TYPE_SUFFIX, JSON_TYPE_SUFFIX,
JSON_ID_NAME, JSON_ID_NAME,
JSON_EDITLINK_NAME, JSON_EDITLINK_NAME,
XHTTP_HEADER_NAME; XHTTP_HEADER_NAME
}; };

View File

@ -55,19 +55,12 @@ public class Constants {
"http://localhost:9080/stub/StaticService/V40/Static.svc/$metadata#"); "http://localhost:9080/stub/StaticService/V40/Static.svc/$metadata#");
constants.put(ConstantKey.ODATA_METADATA_ENTITY_SUFFIX, "/$entity"); constants.put(ConstantKey.ODATA_METADATA_ENTITY_SUFFIX, "/$entity");
constants.put(ConstantKey.ODATA_COUNT_NAME, "odata.count"); constants.put(ConstantKey.ODATA_COUNT_NAME, "odata.count");
constants.put(ConstantKey.ATOM_DEF_TYPE, "Edm.String");
constants.put(ConstantKey.ATOM_PROPERTY_PREFIX, "d:"); constants.put(ConstantKey.ATOM_PROPERTY_PREFIX, "d:");
constants.put(ConstantKey.ATOM_METADATA_PREFIX, "m:");
constants.put(ConstantKey.ATOM_METADATA_NS, "xmlns:m");
constants.put(ConstantKey.ATOM_DATASERVICE_NS, "xmlns:d");
constants.put(ConstantKey.ATOM_LINK_ENTRY, "application/atom+xml;type=entry"); constants.put(ConstantKey.ATOM_LINK_ENTRY, "application/atom+xml;type=entry");
constants.put(ConstantKey.ATOM_LINK_FEED, "application/atom+xml;type=feed"); constants.put(ConstantKey.ATOM_LINK_FEED, "application/atom+xml;type=feed");
constants.put(ConstantKey.TYPE, "m:type");
constants.put(ConstantKey.INLINE_LOCAL, "inline"); constants.put(ConstantKey.INLINE_LOCAL, "inline");
constants.put(ConstantKey.INLINE_FILE_PATH, "inline");
constants.put(ConstantKey.LINKS_FILE_PATH, "links"); constants.put(ConstantKey.LINKS_FILE_PATH, "links");
constants.put(ConstantKey.INLINE, "m:inline"); constants.put(ConstantKey.INLINE, "m:inline");
constants.put(ConstantKey.CONTENT, "content");
constants.put(ConstantKey.PROPERTIES, "m:properties"); constants.put(ConstantKey.PROPERTIES, "m:properties");
constants.put(ConstantKey.LINK, "link"); constants.put(ConstantKey.LINK, "link");
constants.put(ConstantKey.METADATA, "metadata"); constants.put(ConstantKey.METADATA, "metadata");

View File

@ -25,8 +25,6 @@ import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.OutputStreamWriter; import java.io.OutputStreamWriter;
import java.util.EnumMap;
import java.util.Map;
import javax.ws.rs.NotFoundException; import javax.ws.rs.NotFoundException;
@ -61,37 +59,34 @@ public class FSManager {
private final FileSystemManager fsManager; private final FileSystemManager fsManager;
private static Map<ODataServiceVersion, FSManager> instance = private static FSManager instance = null;
new EnumMap<ODataServiceVersion, FSManager>(ODataServiceVersion.class);
private final ODataServiceVersion version; public static FSManager instance() throws IOException {
if (instance == null) {
public static FSManager instance(final ODataServiceVersion version) throws IOException { instance = new FSManager();
if (!instance.containsKey(version)) {
instance.put(version, new FSManager(version));
} }
return instance.get(version); return instance;
} }
private FSManager(final ODataServiceVersion version) throws IOException { private FSManager() throws IOException {
this.version = version;
fsManager = VFS.getManager(); fsManager = VFS.getManager();
final FileObject basePath = fsManager.resolveFile(RES_PREFIX + File.separatorChar + version.name()); final FileObject basePath =
fsManager.resolveFile(RES_PREFIX + File.separatorChar + ODataServiceVersion.V40.name());
final String absoluteBaseFolder = basePath.getURL().getPath(); final String absoluteBaseFolder = basePath.getURL().getPath();
for (FileObject fo : find(basePath, null)) { for (FileObject fo : find(basePath, null)) {
if (fo.getType() == FileType.FILE if (fo.getType() == FileType.FILE
&& !fo.getName().getBaseName().contains("Metadata") && !fo.getName().getBaseName().contains("Metadata")
&& !fo.getName().getBaseName().contains("metadata")) { && !fo.getName().getBaseName().contains("metadata")) {
final String path = fo.getURL().getPath().replace(absoluteBaseFolder, "//" + version.name()); final String path = fo.getURL().getPath().replace(absoluteBaseFolder, "//" + ODataServiceVersion.V40.name());
putInMemory(fo.getContent().getInputStream(), path); putInMemory(fo.getContent().getInputStream(), path);
} }
} }
} }
public String getAbsolutePath(final String relativePath, final Accept accept) { public String getAbsolutePath(final String relativePath, final Accept accept) {
return File.separatorChar + version.name() + File.separatorChar + relativePath return File.separatorChar + ODataServiceVersion.V40.name() + File.separatorChar + relativePath
+ (accept == null ? "" : accept.getExtension()); + (accept == null ? "" : accept.getExtension());
} }

View File

@ -1,42 +0,0 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.olingo.fit.utils;
import com.fasterxml.jackson.databind.SerializationConfig;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.ser.DefaultSerializerProvider;
import com.fasterxml.jackson.databind.ser.SerializerFactory;
public class InjectableSerializerProvider extends DefaultSerializerProvider {
private static final long serialVersionUID = 3432260063063739646L;
public InjectableSerializerProvider(
final SerializerProvider src, final SerializationConfig config, final SerializerFactory factory) {
super(src, config, factory);
}
@Override
public InjectableSerializerProvider createInstance(
final SerializationConfig config, final SerializerFactory factory) {
return this;
}
}

View File

@ -39,7 +39,6 @@ import org.apache.olingo.fit.metadata.Metadata;
import org.apache.olingo.fit.metadata.NavigationProperty; import org.apache.olingo.fit.metadata.NavigationProperty;
import com.fasterxml.jackson.annotation.JsonInclude; import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.databind.InjectableValues;
import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ArrayNode; import com.fasterxml.jackson.databind.node.ArrayNode;
@ -48,21 +47,10 @@ import com.fasterxml.jackson.databind.node.TextNode;
public class JSONUtilities extends AbstractUtilities { public class JSONUtilities extends AbstractUtilities {
private final ObjectMapper mapper; private final ObjectMapper mapper = new ObjectMapper().setSerializationInclusion(JsonInclude.Include.NON_NULL);
public JSONUtilities(final Metadata metadata) throws IOException { public JSONUtilities(final Metadata metadata) throws IOException {
super(metadata); super(metadata);
mapper = new ObjectMapper().setSerializationInclusion(JsonInclude.Include.NON_NULL);
mapper.setInjectableValues(new InjectableValues.Std().
addValue(Boolean.class, Boolean.TRUE));
// addValue(ODataServiceVersion.class, version))
mapper.setSerializerProvider(new InjectableSerializerProvider(mapper.getSerializerProvider(),
mapper.getSerializationConfig().
// withAttribute(ODataServiceVersion.class, version).
withAttribute(Boolean.class, Boolean.TRUE),
mapper.getSerializerFactory()));
} }
@Override @Override

View File

@ -1,182 +0,0 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.olingo.fit.utils;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import javax.ws.rs.NotFoundException;
public class MetadataLinkInfo {
private Map<String, EntitySet> entitySets = new HashMap<String, EntitySet>();
public void setSingleton(final String entitySetName) {
entitySets.get(entitySetName).setSingleton(true);
}
public boolean isSingleton(final String entitySetName) {
return entitySets.get(entitySetName).isSingleton();
}
public Set<String> getEntitySets() {
return entitySets.keySet();
}
public void addEntitySet(final String entitySetName) {
if (!entitySets.containsKey(entitySetName)) {
entitySets.put(entitySetName, new EntitySet(entitySetName));
}
}
public void addLink(
final String entitySetName, final String linkName, final String targetName, final boolean isFeed) {
final EntitySet entitySet;
if (entitySets.containsKey(entitySetName)) {
entitySet = entitySets.get(entitySetName);
} else {
entitySet = new EntitySet(entitySetName);
entitySets.put(entitySetName, entitySet);
}
entitySet.add(linkName, targetName, isFeed);
}
public Set<String> getNavigationLinkNames(final String entitySetName) {
final Set<String> res = new HashSet<String>();
if (!entitySets.containsKey(entitySetName)) {
throw new NotFoundException();
}
for (NavigationLink navigationLink : entitySets.get(entitySetName).getLinks()) {
res.add(navigationLink.getName());
}
return res;
}
public boolean exists(final String entitySetName, final String linkName) {
try {
return getNavigationLinkNames(entitySetName).contains(linkName);
} catch (Exception e) {
return false;
}
}
public boolean isFeed(final String entitySetName, final String linkName) {
return entitySets.containsKey(entitySetName) && entitySets.get(entitySetName).isFeed(linkName);
}
public String getTargetName(final String entitySetName, final String linkName) {
if (!entitySets.containsKey(entitySetName)) {
throw new NotFoundException();
}
final String targetName = entitySets.get(entitySetName).getLink(linkName).getTargetName();
return targetName.substring(targetName.lastIndexOf(".") + 1);
}
private static class EntitySet {
private String name;
private Set<NavigationLink> links;
private boolean singleton;
public EntitySet(final String name) {
this.name = name;
links = new HashSet<NavigationLink>();
}
public void add(final String linkName, final String targetName, final boolean isFeed) {
links.add(new NavigationLink(linkName, targetName, isFeed));
}
public Set<NavigationLink> getLinks() {
return links;
}
public NavigationLink getLink(final String linkName) {
for (NavigationLink navigationLink : links) {
if (linkName.equalsIgnoreCase(navigationLink.getName())) {
return navigationLink;
}
}
throw new NotFoundException();
}
public boolean isFeed(final String linkName) {
try {
return getLink(linkName).isFeed();
} catch (Exception e) {
return false;
}
}
public boolean isSingleton() {
return singleton;
}
public void setSingleton(final boolean singleton) {
this.singleton = singleton;
}
@Override
public String toString() {
return name + ": " + links;
}
}
private static class NavigationLink {
private final String name;
private final String targetName;
private final boolean feed;
public NavigationLink(final String name, final String targetName, final boolean feed) {
this.name = name;
this.targetName = targetName;
this.feed = feed;
}
public String getName() {
return name;
}
public String getTargetName() {
return targetName;
}
public boolean isFeed() {
return feed;
}
@Override
public String toString() {
return name + "(feed: " + isFeed() + ")";
}
}
}

View File

@ -38,6 +38,7 @@ import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.regex.Pattern;
import javax.ws.rs.NotFoundException; import javax.ws.rs.NotFoundException;
import javax.xml.namespace.QName; import javax.xml.namespace.QName;
@ -61,6 +62,8 @@ import org.apache.olingo.fit.metadata.NavigationProperty;
public class XMLUtilities extends AbstractUtilities { public class XMLUtilities extends AbstractUtilities {
private static final Pattern ENTITY_URI_PATTERN = Pattern.compile(".*\\/.*\\(.*\\)");
protected static XMLInputFactory ifactory = null; protected static XMLInputFactory ifactory = null;
protected static XMLOutputFactory ofactory = null; protected static XMLOutputFactory ofactory = null;

View File

@ -18,9 +18,7 @@
*/ */
package org.apache.olingo.fit.proxy.demo.odatademo.types; package org.apache.olingo.fit.proxy.demo.odatademo.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@ -30,9 +28,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "ODataDemo.Person") baseType = "ODataDemo.Person")
public interface Customer public interface Customer extends Person {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Person {
@Override @Override
Customer load(); Customer load();

View File

@ -18,9 +18,7 @@
*/ */
package org.apache.olingo.fit.proxy.demo.odatademo.types; package org.apache.olingo.fit.proxy.demo.odatademo.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@ -30,9 +28,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "ODataDemo.Person") baseType = "ODataDemo.Person")
public interface Employee public interface Employee extends Person {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Person {
@Override @Override
Employee load(); Employee load();

View File

@ -18,9 +18,7 @@
*/ */
package org.apache.olingo.fit.proxy.demo.odatademo.types; package org.apache.olingo.fit.proxy.demo.odatademo.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@ -30,9 +28,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "ODataDemo.Product") baseType = "ODataDemo.Product")
public interface FeaturedProduct public interface FeaturedProduct extends Product {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Product {
@Override @Override
FeaturedProduct load(); FeaturedProduct load();

View File

@ -18,11 +18,8 @@
*/ */
package org.apache.olingo.fit.proxy.opentype.microsoft.test.odata.services.opentypesservice.types; package org.apache.olingo.fit.proxy.opentype.microsoft.test.odata.services.opentypesservice.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.AbstractOpenType;
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@org.apache.olingo.ext.proxy.api.annotations.Namespace("Microsoft.Test.OData.Services.OpenTypesServiceV4") @org.apache.olingo.ext.proxy.api.annotations.Namespace("Microsoft.Test.OData.Services.OpenTypesServiceV4")
@ -31,10 +28,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "Microsoft.Test.OData.Services.OpenTypesServiceV4.Row") baseType = "Microsoft.Test.OData.Services.OpenTypesServiceV4.Row")
public interface IndexedRow public interface IndexedRow extends Row {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Row,
AbstractOpenType {
@Override @Override
IndexedRow load(); IndexedRow load();

View File

@ -18,9 +18,7 @@
*/ */
package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types; package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.AbstractEntitySet; import org.apache.olingo.ext.proxy.api.AbstractEntitySet;
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@ -31,9 +29,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "Microsoft.Test.OData.Services.ODataWCFService.PaymentInstrument") baseType = "Microsoft.Test.OData.Services.ODataWCFService.PaymentInstrument")
public interface CreditCardPI public interface CreditCardPI extends PaymentInstrument {
extends org.apache.olingo.ext.proxy.api.Annotatable,
PaymentInstrument {
@Override @Override
CreditCardPI load(); CreditCardPI load();

View File

@ -18,9 +18,7 @@
*/ */
package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types; package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@ -30,9 +28,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "Microsoft.Test.OData.Services.ODataWCFService.Person") baseType = "Microsoft.Test.OData.Services.ODataWCFService.Person")
public interface Customer public interface Customer extends Person {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Person {
@Override @Override
Customer load(); Customer load();

View File

@ -18,9 +18,7 @@
*/ */
package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types; package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@ -30,9 +28,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "Microsoft.Test.OData.Services.ODataWCFService.Person") baseType = "Microsoft.Test.OData.Services.ODataWCFService.Person")
public interface Employee public interface Employee extends Person {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Person {
@Override @Override
Employee load(); Employee load();

View File

@ -18,12 +18,9 @@
*/ */
package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types; package org.apache.olingo.fit.proxy.staticservice.microsoft.test.odata.services.odatawcfservice.types;
// CHECKSTYLE:OFF (Maven checkstyle)
import java.util.concurrent.Future; import java.util.concurrent.Future;
// CHECKSTYLE:ON (Maven checkstyle)
import org.apache.olingo.ext.proxy.api.AbstractEntitySet; import org.apache.olingo.ext.proxy.api.AbstractEntitySet;
import org.apache.olingo.ext.proxy.api.AbstractOpenType;
import org.apache.olingo.ext.proxy.api.annotations.Key; import org.apache.olingo.ext.proxy.api.annotations.Key;
@org.apache.olingo.ext.proxy.api.annotations.Namespace("Microsoft.Test.OData.Services.ODataWCFService") @org.apache.olingo.ext.proxy.api.annotations.Namespace("Microsoft.Test.OData.Services.ODataWCFService")
@ -32,10 +29,7 @@ import org.apache.olingo.ext.proxy.api.annotations.Key;
hasStream = false, hasStream = false,
isAbstract = false, isAbstract = false,
baseType = "Microsoft.Test.OData.Services.ODataWCFService.Company") baseType = "Microsoft.Test.OData.Services.ODataWCFService.Company")
public interface PublicCompany public interface PublicCompany extends Company {
extends org.apache.olingo.ext.proxy.api.Annotatable,
Company,
AbstractOpenType {
@Override @Override
PublicCompany load(); PublicCompany load();

View File

@ -24,6 +24,7 @@ import static org.junit.Assert.assertNull;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
import java.net.URI; import java.net.URI;
import java.util.EnumMap;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -553,11 +554,11 @@ public class EntityReferencesITCase extends AbstractParamTecSvcITCase {
.getReferenceSingleChangeRequest(new URI(SERVICE_URI), uri, reference) .getReferenceSingleChangeRequest(new URI(SERVICE_URI), uri, reference)
.execute(); .execute();
assertEquals(HttpStatusCode.NO_CONTENT.getStatusCode(), response.getStatusCode()); assertEquals(HttpStatusCode.NO_CONTENT.getStatusCode(), response.getStatusCode());
final String cookie = response.getHeader(HttpHeader.SET_COOKIE).iterator().next(); final String cookie = response.getHeader(HttpHeader.SET_COOKIE).iterator().next();
Map<QueryOption, Object> expandOptions = new HashMap<QueryOption, Object>(); Map<QueryOption, Object> expandOptions = new EnumMap<QueryOption, Object>(QueryOption.class);
expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_KEY_NAV_ONE); expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_KEY_NAV_ONE);
final URI getURI = getClient().newURIBuilder(SERVICE_URI) final URI getURI = getClient().newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_TWO_KEY_NAV) .appendEntitySetSegment(ES_TWO_KEY_NAV)
.appendKeySegment(esTwoKeyNavKey) .appendKeySegment(esTwoKeyNavKey)
@ -601,12 +602,12 @@ public class EntityReferencesITCase extends AbstractParamTecSvcITCase {
.getReferenceAddingRequest(new URI(SERVICE_URI), uri, reference) .getReferenceAddingRequest(new URI(SERVICE_URI), uri, reference)
.execute(); .execute();
assertEquals(HttpStatusCode.NO_CONTENT.getStatusCode(), response.getStatusCode()); assertEquals(HttpStatusCode.NO_CONTENT.getStatusCode(), response.getStatusCode());
final String cookie = response.getHeader(HttpHeader.SET_COOKIE).iterator().next(); final String cookie = response.getHeader(HttpHeader.SET_COOKIE).iterator().next();
final Map<QueryOption, Object> expandOptions = new HashMap<QueryOption, Object>(); final Map<QueryOption, Object> expandOptions = new EnumMap<QueryOption, Object>(QueryOption.class);
expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_KEY_NAV_MANY); expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_KEY_NAV_MANY);
expandOptions.put(QueryOption.FILTER, "PropertyInt16 eq 1"); expandOptions.put(QueryOption.FILTER, "PropertyInt16 eq 1");
final URI getURI = getClient().newURIBuilder(SERVICE_URI) final URI getURI = getClient().newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_TWO_KEY_NAV) .appendEntitySetSegment(ES_TWO_KEY_NAV)
.appendKeySegment(esTwoKeyNavKey) .appendKeySegment(esTwoKeyNavKey)

View File

@ -23,6 +23,8 @@ import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
import java.net.URI; import java.net.URI;
import java.util.Collections;
import java.util.EnumMap;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -49,11 +51,10 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void filter() { public void filter() {
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>();
options.put(QueryOption.FILTER, "PropertyString eq '2'");
final ODataRetrieveResponse<ClientEntitySet> response = final ODataRetrieveResponse<ClientEntitySet> response =
buildRequest(ES_TWO_KEY_NAV, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY, options); buildRequest(ES_TWO_KEY_NAV, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY,
Collections.singletonMap(QueryOption.FILTER, (Object) "PropertyString eq '2'"));
final List<ClientEntity> entities = response.getBody().getEntities(); final List<ClientEntity> entities = response.getBody().getEntities();
assertEquals(4, entities.size()); assertEquals(4, entities.size());
@ -87,11 +88,9 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void orderBy() { public void orderBy() {
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>();
options.put(QueryOption.ORDERBY, "PropertyString desc");
final ODataRetrieveResponse<ClientEntitySet> response = final ODataRetrieveResponse<ClientEntitySet> response =
buildRequest(ES_TWO_KEY_NAV, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY, options); buildRequest(ES_TWO_KEY_NAV, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY,
Collections.<QueryOption, Object> singletonMap(QueryOption.ORDERBY, "PropertyString desc"));
final List<ClientEntity> entities = response.getBody().getEntities(); final List<ClientEntity> entities = response.getBody().getEntities();
assertEquals(4, entities.size()); assertEquals(4, entities.size());
@ -117,11 +116,9 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void skip() { public void skip() {
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>();
options.put(QueryOption.SKIP, "1");
final ODataRetrieveResponse<ClientEntitySet> response = final ODataRetrieveResponse<ClientEntitySet> response =
buildRequest(ES_KEY_NAV, NAV_PROPERTY_ET_KEY_NAV_MANY, options); buildRequest(ES_KEY_NAV, NAV_PROPERTY_ET_KEY_NAV_MANY,
Collections.singletonMap(QueryOption.SKIP, (Object) "1"));
final List<ClientEntity> entities = response.getBody().getEntities(); final List<ClientEntity> entities = response.getBody().getEntities();
assertEquals(3, entities.size()); assertEquals(3, entities.size());
@ -148,11 +145,9 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void top() { public void top() {
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>();
options.put(QueryOption.TOP, "1");
final ODataRetrieveResponse<ClientEntitySet> response = final ODataRetrieveResponse<ClientEntitySet> response =
buildRequest(ES_KEY_NAV, NAV_PROPERTY_ET_KEY_NAV_MANY, options); buildRequest(ES_KEY_NAV, NAV_PROPERTY_ET_KEY_NAV_MANY,
Collections.<QueryOption, Object> singletonMap(QueryOption.TOP, "1"));
final List<ClientEntity> entities = response.getBody().getEntities(); final List<ClientEntity> entities = response.getBody().getEntities();
assertEquals(3, entities.size()); assertEquals(3, entities.size());
@ -179,7 +174,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void combinedSystemQueryOptions() { public void combinedSystemQueryOptions() {
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>(); Map<QueryOption, Object> options = new EnumMap<QueryOption, Object>(QueryOption.class);
options.put(QueryOption.SELECT, "PropertyInt16,PropertyString"); options.put(QueryOption.SELECT, "PropertyInt16,PropertyString");
options.put(QueryOption.FILTER, "PropertyInt16 eq 1"); options.put(QueryOption.FILTER, "PropertyInt16 eq 1");
options.put(QueryOption.SKIP, "1"); options.put(QueryOption.SKIP, "1");
@ -217,7 +212,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Ignore("Server do not support navigation property count annotations") @Ignore("Server do not support navigation property count annotations")
public void count() { public void count() {
final ODataClient client = getEdmEnabledClient(); final ODataClient client = getEdmEnabledClient();
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>(); Map<QueryOption, Object> options = new EnumMap<QueryOption, Object>(QueryOption.class);
options.put(QueryOption.SELECT, "PropertyInt16"); options.put(QueryOption.SELECT, "PropertyInt16");
options.put(QueryOption.COUNT, true); options.put(QueryOption.COUNT, true);
@ -255,14 +250,14 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
public void singleEntityWithExpand() { public void singleEntityWithExpand() {
/* A single entity request will be dispatched to a different processor method than entity set request */ /* A single entity request will be dispatched to a different processor method than entity set request */
final ODataClient client = getEdmEnabledClient(); final ODataClient client = getEdmEnabledClient();
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>();
options.put(QueryOption.FILTER, "PropertyInt16 lt 2");
Map<String, Object> keys = new HashMap<String, Object>(); Map<String, Object> keys = new HashMap<String, Object>();
keys.put("PropertyInt16", 1); keys.put("PropertyInt16", 1);
keys.put("PropertyString", "1"); keys.put("PropertyString", "1");
final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_TWO_KEY_NAV).appendKeySegment(keys) final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_TWO_KEY_NAV).appendKeySegment(keys)
.expandWithOptions(NAV_PROPERTY_ET_KEY_NAV_MANY, options).build(); .expandWithOptions(NAV_PROPERTY_ET_KEY_NAV_MANY,
Collections.singletonMap(QueryOption.FILTER, (Object) "PropertyInt16 lt 2"))
.build();
final ODataRetrieveResponse<ClientEntity> response = final ODataRetrieveResponse<ClientEntity> response =
client.getRetrieveRequestFactory().getEntityRequest(uri).execute(); client.getRetrieveRequestFactory().getEntityRequest(uri).execute();
assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode());
@ -275,11 +270,12 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void URIEscaping() { public void URIEscaping() {
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>();
options.put(QueryOption.FILTER, "PropertyInt16 eq 1"
+ " and PropertyComp/PropertyComp/PropertyDuration eq duration'PT1S' and length(PropertyString) gt 4");
final ODataRetrieveResponse<ClientEntitySet> response = final ODataRetrieveResponse<ClientEntitySet> response =
buildRequest(ES_TWO_KEY_NAV, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY, options); buildRequest(ES_TWO_KEY_NAV, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY,
Collections.<QueryOption, Object> singletonMap(QueryOption.FILTER,
"PropertyInt16 eq 1"
+ " and PropertyComp/PropertyComp/PropertyDuration eq duration'PT1S'"
+ " and length(PropertyString) gt 4"));
final List<ClientEntity> entities = response.getBody().getEntities(); final List<ClientEntity> entities = response.getBody().getEntities();
assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode());
@ -296,7 +292,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
// Define filters to select explicit the entities at any level => Circle // Define filters to select explicit the entities at any level => Circle
final ODataClient client = getEdmEnabledClient(); final ODataClient client = getEdmEnabledClient();
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>(); Map<QueryOption, Object> options = new EnumMap<QueryOption, Object>(QueryOption.class);
options.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY options.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY
+ "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY
+ "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "))"); + "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "))");
@ -371,7 +367,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void systemQueryOptionOnThirdLevel() { public void systemQueryOptionOnThirdLevel() {
final ODataClient client = getEdmEnabledClient(); final ODataClient client = getEdmEnabledClient();
Map<QueryOption, Object> options = new HashMap<QueryOption, Object>(); Map<QueryOption, Object> options = new EnumMap<QueryOption, Object>(QueryOption.class);
options.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY options.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY
+ "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY
+ "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($expand=" + NAV_PROPERTY_ET_TWO_KEY_NAV_MANY
@ -444,7 +440,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void expandWithSearchQuery() { public void expandWithSearchQuery() {
final ODataClient client = getEdmEnabledClient(); final ODataClient client = getEdmEnabledClient();
Map<QueryOption, Object> expandOptions = new HashMap<QueryOption, Object>(); Map<QueryOption, Object> expandOptions = new EnumMap<QueryOption, Object>(QueryOption.class);
expandOptions.put(QueryOption.SEARCH, "abc"); expandOptions.put(QueryOption.SEARCH, "abc");
expandOptions.put(QueryOption.FILTER, "PropertyInt16 eq 1"); expandOptions.put(QueryOption.FILTER, "PropertyInt16 eq 1");
@ -464,12 +460,10 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
@Test @Test
public void expandWithLevels() { public void expandWithLevels() {
final ODataClient client = getEdmEnabledClient(); final ODataClient client = getEdmEnabledClient();
Map<QueryOption, Object> expandOptions = new HashMap<QueryOption, Object>();
expandOptions.put(QueryOption.LEVELS, 2);
// expand=*($levels=2) // expand=*($levels=2)
URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV)
.expandWithOptions("*", expandOptions) .expandWithOptions("*", Collections.<QueryOption, Object> singletonMap(QueryOption.LEVELS, 2))
.build(); .build();
try { try {
@ -479,10 +473,9 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
} }
// expand=NavPropertyETTwoKeyNavMany($levels=2) // expand=NavPropertyETTwoKeyNavMany($levels=2)
expandOptions.clear();
expandOptions.put(QueryOption.LEVELS, 2);
uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV)
.expandWithOptions(NAV_PROPERTY_ET_TWO_KEY_NAV_MANY, expandOptions) .expandWithOptions(NAV_PROPERTY_ET_TWO_KEY_NAV_MANY,
Collections.<QueryOption, Object> singletonMap(QueryOption.LEVELS, 2))
.build(); .build();
try { try {
@ -492,10 +485,10 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
} }
// expand=NavPropertyETTwoKeyNavMany($expand=NavPropertyETTwoKeyNavMany($levels=2)) // expand=NavPropertyETTwoKeyNavMany($expand=NavPropertyETTwoKeyNavMany($levels=2))
expandOptions.clear();
expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($levels=2)");
uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV)
.expandWithOptions(NAV_PROPERTY_ET_TWO_KEY_NAV_MANY, expandOptions) .expandWithOptions(NAV_PROPERTY_ET_TWO_KEY_NAV_MANY,
Collections.<QueryOption, Object> singletonMap(QueryOption.EXPAND,
NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($levels=2)"))
.build(); .build();
try { try {
@ -505,10 +498,9 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
} }
// expand=NavPropertyETTwoKeyNavMany($expand=NavPropertyETTwoKeyNavMany($levels=2);$levels=3) // expand=NavPropertyETTwoKeyNavMany($expand=NavPropertyETTwoKeyNavMany($levels=2);$levels=3)
expandOptions.clear();
expandOptions.put(QueryOption.LEVELS, 2);
uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV)
.expandWithOptions(NAV_PROPERTY_ET_TWO_KEY_NAV_MANY, expandOptions) .expandWithOptions(NAV_PROPERTY_ET_TWO_KEY_NAV_MANY,
Collections.<QueryOption, Object> singletonMap(QueryOption.LEVELS, 2))
.build(); .build();
try { try {
@ -518,7 +510,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractParamTecSvcITCas
} }
// expand=NavPropertyETTwoKeyNavMany($expand=NavPropertyETTwoKeyNavMany($levels=2)) // expand=NavPropertyETTwoKeyNavMany($expand=NavPropertyETTwoKeyNavMany($levels=2))
expandOptions.clear(); Map<QueryOption, Object> expandOptions = new EnumMap<QueryOption, Object>(QueryOption.class);
expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($levels=2)"); expandOptions.put(QueryOption.EXPAND, NAV_PROPERTY_ET_TWO_KEY_NAV_MANY + "($levels=2)");
expandOptions.put(QueryOption.LEVELS, 3); expandOptions.put(QueryOption.LEVELS, 3);
uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV)

View File

@ -1,114 +0,0 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.olingo.client.core.domain;
import java.net.URI;
import org.apache.olingo.client.api.domain.AbstractClientPayload;
import org.apache.olingo.client.api.domain.ClientEntitySet;
public abstract class AbstractClientEntitySet extends AbstractClientPayload implements ClientEntitySet {
/**
* Link to the next page.
*/
private URI next;
/**
* Number of ODataEntities contained in this entity set.
* <br/>
* If <tt>$count</tt> was requested, this value comes from there.
*/
private Integer count;
/**
* Constructor.
*/
public AbstractClientEntitySet() {
super(null);
}
/**
* Constructor.
*
* @param next next link.
*/
public AbstractClientEntitySet(final URI next) {
super(null);
this.next = next;
}
@Override
public URI getNext() {
return next;
}
@Override
public Integer getCount() {
return count;
}
@Override
public void setCount(final int count) {
this.count = count;
}
@Override
public int hashCode() {
final int prime = 31;
int result = super.hashCode();
result = prime * result + ((count == null) ? 0 : count.hashCode());
result = prime * result + ((next == null) ? 0 : next.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (!super.equals(obj)) {
return false;
}
if (!(obj instanceof AbstractClientEntitySet)) {
return false;
}
AbstractClientEntitySet other = (AbstractClientEntitySet) obj;
if (count == null) {
if (other.count != null) {
return false;
}
} else if (!count.equals(other.count)) {
return false;
}
if (next == null) {
if (other.next != null) {
return false;
}
} else if (!next.equals(other.next)) {
return false;
}
return true;
}
@Override
public String toString() {
return "AbstractClientEntitySet [next=" + next + ", count=" + count + "super[" + super.toString() + "]]";
}
}

View File

@ -29,7 +29,7 @@ import org.apache.olingo.client.api.domain.ClientEnumValue;
import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.api.domain.ClientValue;
public class ClientCollectionValueImpl<OV extends ClientValue> extends AbstractClientValue public class ClientCollectionValueImpl<OV extends ClientValue> extends AbstractClientValue
implements ClientCollectionValue<OV>, ClientValue { implements ClientCollectionValue<OV> {
/** /**
* Constructor. * Constructor.

View File

@ -22,11 +22,24 @@ import java.net.URI;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import org.apache.olingo.client.api.domain.AbstractClientPayload;
import org.apache.olingo.client.api.domain.ClientAnnotation; import org.apache.olingo.client.api.domain.ClientAnnotation;
import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntity;
import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientEntitySet;
public class ClientEntitySetImpl extends AbstractClientEntitySet implements ClientEntitySet { public class ClientEntitySetImpl extends AbstractClientPayload implements ClientEntitySet {
/**
* Link to the next page.
*/
private final URI next;
/**
* Number of ODataEntities contained in this entity set.
* <br/>
* If <tt>$count</tt> was requested, this value comes from there.
*/
private Integer count;
private URI deltaLink; private URI deltaLink;
@ -35,11 +48,28 @@ public class ClientEntitySetImpl extends AbstractClientEntitySet implements Clie
private final List<ClientAnnotation> annotations = new ArrayList<ClientAnnotation>(); private final List<ClientAnnotation> annotations = new ArrayList<ClientAnnotation>();
public ClientEntitySetImpl() { public ClientEntitySetImpl() {
super(); super(null);
next = null;
} }
public ClientEntitySetImpl(final URI next) { public ClientEntitySetImpl(final URI next) {
super(next); super(null);
this.next = next;
}
@Override
public URI getNext() {
return next;
}
@Override
public Integer getCount() {
return count;
}
@Override
public void setCount(final int count) {
this.count = count;
} }
@Override @Override
@ -66,6 +96,8 @@ public class ClientEntitySetImpl extends AbstractClientEntitySet implements Clie
public int hashCode() { public int hashCode() {
final int prime = 31; final int prime = 31;
int result = super.hashCode(); int result = super.hashCode();
result = prime * result + ((count == null) ? 0 : count.hashCode());
result = prime * result + ((next == null) ? 0 : next.hashCode());
result = prime * result + ((annotations == null) ? 0 : annotations.hashCode()); result = prime * result + ((annotations == null) ? 0 : annotations.hashCode());
result = prime * result + ((deltaLink == null) ? 0 : deltaLink.hashCode()); result = prime * result + ((deltaLink == null) ? 0 : deltaLink.hashCode());
result = prime * result + ((entities == null) ? 0 : entities.hashCode()); result = prime * result + ((entities == null) ? 0 : entities.hashCode());
@ -77,40 +109,20 @@ public class ClientEntitySetImpl extends AbstractClientEntitySet implements Clie
if (this == obj) { if (this == obj) {
return true; return true;
} }
if (!super.equals(obj)) { if (obj == null || !(obj instanceof ClientEntitySetImpl)) {
return false; return false;
} }
if (!(obj instanceof ClientEntitySetImpl)) { final ClientEntitySetImpl other = (ClientEntitySetImpl) obj;
return false; return (count == null ? other.count == null : count.equals(other.count))
} && (next == null ? other.next == null : next.equals(other.next))
ClientEntitySetImpl other = (ClientEntitySetImpl) obj; && annotations.equals(other.annotations)
if (annotations == null) { && (deltaLink == null ? other.deltaLink == null : deltaLink.equals(other.deltaLink))
if (other.annotations != null) { && entities.equals(other.entities);
return false;
}
} else if (!annotations.equals(other.annotations)) {
return false;
}
if (deltaLink == null) {
if (other.deltaLink != null) {
return false;
}
} else if (!deltaLink.equals(other.deltaLink)) {
return false;
}
if (entities == null) {
if (other.entities != null) {
return false;
}
} else if (!entities.equals(other.entities)) {
return false;
}
return true;
} }
@Override @Override
public String toString() { public String toString() {
return "ClientEntitySetImpl [deltaLink=" + deltaLink + ", entities=" + entities + ", annotations=" + annotations return "ClientEntitySetImpl [deltaLink=" + deltaLink + ", entities=" + entities + ", annotations=" + annotations
+ "super[" + super.toString() + "]]"; + ", next=" + next + ", count=" + count + "super[" + super.toString() + "]]";
} }
} }

View File

@ -21,11 +21,10 @@ package org.apache.olingo.client.core.domain;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.UUID; import java.util.UUID;
import org.apache.olingo.commons.api.Constants;
import org.apache.olingo.client.api.domain.AbstractClientValue; import org.apache.olingo.client.api.domain.AbstractClientValue;
import org.apache.olingo.client.api.domain.ClientEnumValue; import org.apache.olingo.client.api.domain.ClientEnumValue;
import org.apache.olingo.client.api.domain.ClientPrimitiveValue; import org.apache.olingo.client.api.domain.ClientPrimitiveValue;
import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.commons.api.Constants;
import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.edm.EdmPrimitiveType;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
@ -33,7 +32,7 @@ import org.apache.olingo.commons.api.edm.EdmType;
import org.apache.olingo.commons.api.edm.constants.EdmTypeKind; import org.apache.olingo.commons.api.edm.constants.EdmTypeKind;
import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory;
public class ClientPrimitiveValueImpl extends AbstractClientValue implements ClientValue, ClientPrimitiveValue { public class ClientPrimitiveValueImpl extends AbstractClientValue implements ClientPrimitiveValue {
public static class BuilderImpl implements Builder { public static class BuilderImpl implements Builder {

View File

@ -18,30 +18,21 @@
*/ */
package org.apache.olingo.client.core.domain; package org.apache.olingo.client.core.domain;
import org.apache.olingo.client.api.domain.ClientAnnotatable;
import org.apache.olingo.client.api.domain.ClientAnnotation;
import org.apache.olingo.client.api.domain.ClientCollectionValue;
import org.apache.olingo.client.api.domain.ClientComplexValue;
import org.apache.olingo.client.api.domain.ClientEnumValue;
import org.apache.olingo.client.api.domain.ClientPrimitiveValue;
import org.apache.olingo.client.api.domain.ClientProperty;
import org.apache.olingo.client.api.domain.ClientValuable;
import org.apache.olingo.client.api.domain.ClientValue;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
public final class ClientPropertyImpl implements ClientProperty, ClientAnnotatable, ClientValuable { import org.apache.olingo.client.api.domain.ClientAnnotation;
import org.apache.olingo.client.api.domain.ClientProperty;
import org.apache.olingo.client.api.domain.ClientValue;
public final class ClientPropertyImpl extends ClientValuableImpl implements ClientProperty {
private final List<ClientAnnotation> annotations = new ArrayList<ClientAnnotation>(); private final List<ClientAnnotation> annotations = new ArrayList<ClientAnnotation>();
private final String name; private final String name;
private final ClientValue value;
private final ClientValuable valuable;
public ClientPropertyImpl(final String name, final ClientValue value) { public ClientPropertyImpl(final String name, final ClientValue value) {
super(value);
this.name = name; this.name = name;
this.value = value;
this.valuable = new ClientValuableImpl(value);
} }
/** /**
@ -54,16 +45,6 @@ public final class ClientPropertyImpl implements ClientProperty, ClientAnnotatab
return name; return name;
} }
/**
* Returns property value.
*
* @return property value.
*/
@Override
public ClientValue getValue() {
return value;
}
/** /**
* Checks if has null value. * Checks if has null value.
* *
@ -74,87 +55,18 @@ public final class ClientPropertyImpl implements ClientProperty, ClientAnnotatab
return value == null || value.isPrimitive() && value.asPrimitive().toValue() == null; return value == null || value.isPrimitive() && value.asPrimitive().toValue() == null;
} }
/**
* Checks if has primitive value.
*
* @return 'TRUE' if has primitive value; 'FALSE' otherwise.
*/
@Override
public boolean hasPrimitiveValue() {
return !hasNullValue() && value.isPrimitive();
}
/**
* Gets primitive value.
*
* @return primitive value if exists; null otherwise.
*/
@Override
public ClientPrimitiveValue getPrimitiveValue() {
return hasPrimitiveValue() ? value.asPrimitive() : null;
}
/**
* Checks if has complex value.
*
* @return 'TRUE' if has complex value; 'FALSE' otherwise.
*/
@Override
public boolean hasComplexValue() {
return !hasNullValue() && value.isComplex();
}
/**
* Checks if has collection value.
*
* @return 'TRUE' if has collection value; 'FALSE' otherwise.
*/
@Override
public boolean hasCollectionValue() {
return !hasNullValue() && value.isCollection();
}
@Override @Override
public boolean equals(Object obj) { public boolean equals(Object obj) {
if (this == obj) { if (this == obj) {
return true; return true;
} }
if (obj == null) { if (obj == null || !(obj instanceof ClientPropertyImpl)) {
return false; return false;
} }
if (!(obj instanceof ClientPropertyImpl)) { final ClientPropertyImpl other = (ClientPropertyImpl) obj;
return false; return annotations.equals(other.annotations)
} && (name == null ? other.name == null : name.equals(other.name))
ClientPropertyImpl other = (ClientPropertyImpl) obj; && (value == null ? other.value == null : value.equals(other.value));
if (annotations == null) {
if (other.annotations != null) {
return false;
}
} else if (!annotations.equals(other.annotations)) {
return false;
}
if (name == null) {
if (other.name != null) {
return false;
}
} else if (!name.equals(other.name)) {
return false;
}
if (valuable == null) {
if (other.valuable != null) {
return false;
}
} else if (!valuable.equals(other.valuable)) {
return false;
}
if (value == null) {
if (other.value != null) {
return false;
}
} else if (!value.equals(other.value)) {
return false;
}
return true;
} }
@Override @Override
@ -163,31 +75,10 @@ public final class ClientPropertyImpl implements ClientProperty, ClientAnnotatab
int result = 1; int result = 1;
result = prime * result + ((annotations == null) ? 0 : annotations.hashCode()); result = prime * result + ((annotations == null) ? 0 : annotations.hashCode());
result = prime * result + ((name == null) ? 0 : name.hashCode()); result = prime * result + ((name == null) ? 0 : name.hashCode());
result = prime * result + ((valuable == null) ? 0 : valuable.hashCode());
result = prime * result + ((value == null) ? 0 : value.hashCode()); result = prime * result + ((value == null) ? 0 : value.hashCode());
return result; return result;
} }
@Override
public boolean hasEnumValue() {
return valuable.hasEnumValue();
}
@Override
public ClientEnumValue getEnumValue() {
return valuable.getEnumValue();
}
@Override
public ClientComplexValue getComplexValue() {
return valuable.getComplexValue();
}
@Override
public ClientCollectionValue<ClientValue> getCollectionValue() {
return valuable.getCollectionValue();
}
@Override @Override
public List<ClientAnnotation> getAnnotations() { public List<ClientAnnotation> getAnnotations() {
return annotations; return annotations;
@ -195,10 +86,6 @@ public final class ClientPropertyImpl implements ClientProperty, ClientAnnotatab
@Override @Override
public String toString() { public String toString() {
return "ODataPropertyImpl{" return "ClientPropertyImpl{" + "name=" + name + ", value=" + value + ", annotations=" + annotations + '}';
+ "name=" + getName()
+ ",valuable=" + valuable
+ ", annotations=" + annotations
+ '}';
} }
} }

View File

@ -25,9 +25,9 @@ import org.apache.olingo.client.api.domain.ClientPrimitiveValue;
import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.api.domain.ClientValuable;
import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.api.domain.ClientValue;
public final class ClientValuableImpl implements ClientValuable { public class ClientValuableImpl implements ClientValuable {
private final ClientValue value; protected final ClientValue value;
public ClientValuableImpl(final ClientValue value) { public ClientValuableImpl(final ClientValue value) {
this.value = value; this.value = value;
@ -60,9 +60,7 @@ public final class ClientValuableImpl implements ClientValuable {
@Override @Override
public ClientCollectionValue<ClientValue> getCollectionValue() { public ClientCollectionValue<ClientValue> getCollectionValue() {
return hasCollectionValue() return hasCollectionValue() ? getValue().<ClientValue> asCollection() : null;
? getValue().<ClientValue> asCollection()
: null;
} }
@Override @Override
@ -72,9 +70,7 @@ public final class ClientValuableImpl implements ClientValuable {
@Override @Override
public ClientComplexValue getComplexValue() { public ClientComplexValue getComplexValue() {
return hasComplexValue() return hasComplexValue() ? getValue().asComplex() : null;
? getValue().asComplex()
: null;
} }
@Override @Override
@ -84,9 +80,7 @@ public final class ClientValuableImpl implements ClientValuable {
@Override @Override
public ClientEnumValue getEnumValue() { public ClientEnumValue getEnumValue() {
return hasEnumValue() return hasEnumValue() ? getValue().asEnum() : null;
? getValue().asEnum()
: null;
} }
@Override @Override
@ -99,9 +93,7 @@ public final class ClientValuableImpl implements ClientValuable {
} }
ClientValuableImpl that = (ClientValuableImpl) o; ClientValuableImpl that = (ClientValuableImpl) o;
return !(value != null ? !value.equals(that.value) : that.value != null); return !(value != null ? !value.equals(that.value) : that.value != null);
} }
@Override @Override
@ -111,8 +103,6 @@ public final class ClientValuableImpl implements ClientValuable {
@Override @Override
public String toString() { public String toString() {
return "ClientValuableImpl{" + return "ClientValuableImpl{" + "value=" + value + '}';
"value=" + value +
'}';
} }
} }

View File

@ -714,7 +714,7 @@ public class ODataBinderImpl implements ODataBinder {
if (propertyType == null || propertyType.equals(EdmPrimitiveTypeKind.String.getFullQualifiedName().toString())) { if (propertyType == null || propertyType.equals(EdmPrimitiveTypeKind.String.getFullQualifiedName().toString())) {
typeInfo = new EdmTypeInfo.Builder().setTypeExpression(typeName.toString()).build(); typeInfo = new EdmTypeInfo.Builder().setTypeExpression(typeName.toString()).build();
} else if(isPrimiteveType(typeName)) { } else if(isPrimiteveType(typeName)) {
// Inheritance is not allowed for primitve types, so we use the type given by the EDM // Inheritance is not allowed for primitive types, so we use the type given by the EDM.
typeInfo = new EdmTypeInfo.Builder().setTypeExpression(typeName.toString()).build(); typeInfo = new EdmTypeInfo.Builder().setTypeExpression(typeName.toString()).build();
} else { } else {
typeInfo = new EdmTypeInfo.Builder().setTypeExpression(propertyType).build(); typeInfo = new EdmTypeInfo.Builder().setTypeExpression(propertyType).build();

View File

@ -25,9 +25,7 @@ import org.junit.BeforeClass;
public abstract class AbstractTest { public abstract class AbstractTest {
protected static ODataClient v4Client; protected static final ODataClient client = ODataClientFactory.getClient();
protected abstract ODataClient getClient();
@BeforeClass @BeforeClass
public static void setUp() { public static void setUp() {
@ -38,11 +36,6 @@ public abstract class AbstractTest {
XMLUnit.setCompareUnmatched(false); XMLUnit.setCompareUnmatched(false);
} }
@BeforeClass
public static void setClientInstances() {
v4Client = ODataClientFactory.getClient();
}
protected String getSuffix(final ContentType contentType) { protected String getSuffix(final ContentType contentType) {
return contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC) return contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC)
|| contentType.isCompatible(ContentType.APPLICATION_ATOM_XML) || contentType.isCompatible(ContentType.APPLICATION_ATOM_XML)

View File

@ -30,17 +30,11 @@ import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.stream.StreamSource; import javax.xml.transform.stream.StreamSource;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.format.ContentType;
import org.custommonkey.xmlunit.Diff; import org.custommonkey.xmlunit.Diff;
public class AtomTest extends JSONTest { public class AtomTest extends JSONTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
@Override @Override
protected ContentType getODataPubFormat() { protected ContentType getODataPubFormat() {
return ContentType.APPLICATION_ATOM_XML; return ContentType.APPLICATION_ATOM_XML;

View File

@ -26,7 +26,6 @@ import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.net.URI; import java.net.URI;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.data.ResWrap; import org.apache.olingo.client.api.data.ResWrap;
import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntity;
import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientEntitySet;
@ -37,23 +36,18 @@ import org.junit.Test;
public class EntitySetTest extends AbstractTest { public class EntitySetTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
private void read(final ContentType contentType) throws IOException, ODataDeserializerException { private void read(final ContentType contentType) throws IOException, ODataDeserializerException {
final InputStream input = getClass().getResourceAsStream("Customers." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("Customers." + getSuffix(contentType));
final ClientEntitySet entitySet = getClient().getBinder().getODataEntitySet( final ClientEntitySet entitySet = client.getBinder().getODataEntitySet(
getClient().getDeserializer(contentType).toEntitySet(input)); client.getDeserializer(contentType).toEntitySet(input));
assertNotNull(entitySet); assertNotNull(entitySet);
assertEquals(2, entitySet.getEntities().size()); assertEquals(2, entitySet.getEntities().size());
assertNull(entitySet.getNext()); assertNull(entitySet.getNext());
final ClientEntitySet written = final ClientEntitySet written =
getClient().getBinder().getODataEntitySet(new ResWrap<EntityCollection>((URI) null, null, client.getBinder().getODataEntitySet(new ResWrap<EntityCollection>((URI) null, null,
getClient().getBinder().getEntitySet(entitySet))); client.getBinder().getEntitySet(entitySet)));
assertEquals(entitySet, written); assertEquals(entitySet, written);
} }
@ -69,8 +63,8 @@ public class EntitySetTest extends AbstractTest {
private void ref(final ContentType contentType) throws ODataDeserializerException { private void ref(final ContentType contentType) throws ODataDeserializerException {
final InputStream input = getClass().getResourceAsStream("collectionOfEntityReferences." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("collectionOfEntityReferences." + getSuffix(contentType));
final ClientEntitySet entitySet = getClient().getBinder().getODataEntitySet( final ClientEntitySet entitySet = client.getBinder().getODataEntitySet(
getClient().getDeserializer(contentType).toEntitySet(input)); client.getDeserializer(contentType).toEntitySet(input));
assertNotNull(entitySet); assertNotNull(entitySet);
for (ClientEntity entity : entitySet.getEntities()) { for (ClientEntity entity : entitySet.getEntities()) {
@ -79,8 +73,8 @@ public class EntitySetTest extends AbstractTest {
entitySet.setCount(entitySet.getEntities().size()); entitySet.setCount(entitySet.getEntities().size());
final ClientEntitySet written = final ClientEntitySet written =
getClient().getBinder().getODataEntitySet(new ResWrap<EntityCollection>((URI) null, null, client.getBinder().getODataEntitySet(new ResWrap<EntityCollection>((URI) null, null,
getClient().getBinder().getEntitySet(entitySet))); client.getBinder().getEntitySet(entitySet)));
assertEquals(entitySet, written); assertEquals(entitySet, written);
} }

View File

@ -50,11 +50,6 @@ import org.junit.Test;
public class EntityTest extends AbstractTest { public class EntityTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
private EdmEnabledODataClient getEdmEnabledClient() { private EdmEnabledODataClient getEdmEnabledClient() {
return new EdmEnabledODataClientImpl(null, null, null) { return new EdmEnabledODataClientImpl(null, null, null) {
@ -78,8 +73,8 @@ public class EntityTest extends AbstractTest {
private void singleton(final ContentType contentType) throws Exception { private void singleton(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream("VipCustomer." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("VipCustomer." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", entity.getTypeName().toString()); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", entity.getTypeName().toString());
@ -120,8 +115,8 @@ public class EntityTest extends AbstractTest {
// operations won't get serialized // operations won't get serialized
entity.getOperations().clear(); entity.getOperations().clear();
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -138,8 +133,8 @@ public class EntityTest extends AbstractTest {
private void withEnums(final ContentType contentType) throws Exception { private void withEnums(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream("Products_5." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("Products_5." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
final ClientProperty skinColor = entity.getProperty("SkinColor"); final ClientProperty skinColor = entity.getProperty("SkinColor");
@ -156,8 +151,8 @@ public class EntityTest extends AbstractTest {
// operations won't get serialized // operations won't get serialized
entity.getOperations().clear(); entity.getOperations().clear();
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -175,8 +170,8 @@ public class EntityTest extends AbstractTest {
private void withInlineEntitySet(final ContentType contentType) throws Exception { private void withInlineEntitySet(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream( final InputStream input = getClass().getResourceAsStream(
"Accounts_101_expand_MyPaymentInstruments." + getSuffix(contentType)); "Accounts_101_expand_MyPaymentInstruments." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
final ClientLink instruments = entity.getNavigationLink("MyPaymentInstruments"); final ClientLink instruments = entity.getNavigationLink("MyPaymentInstruments");
@ -191,8 +186,8 @@ public class EntityTest extends AbstractTest {
inline.getEntitySet().setCount(3); inline.getEntitySet().setCount(3);
// operations won't get serialized // operations won't get serialized
entity.getOperations().clear(); entity.getOperations().clear();
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -210,16 +205,16 @@ public class EntityTest extends AbstractTest {
private void mediaEntity(final ContentType contentType) throws Exception { private void mediaEntity(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream( final InputStream input = getClass().getResourceAsStream(
"Advertisements_f89dee73-af9f-4cd4-b330-db93c25ff3c7." + getSuffix(contentType)); "Advertisements_f89dee73-af9f-4cd4-b330-db93c25ff3c7." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
assertTrue(entity.isMediaEntity()); assertTrue(entity.isMediaEntity());
assertNotNull(entity.getMediaContentSource()); assertNotNull(entity.getMediaContentSource());
assertEquals("\"8zOOKKvgOtptr4gt8IrnapX3jds=\"", entity.getMediaETag()); assertEquals("\"8zOOKKvgOtptr4gt8IrnapX3jds=\"", entity.getMediaETag());
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -236,8 +231,8 @@ public class EntityTest extends AbstractTest {
private void withStream(final ContentType contentType) throws Exception { private void withStream(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream("PersonDetails_1." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("PersonDetails_1." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
assertFalse(entity.isMediaEntity()); assertFalse(entity.isMediaEntity());
@ -245,8 +240,8 @@ public class EntityTest extends AbstractTest {
final ClientLink editMedia = entity.getMediaEditLink("Photo"); final ClientLink editMedia = entity.getMediaEditLink("Photo");
assertNotNull(editMedia); assertNotNull(editMedia);
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -263,14 +258,14 @@ public class EntityTest extends AbstractTest {
private void ref(final ContentType contentType) throws Exception { private void ref(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream("entityReference." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("entityReference." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
assertNotNull(entity.getId()); assertNotNull(entity.getId());
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -287,8 +282,8 @@ public class EntityTest extends AbstractTest {
private void complexNavigationProperties(final ContentType contentType) throws Exception { private void complexNavigationProperties(final ContentType contentType) throws Exception {
final InputStream input = getClass().getResourceAsStream("entity.withcomplexnavigation." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("entity.withcomplexnavigation." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
final ClientComplexValue addressValue = entity.getProperty("Address").getComplexValue(); final ClientComplexValue addressValue = entity.getProperty("Address").getComplexValue();
@ -297,8 +292,8 @@ public class EntityTest extends AbstractTest {
// ETag is not serialized // ETag is not serialized
entity.setETag(null); entity.setETag(null);
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -315,8 +310,8 @@ public class EntityTest extends AbstractTest {
private void annotated(final ContentType contentType) throws EdmPrimitiveTypeException, Exception { private void annotated(final ContentType contentType) throws EdmPrimitiveTypeException, Exception {
final InputStream input = getClass().getResourceAsStream("annotated." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("annotated." + getSuffix(contentType));
final ClientEntity entity = getClient().getBinder().getODataEntity( final ClientEntity entity = client.getBinder().getODataEntity(
getClient().getDeserializer(contentType).toEntity(input)); client.getDeserializer(contentType).toEntity(input));
assertNotNull(entity); assertNotNull(entity);
assertFalse(entity.getAnnotations().isEmpty()); assertFalse(entity.getAnnotations().isEmpty());
@ -343,8 +338,8 @@ public class EntityTest extends AbstractTest {
assertEquals(2, assertEquals(2,
annotation.getValue().asComplex().get("order").getPrimitiveValue().toCastValue(Integer.class), 0); annotation.getValue().asComplex().get("order").getPrimitiveValue().toCastValue(Integer.class), 0);
final ClientEntity written = getClient().getBinder().getODataEntity( final ClientEntity written = client.getBinder().getODataEntity(
new ResWrap<Entity>((URI) null, null, getClient().getBinder().getEntity(entity))); new ResWrap<Entity>((URI) null, null, client.getBinder().getEntity(entity)));
assertEquals(entity, written); assertEquals(entity, written);
input.close(); input.close();
} }
@ -374,7 +369,7 @@ public class EntityTest extends AbstractTest {
@Test @Test
public void derivedFromAtom() throws Exception { public void derivedFromAtom() throws Exception {
derived(getClient(), ContentType.APPLICATION_ATOM_XML); derived(client, ContentType.APPLICATION_ATOM_XML);
} }
@Test @Test
@ -384,6 +379,6 @@ public class EntityTest extends AbstractTest {
@Test @Test
public void derivedFromFullJSON() throws Exception { public void derivedFromFullJSON() throws Exception {
derived(getClient(), ContentType.JSON_FULL_METADATA); derived(client, ContentType.JSON_FULL_METADATA);
} }
} }

View File

@ -21,7 +21,6 @@ package org.apache.olingo.client.core;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.client.api.serialization.ODataDeserializerException;
import org.apache.olingo.commons.api.ex.ODataError; import org.apache.olingo.commons.api.ex.ODataError;
import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.format.ContentType;
@ -29,13 +28,8 @@ import org.junit.Test;
public class ErrorTest extends AbstractTest { public class ErrorTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
private ODataError error(final String name, final ContentType contentType) throws ODataDeserializerException { private ODataError error(final String name, final ContentType contentType) throws ODataDeserializerException {
final ODataError error = getClient().getDeserializer(contentType).toError( final ODataError error = client.getDeserializer(contentType).toError(
getClass().getResourceAsStream(name + "." + getSuffix(contentType))); getClass().getResourceAsStream(name + "." + getSuffix(contentType)));
assertNotNull(error); assertNotNull(error);
return error; return error;

View File

@ -30,7 +30,6 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.domain.ClientCollectionValue; import org.apache.olingo.client.api.domain.ClientCollectionValue;
import org.apache.olingo.client.api.domain.ClientComplexValue; import org.apache.olingo.client.api.domain.ClientComplexValue;
import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntity;
@ -50,11 +49,6 @@ public class JSONTest extends AbstractTest {
private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper(); private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper();
@Override
protected ODataClient getClient() {
return v4Client;
}
protected ContentType getODataPubFormat() { protected ContentType getODataPubFormat() {
return ContentType.JSON; return ContentType.JSON;
} }
@ -129,7 +123,7 @@ public class JSONTest extends AbstractTest {
protected void entitySet(final String filename, final ContentType contentType) throws Exception { protected void entitySet(final String filename, final ContentType contentType) throws Exception {
final StringWriter writer = new StringWriter(); final StringWriter writer = new StringWriter();
getClient().getSerializer(contentType).write(writer, getClient().getDeserializer(contentType).toEntitySet( client.getSerializer(contentType).write(writer, client.getDeserializer(contentType).toEntitySet(
getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload()); getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload());
assertSimilar(filename + "." + getSuffix(contentType), writer.toString()); assertSimilar(filename + "." + getSuffix(contentType), writer.toString());
@ -143,7 +137,7 @@ public class JSONTest extends AbstractTest {
protected void entity(final String filename, final ContentType contentType) throws Exception { protected void entity(final String filename, final ContentType contentType) throws Exception {
final StringWriter writer = new StringWriter(); final StringWriter writer = new StringWriter();
getClient().getSerializer(contentType).write(writer, getClient().getDeserializer(contentType).toEntity( client.getSerializer(contentType).write(writer, client.getDeserializer(contentType).toEntity(
getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload()); getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload());
assertSimilar(filename + "." + getSuffix(contentType), writer.toString()); assertSimilar(filename + "." + getSuffix(contentType), writer.toString());
} }
@ -169,7 +163,7 @@ public class JSONTest extends AbstractTest {
protected void property(final String filename, final ContentType contentType) throws Exception { protected void property(final String filename, final ContentType contentType) throws Exception {
final StringWriter writer = new StringWriter(); final StringWriter writer = new StringWriter();
getClient().getSerializer(contentType).write(writer, getClient().getDeserializer(contentType). client.getSerializer(contentType).write(writer, client.getDeserializer(contentType).
toProperty(getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload()); toProperty(getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload());
assertSimilar(filename + "." + getSuffix(contentType), writer.toString()); assertSimilar(filename + "." + getSuffix(contentType), writer.toString());
@ -185,12 +179,12 @@ public class JSONTest extends AbstractTest {
@Test @Test
public void crossjoin() throws Exception { public void crossjoin() throws Exception {
assertNotNull(getClient().getDeserializer(ContentType.JSON_FULL_METADATA).toEntitySet( assertNotNull(client.getDeserializer(ContentType.JSON_FULL_METADATA).toEntitySet(
getClass().getResourceAsStream("crossjoin.json"))); getClass().getResourceAsStream("crossjoin.json")));
} }
protected void delta(final String filename, final ContentType contentType) throws Exception { protected void delta(final String filename, final ContentType contentType) throws Exception {
final Delta delta = getClient().getDeserializer(contentType).toDelta( final Delta delta = client.getDeserializer(contentType).toDelta(
getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload(); getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload();
assertNotNull(delta); assertNotNull(delta);
assertNotNull(delta.getDeltaLink()); assertNotNull(delta.getDeltaLink());
@ -223,30 +217,30 @@ public class JSONTest extends AbstractTest {
@Test @Test
public void issueOLINGO390() throws Exception { public void issueOLINGO390() throws Exception {
final ClientEntity message = getClient().getObjectFactory(). final ClientEntity message = client.getObjectFactory().
newEntity(new FullQualifiedName("Microsoft.Exchange.Services.OData.Model.Message")); newEntity(new FullQualifiedName("Microsoft.Exchange.Services.OData.Model.Message"));
final ClientComplexValue toRecipient = getClient().getObjectFactory(). final ClientComplexValue toRecipient = client.getObjectFactory().
newComplexValue("Microsoft.Exchange.Services.OData.Model.Recipient"); newComplexValue("Microsoft.Exchange.Services.OData.Model.Recipient");
toRecipient.add(getClient().getObjectFactory().newPrimitiveProperty("Name", toRecipient.add(client.getObjectFactory().newPrimitiveProperty("Name",
getClient().getObjectFactory().newPrimitiveValueBuilder().buildString("challen_olingo_client"))); client.getObjectFactory().newPrimitiveValueBuilder().buildString("challen_olingo_client")));
toRecipient.add(getClient().getObjectFactory().newPrimitiveProperty("Address", toRecipient.add(client.getObjectFactory().newPrimitiveProperty("Address",
getClient().getObjectFactory().newPrimitiveValueBuilder().buildString("challenh@microsoft.com"))); client.getObjectFactory().newPrimitiveValueBuilder().buildString("challenh@microsoft.com")));
final ClientCollectionValue<ClientValue> toRecipients = getClient().getObjectFactory(). final ClientCollectionValue<ClientValue> toRecipients = client.getObjectFactory().
newCollectionValue("Microsoft.Exchange.Services.OData.Model.Recipient"); newCollectionValue("Microsoft.Exchange.Services.OData.Model.Recipient");
toRecipients.add(toRecipient); toRecipients.add(toRecipient);
message.getProperties().add(getClient().getObjectFactory().newCollectionProperty("ToRecipients", toRecipients)); message.getProperties().add(client.getObjectFactory().newCollectionProperty("ToRecipients", toRecipients));
final ClientComplexValue body = final ClientComplexValue body =
getClient().getObjectFactory().newComplexValue("Microsoft.Exchange.Services.OData.Model.ItemBody"); client.getObjectFactory().newComplexValue("Microsoft.Exchange.Services.OData.Model.ItemBody");
body.add(getClient().getObjectFactory().newPrimitiveProperty("Content", body.add(client.getObjectFactory().newPrimitiveProperty("Content",
getClient().getObjectFactory().newPrimitiveValueBuilder(). client.getObjectFactory().newPrimitiveValueBuilder().
buildString("this is a simple email body content"))); buildString("this is a simple email body content")));
body.add(getClient().getObjectFactory().newEnumProperty("ContentType", body.add(client.getObjectFactory().newEnumProperty("ContentType",
getClient().getObjectFactory().newEnumValue("Microsoft.Exchange.Services.OData.Model.BodyType", "text"))); client.getObjectFactory().newEnumValue("Microsoft.Exchange.Services.OData.Model.BodyType", "text")));
message.getProperties().add(getClient().getObjectFactory().newComplexProperty("Body", body)); message.getProperties().add(client.getObjectFactory().newComplexProperty("Body", body));
final String actual = IOUtils.toString(getClient().getWriter().writeEntity(message, ContentType.JSON)); final String actual = IOUtils.toString(client.getWriter().writeEntity(message, ContentType.JSON));
final JsonNode expected = final JsonNode expected =
OBJECT_MAPPER.readTree(IOUtils.toString(getClass().getResourceAsStream("olingo390.json")). OBJECT_MAPPER.readTree(IOUtils.toString(getClass().getResourceAsStream("olingo390.json")).
replace(Constants.JSON_NAVIGATION_LINK, Constants.JSON_BIND_LINK_SUFFIX)); replace(Constants.JSON_NAVIGATION_LINK, Constants.JSON_BIND_LINK_SUFFIX));

View File

@ -26,7 +26,6 @@ import static org.junit.Assert.assertTrue;
import java.io.InputStream; import java.io.InputStream;
import java.util.List; import java.util.List;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.edm.xml.XMLMetadata; import org.apache.olingo.client.api.edm.xml.XMLMetadata;
import org.apache.olingo.commons.api.Constants; import org.apache.olingo.commons.api.Constants;
import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.Edm;
@ -72,14 +71,9 @@ import org.junit.Test;
public class MetadataTest extends AbstractTest { public class MetadataTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
@Test @Test
public void parse() { public void parse() {
final Edm edm = getClient().getReader().readMetadata(getClass().getResourceAsStream("metadata.xml")); final Edm edm = client.getReader().readMetadata(getClass().getResourceAsStream("metadata.xml"));
assertNotNull(edm); assertNotNull(edm);
// 1. Enum // 1. Enum
@ -140,7 +134,7 @@ public class MetadataTest extends AbstractTest {
@Test @Test
public void demo() { public void demo() {
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML).
toMetadata(getClass().getResourceAsStream("demo-metadata.xml")); toMetadata(getClass().getResourceAsStream("demo-metadata.xml"));
assertNotNull(metadata); assertNotNull(metadata);
@ -154,7 +148,7 @@ public class MetadataTest extends AbstractTest {
annots.getAnnotation("Org.OData.Publication.V1.PrivacyPolicyUrl").getExpression().asConstant().getValue()); annots.getAnnotation("Org.OData.Publication.V1.PrivacyPolicyUrl").getExpression().asConstant().getValue());
// Now let's test some edm:Annotations // Now let's test some edm:Annotations
final Edm edm = getClient().getReader(). final Edm edm = client.getReader().
readMetadata(getClass().getResourceAsStream("demo-metadata.xml")); readMetadata(getClass().getResourceAsStream("demo-metadata.xml"));
assertNotNull(edm); assertNotNull(edm);
@ -181,7 +175,7 @@ public class MetadataTest extends AbstractTest {
@Test @Test
public void multipleSchemas() { public void multipleSchemas() {
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML).
toMetadata(getClass().getResourceAsStream("northwind-metadata.xml")); toMetadata(getClass().getResourceAsStream("northwind-metadata.xml"));
assertNotNull(metadata); assertNotNull(metadata);
@ -198,10 +192,10 @@ public class MetadataTest extends AbstractTest {
@Test @Test
public void getContainerWithoutCallingGetSchemas() { public void getContainerWithoutCallingGetSchemas() {
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML).
toMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml")); toMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml"));
Edm edm = getClient().getReader().readMetadata(metadata.getSchemaByNsOrAlias()); Edm edm = client.getReader().readMetadata(metadata.getSchemaByNsOrAlias());
assertNotNull(edm.getEntityContainer()); assertNotNull(edm.getEntityContainer());
} }
@ -211,7 +205,7 @@ public class MetadataTest extends AbstractTest {
*/ */
@Test @Test
public void fromdoc1() { public void fromdoc1() {
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML).
toMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml")); toMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml"));
assertNotNull(metadata); assertNotNull(metadata);
@ -249,7 +243,7 @@ public class MetadataTest extends AbstractTest {
functionImport.getFunction()); functionImport.getFunction());
// Now let's go high-level // Now let's go high-level
final Edm edm = getClient().getReader().readMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml")); final Edm edm = client.getReader().readMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml"));
assertNotNull(edm); assertNotNull(edm);
List<EdmSchema> schemaList = edm.getSchemas(); List<EdmSchema> schemaList = edm.getSchemas();
@ -291,7 +285,7 @@ public class MetadataTest extends AbstractTest {
*/ */
@Test @Test
public void fromdoc2() { public void fromdoc2() {
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML) final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML)
.toMetadata(getClass().getResourceAsStream("fromdoc2-metadata.xml")); .toMetadata(getClass().getResourceAsStream("fromdoc2-metadata.xml"));
assertNotNull(metadata); assertNotNull(metadata);
@ -336,7 +330,7 @@ public class MetadataTest extends AbstractTest {
*/ */
@Test @Test
public void fromdoc3() { public void fromdoc3() {
final Edm edm = getClient().getReader().readMetadata(getClass().getResourceAsStream("fromdoc3-metadata.xml")); final Edm edm = client.getReader().readMetadata(getClass().getResourceAsStream("fromdoc3-metadata.xml"));
assertNotNull(edm); assertNotNull(edm);
final EdmAnnotations group = edm.getSchema("Annotations").getAnnotationGroups().get(0); final EdmAnnotations group = edm.getSchema("Annotations").getAnnotationGroups().get(0);
@ -354,7 +348,7 @@ public class MetadataTest extends AbstractTest {
*/ */
@Test @Test
public void fromdoc4() { public void fromdoc4() {
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML).
toMetadata(getClass().getResourceAsStream("fromdoc4-metadata.xml")); toMetadata(getClass().getResourceAsStream("fromdoc4-metadata.xml"));
assertNotNull(metadata); assertNotNull(metadata);
@ -382,7 +376,7 @@ public class MetadataTest extends AbstractTest {
assertTrue(urlRef.getValue().asDynamic().isApply()); assertTrue(urlRef.getValue().asDynamic().isApply());
// Now let's go high-level // Now let's go high-level
final Edm edm = getClient().getReader().readMetadata(getClass().getResourceAsStream("fromdoc4-metadata.xml")); final Edm edm = client.getReader().readMetadata(getClass().getResourceAsStream("fromdoc4-metadata.xml"));
assertNotNull(edm); assertNotNull(edm);
final EdmAnnotations edmGroup = edm.getSchemas().get(0).getAnnotationGroups().get(0); final EdmAnnotations edmGroup = edm.getSchemas().get(0).getAnnotationGroups().get(0);
@ -410,8 +404,7 @@ public class MetadataTest extends AbstractTest {
@Test @Test
public void metadataWithCapabilities() throws Exception { public void metadataWithCapabilities() throws Exception {
InputStream input = getClass().getResourceAsStream("Metadata-With-Capabilities.xml"); InputStream input = getClass().getResourceAsStream("Metadata-With-Capabilities.xml");
final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). final XMLMetadata metadata = client.getDeserializer(ContentType.APPLICATION_XML).toMetadata(input);
toMetadata(input);
CsdlSchema schema = metadata.getSchema("Capabilities"); CsdlSchema schema = metadata.getSchema("Capabilities");
assertNotNull(schema); assertNotNull(schema);

View File

@ -18,31 +18,25 @@
*/ */
package org.apache.olingo.client.core; package org.apache.olingo.client.core;
import org.apache.olingo.client.api.ODataClient; import static org.junit.Assert.assertEquals;
import java.util.Calendar;
import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.api.domain.ClientValue;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
import org.junit.Test; import org.junit.Test;
import java.util.Calendar;
import static org.junit.Assert.assertEquals;
public class PrimitiveValueTest extends AbstractTest { public class PrimitiveValueTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
@Test @Test
public void timeOfDay() throws EdmPrimitiveTypeException { public void timeOfDay() throws EdmPrimitiveTypeException {
final Calendar expected = Calendar.getInstance(); final Calendar expected = Calendar.getInstance();
expected.clear(); expected.clear();
expected.set(2013, 0, 10, 21, 45, 17); expected.set(2013, 0, 10, 21, 45, 17);
final ClientValue value = getClient().getObjectFactory().newPrimitiveValueBuilder(). final ClientValue value = client.getObjectFactory().newPrimitiveValueBuilder()
setType(EdmPrimitiveTypeKind.TimeOfDay).setValue(expected).build(); .setType(EdmPrimitiveTypeKind.TimeOfDay).setValue(expected).build();
assertEquals(EdmPrimitiveTypeKind.TimeOfDay, value.asPrimitive().getTypeKind()); assertEquals(EdmPrimitiveTypeKind.TimeOfDay, value.asPrimitive().getTypeKind());
final Calendar actual = value.asPrimitive().toCastValue(Calendar.class); final Calendar actual = value.asPrimitive().toCastValue(Calendar.class);
@ -59,8 +53,8 @@ public class PrimitiveValueTest extends AbstractTest {
expected.clear(); expected.clear();
expected.set(2013, 0, 10); expected.set(2013, 0, 10);
final ClientValue value = getClient().getObjectFactory().newPrimitiveValueBuilder(). final ClientValue value = client.getObjectFactory().newPrimitiveValueBuilder()
setType(EdmPrimitiveTypeKind.Date).setValue(expected).build(); .setType(EdmPrimitiveTypeKind.Date).setValue(expected).build();
assertEquals(EdmPrimitiveTypeKind.Date, value.asPrimitive().getTypeKind()); assertEquals(EdmPrimitiveTypeKind.Date, value.asPrimitive().getTypeKind());
final Calendar actual = value.asPrimitive().toCastValue(Calendar.class); final Calendar actual = value.asPrimitive().toCastValue(Calendar.class);

View File

@ -25,35 +25,29 @@ import static org.junit.Assert.assertTrue;
import java.io.InputStream; import java.io.InputStream;
import java.util.Iterator; import java.util.Iterator;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.domain.ClientCollectionValue; import org.apache.olingo.client.api.domain.ClientCollectionValue;
import org.apache.olingo.client.api.domain.ClientComplexValue; import org.apache.olingo.client.api.domain.ClientComplexValue;
import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientProperty;
import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.api.domain.ClientValue;
import org.apache.olingo.commons.api.format.ContentType;
import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.client.api.serialization.ODataDeserializerException;
import org.apache.olingo.client.api.serialization.ODataSerializerException; import org.apache.olingo.client.api.serialization.ODataSerializerException;
import org.apache.olingo.commons.api.format.ContentType;
import org.junit.Test; import org.junit.Test;
public class PropertyTest extends AbstractTest { public class PropertyTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
private void _enum(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException { private void _enum(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException {
final InputStream input = getClass().getResourceAsStream("Products_5_SkinColor." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("Products_5_SkinColor." + getSuffix(contentType));
final ClientProperty property = getClient().getReader().readProperty(input, contentType); final ClientProperty property = client.getReader().readProperty(input, contentType);
assertNotNull(property); assertNotNull(property);
assertTrue(property.hasEnumValue()); assertTrue(property.hasEnumValue());
final ClientProperty written = getClient().getReader().readProperty( final ClientProperty written = client.getReader().readProperty(
getClient().getWriter().writeProperty(property, contentType), contentType); client.getWriter().writeProperty(property, contentType), contentType);
// This is needed because type information gets lost with serialization // This is needed because type information gets lost with serialization
if (contentType.isCompatible(ContentType.APPLICATION_XML)) { if (contentType.isCompatible(ContentType.APPLICATION_XML)) {
final ClientProperty comparable = getClient().getObjectFactory().newEnumProperty(property.getName(), final ClientProperty comparable = client.getObjectFactory().newEnumProperty(property.getName(),
getClient().getObjectFactory(). client.getObjectFactory().
newEnumValue(property.getEnumValue().getTypeName(), written.getEnumValue().getValue())); newEnumValue(property.getEnumValue().getTypeName(), written.getEnumValue().getValue()));
assertEquals(property, comparable); assertEquals(property, comparable);
@ -72,21 +66,21 @@ public class PropertyTest extends AbstractTest {
private void complex(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException { private void complex(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException {
final InputStream input = getClass().getResourceAsStream("Employees_3_HomeAddress." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("Employees_3_HomeAddress." + getSuffix(contentType));
final ClientProperty property = getClient().getReader().readProperty(input, contentType); final ClientProperty property = client.getReader().readProperty(input, contentType);
assertNotNull(property); assertNotNull(property);
assertTrue(property.hasComplexValue()); assertTrue(property.hasComplexValue());
assertEquals(3, property.getComplexValue().size()); assertEquals(3, property.getComplexValue().size());
final ClientProperty written = getClient().getReader().readProperty( final ClientProperty written = client.getReader().readProperty(
getClient().getWriter().writeProperty(property, contentType), contentType); client.getWriter().writeProperty(property, contentType), contentType);
// This is needed because type information gets lost with JSON serialization // This is needed because type information gets lost with JSON serialization
final ClientComplexValue typedValue = getClient().getObjectFactory(). final ClientComplexValue typedValue = client.getObjectFactory().
newComplexValue(property.getComplexValue().getTypeName()); newComplexValue(property.getComplexValue().getTypeName());
for (final Iterator<ClientProperty> itor = written.getComplexValue().iterator(); itor.hasNext();) { for (final Iterator<ClientProperty> itor = written.getComplexValue().iterator(); itor.hasNext();) {
final ClientProperty prop = itor.next(); final ClientProperty prop = itor.next();
typedValue.add(prop); typedValue.add(prop);
} }
final ClientProperty comparable = getClient().getObjectFactory(). final ClientProperty comparable = client.getObjectFactory().
newComplexProperty(property.getName(), typedValue); newComplexProperty(property.getName(), typedValue);
assertEquals(property, comparable); assertEquals(property, comparable);
@ -104,22 +98,22 @@ public class PropertyTest extends AbstractTest {
private void collection(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException { private void collection(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException {
final InputStream input = getClass().getResourceAsStream("Products_5_CoverColors." + getSuffix(contentType)); final InputStream input = getClass().getResourceAsStream("Products_5_CoverColors." + getSuffix(contentType));
final ClientProperty property = getClient().getReader().readProperty(input, contentType); final ClientProperty property = client.getReader().readProperty(input, contentType);
assertNotNull(property); assertNotNull(property);
assertTrue(property.hasCollectionValue()); assertTrue(property.hasCollectionValue());
assertEquals(3, property.getCollectionValue().size()); assertEquals(3, property.getCollectionValue().size());
final ClientProperty written = getClient().getReader().readProperty( final ClientProperty written = client.getReader().readProperty(
getClient().getWriter().writeProperty(property, contentType), contentType); client.getWriter().writeProperty(property, contentType), contentType);
// This is needed because type information gets lost with JSON serialization // This is needed because type information gets lost with JSON serialization
if(contentType.isCompatible(ContentType.APPLICATION_XML)) { if(contentType.isCompatible(ContentType.APPLICATION_XML)) {
final ClientCollectionValue<ClientValue> typedValue = getClient().getObjectFactory(). final ClientCollectionValue<ClientValue> typedValue = client.getObjectFactory().
newCollectionValue(property.getCollectionValue().getTypeName()); newCollectionValue(property.getCollectionValue().getTypeName());
for (final Iterator<ClientValue> itor = written.getCollectionValue().iterator(); itor.hasNext();) { for (final Iterator<ClientValue> itor = written.getCollectionValue().iterator(); itor.hasNext();) {
final ClientValue value = itor.next(); final ClientValue value = itor.next();
typedValue.add(value); typedValue.add(value);
} }
final ClientProperty comparable = getClient().getObjectFactory(). final ClientProperty comparable = client.getObjectFactory().
newCollectionProperty(property.getName(), typedValue); newCollectionProperty(property.getName(), typedValue);
assertEquals(property, comparable); assertEquals(property, comparable);

View File

@ -24,7 +24,6 @@ import static org.junit.Assert.assertTrue;
import java.net.URI; import java.net.URI;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.data.ResWrap; import org.apache.olingo.client.api.data.ResWrap;
import org.apache.olingo.client.api.data.ServiceDocument; import org.apache.olingo.client.api.data.ServiceDocument;
import org.apache.olingo.client.api.domain.ClientServiceDocument; import org.apache.olingo.client.api.domain.ClientServiceDocument;
@ -34,23 +33,14 @@ import org.junit.Test;
public class ServiceDocumentTest extends AbstractTest { public class ServiceDocumentTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
private String getFileExtension(final ContentType contentType) {
return contentType.isCompatible(ContentType.APPLICATION_XML) ? "xml" : "json";
}
private ClientServiceDocument parse(final ContentType contentType) throws ODataDeserializerException { private ClientServiceDocument parse(final ContentType contentType) throws ODataDeserializerException {
ResWrap<ServiceDocument> service = getClient().getDeserializer(contentType).toServiceDocument( ResWrap<ServiceDocument> service = client.getDeserializer(contentType).toServiceDocument(
getClass().getResourceAsStream("serviceDocument." + getFileExtension(contentType))); getClass().getResourceAsStream("serviceDocument." + getSuffix(contentType)));
assertEquals(URI.create("http://host/service/$metadata"), service.getContextURL()); assertEquals(URI.create("http://host/service/$metadata"), service.getContextURL());
assertEquals("W/\"MjAxMy0wNS0xM1QxNDo1NFo=\"", service.getMetadataETag()); assertEquals("W/\"MjAxMy0wNS0xM1QxNDo1NFo=\"", service.getMetadataETag());
final ClientServiceDocument serviceDocument = getClient().getBinder().getODataServiceDocument(service.getPayload()); final ClientServiceDocument serviceDocument = client.getBinder().getODataServiceDocument(service.getPayload());
assertNotNull(serviceDocument); assertNotNull(serviceDocument);
assertTrue(serviceDocument.getEntitySetNames().contains("Order Details")); assertTrue(serviceDocument.getEntitySetNames().contains("Order Details"));

View File

@ -25,7 +25,6 @@ import java.net.URLEncoder;
import java.util.Calendar; import java.util.Calendar;
import java.util.TimeZone; import java.util.TimeZone;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.uri.FilterArgFactory; import org.apache.olingo.client.api.uri.FilterArgFactory;
import org.apache.olingo.client.api.uri.FilterFactory; import org.apache.olingo.client.api.uri.FilterFactory;
import org.apache.olingo.client.api.uri.URIFilter; import org.apache.olingo.client.api.uri.URIFilter;
@ -39,13 +38,8 @@ import org.junit.Test;
public class FilterFactoryTest extends AbstractTest { public class FilterFactoryTest extends AbstractTest {
@Override
protected ODataClient getClient() {
return v4Client;
}
private FilterFactory getFilterFactory() { private FilterFactory getFilterFactory() {
return getClient().getFilterFactory(); return client.getFilterFactory();
} }
private FilterArgFactory getFilterArgFactory() { private FilterArgFactory getFilterArgFactory() {

View File

@ -26,32 +26,25 @@ import java.util.Collections;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.Map; import java.util.Map;
import org.apache.olingo.client.api.ODataClient;
import org.apache.olingo.client.api.uri.QueryOption; import org.apache.olingo.client.api.uri.QueryOption;
import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.client.api.uri.URIBuilder;
import org.apache.olingo.client.core.AbstractTest; import org.apache.olingo.client.core.AbstractTest;
import org.apache.olingo.client.core.uri.ParameterAlias;
import org.junit.Test; import org.junit.Test;
public class URIBuilderTest extends AbstractTest { public class URIBuilderTest extends AbstractTest {
private static final String SERVICE_ROOT = "http://host/service"; private static final String SERVICE_ROOT = "http://host/service";
@Override
protected ODataClient getClient() {
return v4Client;
}
@Test @Test
public void metadata() throws URISyntaxException { public void metadata() throws URISyntaxException {
final URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendMetadataSegment().build(); final URI uri = client.newURIBuilder(SERVICE_ROOT).appendMetadataSegment().build();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/$metadata").build(), uri); assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/$metadata").build(), uri);
} }
@Test @Test
public void entity() throws URISyntaxException { public void entity() throws URISyntaxException {
final URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("AnEntitySet"). final URI uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("AnEntitySet").
appendKeySegment(11).build(); appendKeySegment(11).build();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/AnEntitySet(11)").build(), uri); assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/AnEntitySet(11)").build(), uri);
@ -59,21 +52,21 @@ public class URIBuilderTest extends AbstractTest {
final Map<String, Object> multiKey = new LinkedHashMap<String, Object>(); final Map<String, Object> multiKey = new LinkedHashMap<String, Object>();
multiKey.put("OrderId", -10); multiKey.put("OrderId", -10);
multiKey.put("ProductId", -10); multiKey.put("ProductId", -10);
URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("OrderLine").appendKeySegment(multiKey). appendEntitySetSegment("OrderLine").appendKeySegment(multiKey).
appendPropertySegment("Quantity").appendValueSegment(); appendPropertySegment("Quantity").appendValueSegment();
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
SERVICE_ROOT + "/OrderLine(OrderId=-10,ProductId=-10)/Quantity/$value").build(), uriBuilder.build()); SERVICE_ROOT + "/OrderLine(OrderId=-10,ProductId=-10)/Quantity/$value").build(), uriBuilder.build());
uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Customer").appendKeySegment(-10). appendEntitySetSegment("Customer").appendKeySegment(-10).
select("CustomerId", "Name", "Orders").expand("Orders"); select("CustomerId", "Name", "Orders").expand("Orders");
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Customer(-10)"). assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Customer(-10)").
addParameter("$select", "CustomerId,Name,Orders").addParameter("$expand", "Orders").build(), addParameter("$select", "CustomerId,Name,Orders").addParameter("$expand", "Orders").build(),
uriBuilder.build()); uriBuilder.build());
uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Customer").appendKeySegment(-10).appendNavigationSegment("Orders").appendRefSegment(); appendEntitySetSegment("Customer").appendKeySegment(-10).appendNavigationSegment("Orders").appendRefSegment();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Customer(-10)/Orders/$ref").build(), assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Customer(-10)/Orders/$ref").build(),
uriBuilder.build()); uriBuilder.build());
@ -81,7 +74,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void expandWithOptions() throws URISyntaxException { public void expandWithOptions() throws URISyntaxException {
final URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").appendKeySegment(5). final URI uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").appendKeySegment(5).
expandWithOptions("ProductDetails", new LinkedHashMap<QueryOption, Object>() { expandWithOptions("ProductDetails", new LinkedHashMap<QueryOption, Object>() {
private static final long serialVersionUID = 3109256773218160485L; private static final long serialVersionUID = 3109256773218160485L;
@ -96,7 +89,7 @@ public class URIBuilderTest extends AbstractTest {
} }
public void expandWithLevels() throws URISyntaxException { public void expandWithLevels() throws URISyntaxException {
final URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").appendKeySegment(1). final URI uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").appendKeySegment(1).
expandWithOptions("Customer", Collections.<QueryOption, Object> singletonMap(QueryOption.LEVELS, 4)). expandWithOptions("Customer", Collections.<QueryOption, Object> singletonMap(QueryOption.LEVELS, 4)).
build(); build();
@ -106,11 +99,11 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void count() throws URISyntaxException { public void count() throws URISyntaxException {
URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").count().build(); URI uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").count().build();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Products/$count").build(), uri); assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Products/$count").build(), uri);
uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").count(true).build(); uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").count(true).build();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Products"). assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Products").
addParameter("$count", "true").build(), uri); addParameter("$count", "true").build(), uri);
@ -118,34 +111,34 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void filter() throws URISyntaxException { public void filter() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("AnEntitySet"). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("AnEntitySet").
filter(getClient().getFilterFactory().lt("VIN", 16)); filter(client.getFilterFactory().lt("VIN", 16));
assertEquals("http://host/service/AnEntitySet?%24filter=%28VIN%20lt%2016%29", uriBuilder.build().toASCIIString()); assertEquals("http://host/service/AnEntitySet?%24filter=%28VIN%20lt%2016%29", uriBuilder.build().toASCIIString());
// assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/AnEntitySet"). // assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/AnEntitySet").
// addParameter("$filter", "(VIN lt 16)").build(), // addParameter("$filter", "(VIN lt 16)").build(),
// uriBuilder.build()); // uriBuilder.build());
} }
@Test @Test
public void filterWithParameter() throws URISyntaxException { public void filterWithParameter() throws URISyntaxException {
// http://host/service.svc/Employees?$filter=Region eq @p1&@p1='WA' // http://host/service.svc/Employees?$filter=Region eq @p1&@p1='WA'
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Employees"). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Employees").
filter(getClient().getFilterFactory().eq("Region", new ParameterAlias("p1"))). filter(client.getFilterFactory().eq("Region", new ParameterAlias("p1"))).
addParameterAlias("p1", "'WA'"); addParameterAlias("p1", "'WA'");
assertEquals("http://host/service/Employees?%24filter=%28Region%20eq%20%40p1%29&%40p1='WA'", uriBuilder.build() assertEquals("http://host/service/Employees?%24filter=%28Region%20eq%20%40p1%29&%40p1='WA'", uriBuilder.build()
.toASCIIString()); .toASCIIString());
// assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Employees"). // assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Employees").
// addParameter("$filter", "(Region eq @p1)").addParameter("@p1", "'WA'").build(), // addParameter("$filter", "(Region eq @p1)").addParameter("@p1", "'WA'").build(),
// uriBuilder.build()); // uriBuilder.build());
} }
@Test @Test
public void expandMoreThenOnce() throws URISyntaxException { public void expandMoreThenOnce() throws URISyntaxException {
URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").appendKeySegment(5). URI uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Products").appendKeySegment(5).
expand("Orders", "Customers").expand("Info").build(); expand("Orders", "Customers").expand("Info").build();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Products(5)"). assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Products(5)").
@ -154,7 +147,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void selectMoreThenOnce() throws URISyntaxException { public void selectMoreThenOnce() throws URISyntaxException {
URI uri = getClient().newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Customers").appendKeySegment(5). URI uri = client.newURIBuilder(SERVICE_ROOT).appendEntitySetSegment("Customers").appendKeySegment(5).
select("Name", "Surname").expand("Info").select("Gender").build(); select("Name", "Surname").expand("Info").select("Gender").build();
assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Customers(5)"). assertEquals(new org.apache.http.client.utils.URIBuilder(SERVICE_ROOT + "/Customers(5)").
@ -163,7 +156,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void singleton() throws URISyntaxException { public void singleton() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendSingletonSegment("BestProductEverCreated"); appendSingletonSegment("BestProductEverCreated");
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
@ -172,7 +165,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void entityId() throws URISyntaxException { public void entityId() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntityIdSegment("Products(0)"); appendEntityIdSegment("Products(0)");
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
@ -181,7 +174,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void boundAction() throws URISyntaxException { public void boundAction() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Categories").appendKeySegment(1). appendEntitySetSegment("Categories").appendKeySegment(1).
appendNavigationSegment("Products"). appendNavigationSegment("Products").
appendActionCallSegment("Model.AllOrders"); appendActionCallSegment("Model.AllOrders");
@ -189,10 +182,10 @@ public class URIBuilderTest extends AbstractTest {
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
SERVICE_ROOT + "/Categories(1)/Products/Model.AllOrders").build(), uriBuilder.build()); SERVICE_ROOT + "/Categories(1)/Products/Model.AllOrders").build(), uriBuilder.build());
} }
@Test @Test
public void boundOperation() throws URISyntaxException { public void boundOperation() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Categories").appendKeySegment(1). appendEntitySetSegment("Categories").appendKeySegment(1).
appendNavigationSegment("Products"). appendNavigationSegment("Products").
appendOperationCallSegment("Model.AllOrders"); appendOperationCallSegment("Model.AllOrders");
@ -203,14 +196,14 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void ref() throws URISyntaxException { public void ref() throws URISyntaxException {
URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Categories").appendKeySegment(1). appendEntitySetSegment("Categories").appendKeySegment(1).
appendNavigationSegment("Products").appendRefSegment(); appendNavigationSegment("Products").appendRefSegment();
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
SERVICE_ROOT + "/Categories(1)/Products/$ref").build(), uriBuilder.build()); SERVICE_ROOT + "/Categories(1)/Products/$ref").build(), uriBuilder.build());
uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Categories").appendKeySegment(1). appendEntitySetSegment("Categories").appendKeySegment(1).
appendNavigationSegment("Products").appendRefSegment().id("../../Products(0)"); appendNavigationSegment("Products").appendRefSegment().id("../../Products(0)");
@ -221,7 +214,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void derived() throws URISyntaxException { public void derived() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Customers").appendDerivedEntityTypeSegment("Model.VipCustomer").appendKeySegment(1); appendEntitySetSegment("Customers").appendDerivedEntityTypeSegment("Model.VipCustomer").appendKeySegment(1);
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
@ -230,7 +223,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void crossjoin() throws URISyntaxException { public void crossjoin() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendCrossjoinSegment("Products", "Sales"); appendCrossjoinSegment("Products", "Sales");
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
@ -239,7 +232,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void all() throws URISyntaxException { public void all() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT).appendAllSegment(); final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).appendAllSegment();
assertEquals(new org.apache.http.client.utils.URIBuilder( assertEquals(new org.apache.http.client.utils.URIBuilder(
SERVICE_ROOT + "/$all").build(), uriBuilder.build()); SERVICE_ROOT + "/$all").build(), uriBuilder.build());
@ -247,7 +240,7 @@ public class URIBuilderTest extends AbstractTest {
@Test @Test
public void search() throws URISyntaxException { public void search() throws URISyntaxException {
final URIBuilder uriBuilder = getClient().newURIBuilder(SERVICE_ROOT). final URIBuilder uriBuilder = client.newURIBuilder(SERVICE_ROOT).
appendEntitySetSegment("Products").search("blue OR green"); appendEntitySetSegment("Products").search("blue OR green");
assertEquals(new URI("http://host/service/Products?%24search=blue%20OR%20green"), uriBuilder.build()); assertEquals(new URI("http://host/service/Products?%24search=blue%20OR%20green"), uriBuilder.build());

View File

@ -72,7 +72,6 @@ public abstract class Geospatial {
* The OGIS geometry type number for feature collections. * The OGIS geometry type number for feature collections.
*/ */
GEOSPATIALCOLLECTION GEOSPATIALCOLLECTION
} }
protected final Dimension dimension; protected final Dimension dimension;
@ -87,8 +86,8 @@ public abstract class Geospatial {
/** /**
* Constructor. * Constructor.
* *
* @param dimension dimension. * @param dimension dimension
* @param type type. * @param type type
* @param srid SRID * @param srid SRID
*/ */
protected Geospatial(final Dimension dimension, final Type type, final SRID srid) { protected Geospatial(final Dimension dimension, final Type type, final SRID srid) {
@ -129,7 +128,7 @@ public abstract class Geospatial {
/** /**
* Returns the {@link EdmPrimitiveTypeKind} * Returns the {@link EdmPrimitiveTypeKind}
* @return Edm primitve type kind * @return EDM primitive type kind
*/ */
public abstract EdmPrimitiveTypeKind getEdmPrimitiveTypeKind(); public abstract EdmPrimitiveTypeKind getEdmPrimitiveTypeKind();
} }

View File

@ -23,7 +23,6 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.Edm;
import org.apache.olingo.commons.api.edm.EdmElement;
import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.EdmEntityType;
import org.apache.olingo.commons.api.edm.EdmException; import org.apache.olingo.commons.api.edm.EdmException;
import org.apache.olingo.commons.api.edm.EdmNavigationProperty; import org.apache.olingo.commons.api.edm.EdmNavigationProperty;
@ -32,7 +31,7 @@ import org.apache.olingo.commons.api.edm.EdmStructuredType;
import org.apache.olingo.commons.api.edm.provider.CsdlNavigationProperty; import org.apache.olingo.commons.api.edm.provider.CsdlNavigationProperty;
import org.apache.olingo.commons.api.edm.provider.CsdlReferentialConstraint; import org.apache.olingo.commons.api.edm.provider.CsdlReferentialConstraint;
public class EdmNavigationPropertyImpl extends AbstractEdmNamed implements EdmElement, EdmNavigationProperty { public class EdmNavigationPropertyImpl extends AbstractEdmNamed implements EdmNavigationProperty {
private final CsdlNavigationProperty navigationProperty; private final CsdlNavigationProperty navigationProperty;
private List<EdmReferentialConstraint> referentialConstraints; private List<EdmReferentialConstraint> referentialConstraints;

View File

@ -19,7 +19,6 @@
package org.apache.olingo.commons.core.edm; package org.apache.olingo.commons.core.edm;
import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.Edm;
import org.apache.olingo.commons.api.edm.EdmElement;
import org.apache.olingo.commons.api.edm.EdmException; import org.apache.olingo.commons.api.edm.EdmException;
import org.apache.olingo.commons.api.edm.EdmMapping; import org.apache.olingo.commons.api.edm.EdmMapping;
import org.apache.olingo.commons.api.edm.EdmParameter; import org.apache.olingo.commons.api.edm.EdmParameter;
@ -27,7 +26,7 @@ import org.apache.olingo.commons.api.edm.EdmType;
import org.apache.olingo.commons.api.edm.geo.SRID; import org.apache.olingo.commons.api.edm.geo.SRID;
import org.apache.olingo.commons.api.edm.provider.CsdlParameter; import org.apache.olingo.commons.api.edm.provider.CsdlParameter;
public class EdmParameterImpl extends AbstractEdmNamed implements EdmParameter, EdmElement { public class EdmParameterImpl extends AbstractEdmNamed implements EdmParameter {
private final CsdlParameter parameter; private final CsdlParameter parameter;
private EdmType typeImpl; private EdmType typeImpl;

View File

@ -19,7 +19,6 @@
package org.apache.olingo.commons.core.edm; package org.apache.olingo.commons.core.edm;
import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.Edm;
import org.apache.olingo.commons.api.edm.EdmElement;
import org.apache.olingo.commons.api.edm.EdmException; import org.apache.olingo.commons.api.edm.EdmException;
import org.apache.olingo.commons.api.edm.EdmMapping; import org.apache.olingo.commons.api.edm.EdmMapping;
import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.edm.EdmProperty;
@ -27,7 +26,7 @@ import org.apache.olingo.commons.api.edm.EdmType;
import org.apache.olingo.commons.api.edm.geo.SRID; import org.apache.olingo.commons.api.edm.geo.SRID;
import org.apache.olingo.commons.api.edm.provider.CsdlProperty; import org.apache.olingo.commons.api.edm.provider.CsdlProperty;
public class EdmPropertyImpl extends AbstractEdmNamed implements EdmProperty, EdmElement { public class EdmPropertyImpl extends AbstractEdmNamed implements EdmProperty {
private final CsdlProperty property; private final CsdlProperty property;
private EdmTypeInfo typeInfo; private EdmTypeInfo typeInfo;
@ -59,7 +58,7 @@ public class EdmPropertyImpl extends AbstractEdmNamed implements EdmProperty, Ed
if (property.getType() == null) { if (property.getType() == null) {
throw new EdmException("Property " + property.getName() + " must hava a full qualified type."); throw new EdmException("Property " + property.getName() + " must hava a full qualified type.");
} }
typeInfo = new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(property.getType().toString()).build(); typeInfo = new EdmTypeInfo.Builder().setEdm(edm).setTypeExpression(property.getType()).build();
} }
@Override @Override

View File

@ -33,20 +33,26 @@ import org.apache.olingo.server.core.deserializer.batch.BatchParserCommon;
public class BatchFacadeImpl implements BatchFacade { public class BatchFacadeImpl implements BatchFacade {
private final BatchPartHandler partHandler; private final BatchPartHandler partHandler;
public BatchFacadeImpl(final ODataHandler oDataHandler, final ODataRequest request, /**
final BatchProcessor batchProcessor, final boolean isStrict) { * Creates a new BatchFacade.
* @param oDataHandler handler
* @param batchProcessor batch processor
* @param isStrict mode switch (currently not used)
*/
public BatchFacadeImpl(final ODataHandler oDataHandler, final BatchProcessor batchProcessor,
final boolean isStrict) {
partHandler = new BatchPartHandler(oDataHandler, batchProcessor, this); partHandler = new BatchPartHandler(oDataHandler, batchProcessor, this);
} }
@Override @Override
public ODataResponse handleODataRequest(final ODataRequest request) throws ODataApplicationException, public ODataResponse handleODataRequest(final ODataRequest request)
ODataLibraryException { throws ODataApplicationException, ODataLibraryException {
return partHandler.handleODataRequest(request); return partHandler.handleODataRequest(request);
} }
@Override @Override
public ODataResponsePart handleBatchRequest(final BatchRequestPart request) throws ODataApplicationException, public ODataResponsePart handleBatchRequest(final BatchRequestPart request)
ODataLibraryException { throws ODataApplicationException, ODataLibraryException {
return partHandler.handleBatchRequest(request); return partHandler.handleBatchRequest(request);
} }

View File

@ -46,7 +46,7 @@ public class BatchHandler {
throws ODataApplicationException, ODataLibraryException { throws ODataApplicationException, ODataLibraryException {
validateRequest(request); validateRequest(request);
final BatchFacade operation = new BatchFacadeImpl(oDataHandler, request, batchProcessor, isStrict); final BatchFacade operation = new BatchFacadeImpl(oDataHandler, batchProcessor, isStrict);
batchProcessor.processBatch(operation, request, response); batchProcessor.processBatch(operation, request, response);
} }