[OLINGO-246] provided batch integration; still missing internak batch reference support

This commit is contained in:
fmartelli 2014-04-15 16:33:19 +02:00
parent 542541dd4c
commit 68f27d57a1
13 changed files with 688 additions and 410 deletions

View File

@ -18,12 +18,12 @@
*/ */
package org.apache.olingo.fit; package org.apache.olingo.fit;
import org.apache.olingo.commons.api.data.Container; import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.JsonNode;
import org.apache.olingo.commons.api.data.Feed; import org.apache.olingo.commons.api.data.Feed;
import org.apache.olingo.commons.api.data.Link; import org.apache.olingo.commons.api.data.Link;
import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.Property;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.apache.olingo.commons.api.format.ContentType;
import org.apache.olingo.commons.core.data.AtomFeedImpl; import org.apache.olingo.commons.core.data.AtomFeedImpl;
import org.apache.olingo.commons.core.data.LinkImpl; import org.apache.olingo.commons.core.data.LinkImpl;
import org.apache.olingo.fit.metadata.Metadata; import org.apache.olingo.fit.metadata.Metadata;
@ -33,24 +33,28 @@ import org.apache.olingo.fit.utils.ConstantKey;
import org.apache.olingo.fit.utils.Constants; import org.apache.olingo.fit.utils.Constants;
import org.apache.olingo.fit.utils.DataBinder; import org.apache.olingo.fit.utils.DataBinder;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.io.File; import java.io.File;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStreamWriter; import java.io.OutputStreamWriter;
import java.util.AbstractMap; import java.util.AbstractMap;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.Enumeration;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; 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.UUID;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import javax.mail.Header;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMultipart;
import javax.ws.rs.Consumes; import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE; import javax.ws.rs.DELETE;
import javax.ws.rs.DefaultValue; import javax.ws.rs.DefaultValue;
@ -65,12 +69,20 @@ import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam; import javax.ws.rs.QueryParam;
import javax.ws.rs.core.Context; import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.MultivaluedHashMap;
import javax.ws.rs.core.MultivaluedMap;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
import javax.ws.rs.core.UriInfo; 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.cxf.jaxrs.client.WebClient;
import org.apache.cxf.jaxrs.ext.multipart.Attachment;
import org.apache.cxf.jaxrs.ext.multipart.Multipart;
import org.apache.cxf.jaxrs.ext.multipart.MultipartBody;
import org.apache.olingo.commons.api.data.Container;
import org.apache.olingo.commons.api.data.Entry; import org.apache.olingo.commons.api.data.Entry;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
import org.apache.olingo.commons.api.format.ContentType;
import org.apache.olingo.commons.core.data.AtomEntryImpl; import org.apache.olingo.commons.core.data.AtomEntryImpl;
import org.apache.olingo.commons.core.data.AtomPropertyImpl; import org.apache.olingo.commons.core.data.AtomPropertyImpl;
import org.apache.olingo.commons.core.data.AtomSerializer; import org.apache.olingo.commons.core.data.AtomSerializer;
@ -81,13 +93,13 @@ import org.apache.olingo.commons.core.data.PrimitiveValueImpl;
import org.apache.olingo.fit.metadata.EntitySet; import org.apache.olingo.fit.metadata.EntitySet;
import org.apache.olingo.fit.metadata.EntityType; import org.apache.olingo.fit.metadata.EntityType;
import org.apache.olingo.fit.metadata.NavigationProperty; import org.apache.olingo.fit.metadata.NavigationProperty;
import org.apache.olingo.fit.methods.MERGE;
import org.apache.olingo.fit.methods.PATCH;
import org.apache.olingo.fit.serializer.FITAtomDeserializer;
import org.apache.olingo.fit.utils.Accept; import org.apache.olingo.fit.utils.Accept;
import org.apache.olingo.fit.utils.FSManager; import org.apache.olingo.fit.utils.FSManager;
import org.apache.olingo.fit.utils.Commons; import org.apache.olingo.fit.utils.Commons;
import org.apache.olingo.fit.methods.MERGE;
import org.apache.olingo.fit.methods.PATCH;
import org.apache.olingo.fit.serializer.FITAtomDeserializer;
import org.apache.olingo.fit.utils.AbstractJSONUtilities; import org.apache.olingo.fit.utils.AbstractJSONUtilities;
import org.apache.olingo.fit.utils.AbstractUtilities; import org.apache.olingo.fit.utils.AbstractUtilities;
import org.apache.olingo.fit.utils.AbstractXMLUtilities; import org.apache.olingo.fit.utils.AbstractXMLUtilities;
@ -102,6 +114,10 @@ public abstract class AbstractServices {
*/ */
protected static final Logger LOG = LoggerFactory.getLogger(AbstractServices.class); protected static final Logger LOG = LoggerFactory.getLogger(AbstractServices.class);
private Pattern requestPatter = Pattern.compile("(.*) (http://.*) HTTP/.*");
private static final String boundary = "batch_243234_25424_ef_892u748";
protected final ODataServiceVersion version; protected final ODataServiceVersion version;
protected final AbstractXMLUtilities xml; protected final AbstractXMLUtilities xml;
@ -174,6 +190,197 @@ public abstract class AbstractServices {
} }
} }
@POST
@Path("/$batch")
@Consumes("multipart/mixed")
@Produces("application/octet-stream; boundary=" + boundary)
public Response batch(final @Multipart MultipartBody attachment) {
try {
return xml.createBatchResponse(exploreMultipart(attachment.getAllAttachments(), boundary), boundary);
} catch (IOException e) {
return xml.createFaultResponse(Accept.XML.toString(version), e);
}
}
private Response bodyPartRequest(final MimeBodyPart body) throws Exception {
@SuppressWarnings("unchecked")
final Enumeration<Header> en = (Enumeration<Header>) body.getAllHeaders();
Header header = en.nextElement();
final String request = header.getName() + ":" + header.getValue();
final Matcher matcher = requestPatter.matcher(request);
if (matcher.find()) {
final MultivaluedMap<String, String> headers = new MultivaluedHashMap<String, String>();
while (en.hasMoreElements()) {
header = en.nextElement();
headers.putSingle(header.getName(), header.getValue());
}
String method = matcher.group(1);
if ("PATCH".equals(method) || "MERGE".equals(method)) {
headers.putSingle("X-HTTP-METHOD", method);
method = "POST";
}
final String url = matcher.group(2);
final WebClient client = WebClient.create(url);
client.headers(headers);
return client.invoke(method, body.getDataHandler().getInputStream());
} else {
return null;
}
}
public InputStream exploreMultipart(final List<Attachment> attachments, final String boundary) throws IOException {
final ByteArrayOutputStream bos = new ByteArrayOutputStream();
Response res = null;
try {
for (Attachment obj : attachments) {
bos.write(("--" + boundary).getBytes());
bos.write(Constants.CRLF);
final Object content = obj.getDataHandler().getContent();
if (content instanceof MimeMultipart) {
final String cboundary = "changeset_" + UUID.randomUUID().toString();
bos.write(("Content-Type: multipart/mixed;boundary=" + cboundary).getBytes());
bos.write(Constants.CRLF);
bos.write(Constants.CRLF);
final ByteArrayOutputStream chbos = new ByteArrayOutputStream();
String lastContebtID = null;
try {
for (int i = 0; i < ((MimeMultipart) content).getCount(); i++) {
final MimeBodyPart part = (MimeBodyPart) ((MimeMultipart) content).getBodyPart(i);
lastContebtID = part.getContentID();
addChangesetItemIntro(chbos, lastContebtID, cboundary);
res = bodyPartRequest(new MimeBodyPart(part.getInputStream()));
if (res.getStatus() > 400) {
throw new Exception("Failure processing changeset");
}
addSingleBatchResponse(res, lastContebtID, chbos);
}
bos.write(chbos.toByteArray());
IOUtils.closeQuietly(chbos);
bos.write(("--" + cboundary + "--").getBytes());
bos.write(Constants.CRLF);
} catch (Exception e) {
LOG.warn("While processing changeset", e);
IOUtils.closeQuietly(chbos);
addChangesetItemIntro(bos, lastContebtID, cboundary);
if (res == null || res.getStatus() < 400) {
addErrorBatchResponse(e, "1", bos);
} else {
addSingleBatchResponse(res, lastContebtID, bos);
}
bos.write(("--" + cboundary + "--").getBytes());
bos.write(Constants.CRLF);
}
} else {
addItemIntro(bos);
res = bodyPartRequest(new MimeBodyPart(obj.getDataHandler().getInputStream()));
if (res.getStatus() > 400) {
throw new Exception("Failure processing changeset");
}
addSingleBatchResponse(res, bos);
}
}
} catch (Exception e) {
if (res == null || res.getStatus() < 400) {
addErrorBatchResponse(e, bos);
} else {
addSingleBatchResponse(res, bos);
}
}
bos.write(("--" + boundary + "--").getBytes());
return new ByteArrayInputStream(bos.toByteArray());
}
private void addItemIntro(final ByteArrayOutputStream bos) throws IOException {
bos.write("Content-Type: application/http".getBytes());
bos.write(Constants.CRLF);
bos.write("Content-Transfer-Encoding: binary".getBytes());
bos.write(Constants.CRLF);
bos.write(Constants.CRLF);
}
private void addChangesetItemIntro(
final ByteArrayOutputStream bos, final String contentId, final String cboundary) throws IOException {
bos.write(("--" + cboundary).getBytes());
bos.write(Constants.CRLF);
bos.write(("Content-ID: " + contentId).getBytes());
bos.write(Constants.CRLF);
addItemIntro(bos);
}
private void addSingleBatchResponse(
final Response response, final ByteArrayOutputStream bos) throws IOException {
addSingleBatchResponse(response, null, bos);
}
private void addSingleBatchResponse(
final Response response, final String contentId, final ByteArrayOutputStream bos) throws IOException {
bos.write("HTTP/1.1 ".getBytes());
bos.write(String.valueOf(response.getStatusInfo().getStatusCode()).getBytes());
bos.write(" ".getBytes());
bos.write(response.getStatusInfo().getReasonPhrase().getBytes());
bos.write(Constants.CRLF);
for (Map.Entry<String, List<Object>> header : response.getHeaders().entrySet()) {
StringBuilder builder = new StringBuilder();
for (Object value : header.getValue()) {
if (builder.length() > 0) {
builder.append(", ");
}
builder.append(value.toString());
}
builder.insert(0, ": ").insert(0, header.getKey());
bos.write(builder.toString().getBytes());
bos.write(Constants.CRLF);
}
if (StringUtils.isNotBlank(contentId)) {
bos.write(("Content-ID: " + contentId).getBytes());
bos.write(Constants.CRLF);
}
bos.write(Constants.CRLF);
final Object entity = response.getEntity();
if (entity != null) {
bos.write(IOUtils.toByteArray((InputStream) entity));
bos.write(Constants.CRLF);
}
bos.write(Constants.CRLF);
}
private void addErrorBatchResponse(final Exception e, final ByteArrayOutputStream bos)
throws IOException {
addErrorBatchResponse(e, null, bos);
}
private void addErrorBatchResponse(final Exception e, final String contentId, final ByteArrayOutputStream bos)
throws IOException {
addSingleBatchResponse(xml.createFaultResponse(Accept.XML.toString(version), e), contentId, bos);
}
@MERGE @MERGE
@Path("/{entitySetName}({entityId})") @Path("/{entitySetName}({entityId})")
@Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_ATOM_XML, MediaType.APPLICATION_JSON}) @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_ATOM_XML, MediaType.APPLICATION_JSON})
@ -386,7 +593,7 @@ public abstract class AbstractServices {
} else { } else {
final Container<JSONEntryImpl> jcontainer = final Container<JSONEntryImpl> jcontainer =
mapper.readValue(IOUtils.toInputStream(entity), new TypeReference<JSONEntryImpl>() { mapper.readValue(IOUtils.toInputStream(entity), new TypeReference<JSONEntryImpl>() {
}); });
entry = (new DataBinder(version)). entry = (new DataBinder(version)).
getAtomEntry(jcontainer.getObject()); getAtomEntry(jcontainer.getObject());
@ -459,13 +666,13 @@ public abstract class AbstractServices {
replaceAll("\"Salary\":[0-9]*,", "\"Salary\":0,"). replaceAll("\"Salary\":[0-9]*,", "\"Salary\":0,").
replaceAll("\"Title\":\".*\"", "\"Title\":\"[Sacked]\""). replaceAll("\"Title\":\".*\"", "\"Title\":\"[Sacked]\"").
replaceAll("\\<d:Salary m:type=\"Edm.Int32\"\\>.*\\</d:Salary\\>", replaceAll("\\<d:Salary m:type=\"Edm.Int32\"\\>.*\\</d:Salary\\>",
"<d:Salary m:type=\"Edm.Int32\">0</d:Salary>"). "<d:Salary m:type=\"Edm.Int32\">0</d:Salary>").
replaceAll("\\<d:Title\\>.*\\</d:Title\\>", "<d:Title>[Sacked]</d:Title>"); replaceAll("\\<d:Title\\>.*\\</d:Title\\>", "<d:Title>[Sacked]</d:Title>");
final FSManager fsManager = FSManager.instance(version); final FSManager fsManager = FSManager.instance(version);
fsManager.putInMemory(IOUtils.toInputStream(newContent, "UTF-8"), fsManager.putInMemory(IOUtils.toInputStream(newContent, "UTF-8"),
fsManager.getAbsolutePath(Commons.getEntityBasePath("Person", entityId) + Constants.get(version, fsManager.getAbsolutePath(Commons.getEntityBasePath("Person", entityId) + Constants.get(version,
ConstantKey.ENTITY), utils.getKey())); ConstantKey.ENTITY), utils.getKey()));
return utils.getValue().createResponse(null, null, utils.getKey(), Response.Status.NO_CONTENT); return utils.getValue().createResponse(null, null, utils.getKey(), Response.Status.NO_CONTENT);
} catch (Exception e) { } catch (Exception e) {
@ -517,9 +724,9 @@ public abstract class AbstractServices {
final Long newSalary = Long.valueOf(salaryMatcher.group(1)) + n; final Long newSalary = Long.valueOf(salaryMatcher.group(1)) + n;
newContent = newContent. newContent = newContent.
replaceAll("\"Salary\":" + salaryMatcher.group(1) + ",", replaceAll("\"Salary\":" + salaryMatcher.group(1) + ",",
"\"Salary\":" + newSalary + ","). "\"Salary\":" + newSalary + ",").
replaceAll("\\<d:Salary m:type=\"Edm.Int32\"\\>" + salaryMatcher.group(1) + "</d:Salary\\>", replaceAll("\\<d:Salary m:type=\"Edm.Int32\"\\>" + salaryMatcher.group(1) + "</d:Salary\\>",
"<d:Salary m:type=\"Edm.Int32\">" + newSalary + "</d:Salary>"); "<d:Salary m:type=\"Edm.Int32\">" + newSalary + "</d:Salary>");
} }
FSManager.instance(version).putInMemory(IOUtils.toInputStream(newContent, "UTF-8"), FSManager.instance(version).putInMemory(IOUtils.toInputStream(newContent, "UTF-8"),
@ -651,7 +858,7 @@ public abstract class AbstractServices {
mapper.writeValue( mapper.writeValue(
writer, new JsonFeedContainer<JSONFeedImpl>(container.getContextURL(), container.getMetadataETag(), writer, new JsonFeedContainer<JSONFeedImpl>(container.getContextURL(), container.getMetadataETag(),
new DataBinder(version).getJsonFeed(container.getObject()))); new DataBinder(version).getJsonFeed(container.getObject())));
} }
return xml.createResponse(new ByteArrayInputStream(content.toByteArray()), return xml.createResponse(new ByteArrayInputStream(content.toByteArray()),
@ -833,7 +1040,7 @@ public abstract class AbstractServices {
final ObjectMapper mapper = Commons.getJsonMapper(version); final ObjectMapper mapper = Commons.getJsonMapper(version);
mapper.writeValue( mapper.writeValue(
writer, new JsonEntryContainer<JSONEntryImpl>(container.getContextURL(), container.getMetadataETag(), writer, new JsonEntryContainer<JSONEntryImpl>(container.getContextURL(), container.getMetadataETag(),
(new DataBinder(version)).getJsonEntry((AtomEntryImpl) container.getObject()))); (new DataBinder(version)).getJsonEntry((AtomEntryImpl) container.getObject())));
} }
return xml.createResponse(new ByteArrayInputStream(content.toByteArray()), return xml.createResponse(new ByteArrayInputStream(content.toByteArray()),

View File

@ -60,6 +60,21 @@ public abstract class AbstractUtilities {
protected final static Pattern entityUriPattern = Pattern.compile(".*\\/.*\\(.*\\)"); protected final static Pattern entityUriPattern = 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";
public AbstractUtilities(final ODataServiceVersion version) throws Exception { public AbstractUtilities(final ODataServiceVersion version) throws Exception {
this.version = version; this.version = version;
this.fsManager = FSManager.instance(version); this.fsManager = FSManager.instance(version);
@ -399,6 +414,13 @@ public abstract class AbstractUtilities {
return createResponse(entity, etag, accept, null); return createResponse(entity, etag, accept, null);
} }
public Response createBatchResponse(final InputStream stream, final String boundary) {
final Response.ResponseBuilder builder = Response.accepted(stream);
builder.header(Constants.get(version, ConstantKey.ODATA_SERVICE_VERSION), version.toString() + ";");
return builder.build();
}
public Response createResponse( public Response createResponse(
final InputStream entity, final String etag, final Accept accept, final Response.Status status) { final InputStream entity, final String etag, final Accept accept, final Response.Status status) {
final Response.ResponseBuilder builder = Response.ok(); final Response.ResponseBuilder builder = Response.ok();

View File

@ -29,6 +29,11 @@ public class Constants {
private final static Map<ConstantKey, String> constants = new EnumMap<ConstantKey, String>(ConstantKey.class); private final static Map<ConstantKey, String> constants = new EnumMap<ConstantKey, String>(ConstantKey.class);
/**
* CR/LF.
*/
public static final byte[] CRLF = {13, 10};
public static Charset encoding = Charset.forName("UTF-8"); public static Charset encoding = Charset.forName("UTF-8");
static { static {

View File

@ -59,7 +59,7 @@ public enum HeaderName {
* <li>multipart/mixed</li> * <li>multipart/mixed</li>
* </ul> * </ul>
*/ */
contentType("Content-Type", Arrays.asList(ODataServiceVersion.V30)), contentType("Content-Type", Arrays.asList(ODataServiceVersion.V30, ODataServiceVersion.V40)),
/** /**
* This header is a custom HTTP header defined for protocol versioning purposes. This header MAY be present on any * This header is a custom HTTP header defined for protocol versioning purposes. This header MAY be present on any
* request or response message. * request or response message.

View File

@ -19,6 +19,7 @@
package org.apache.olingo.client.api.communication.request.cud; package org.apache.olingo.client.api.communication.request.cud;
import org.apache.olingo.client.api.communication.request.ODataBasicRequest; import org.apache.olingo.client.api.communication.request.ODataBasicRequest;
import org.apache.olingo.client.api.communication.request.ODataBatchableRequest;
import org.apache.olingo.client.api.communication.response.ODataEntityCreateResponse; import org.apache.olingo.client.api.communication.response.ODataEntityCreateResponse;
import org.apache.olingo.commons.api.domain.CommonODataEntity; import org.apache.olingo.commons.api.domain.CommonODataEntity;
import org.apache.olingo.commons.api.format.ODataPubFormat; import org.apache.olingo.commons.api.format.ODataPubFormat;
@ -29,5 +30,5 @@ import org.apache.olingo.commons.api.format.ODataPubFormat;
* @param <E> concrete ODataEntity implementation * @param <E> concrete ODataEntity implementation
*/ */
public interface ODataEntityCreateRequest<E extends CommonODataEntity> public interface ODataEntityCreateRequest<E extends CommonODataEntity>
extends ODataBasicRequest<ODataEntityCreateResponse<E>, ODataPubFormat> { extends ODataBasicRequest<ODataEntityCreateResponse<E>, ODataPubFormat>, ODataBatchableRequest {
} }

View File

@ -19,6 +19,7 @@
package org.apache.olingo.client.api.communication.request.cud; package org.apache.olingo.client.api.communication.request.cud;
import org.apache.olingo.client.api.communication.request.ODataBasicRequest; import org.apache.olingo.client.api.communication.request.ODataBasicRequest;
import org.apache.olingo.client.api.communication.request.ODataBatchableRequest;
import org.apache.olingo.client.api.communication.response.ODataEntityUpdateResponse; import org.apache.olingo.client.api.communication.response.ODataEntityUpdateResponse;
import org.apache.olingo.commons.api.domain.CommonODataEntity; import org.apache.olingo.commons.api.domain.CommonODataEntity;
import org.apache.olingo.commons.api.format.ODataPubFormat; import org.apache.olingo.commons.api.format.ODataPubFormat;
@ -29,5 +30,5 @@ import org.apache.olingo.commons.api.format.ODataPubFormat;
* @param <E> concrete ODataEntity implementation * @param <E> concrete ODataEntity implementation
*/ */
public interface ODataEntityUpdateRequest<E extends CommonODataEntity> public interface ODataEntityUpdateRequest<E extends CommonODataEntity>
extends ODataBasicRequest<ODataEntityUpdateResponse<E>, ODataPubFormat> { extends ODataBasicRequest<ODataEntityUpdateResponse<E>, ODataPubFormat>, ODataBatchableRequest {
} }

View File

@ -19,11 +19,13 @@
package org.apache.olingo.client.api.communication.request.retrieve; package org.apache.olingo.client.api.communication.request.retrieve;
import org.apache.olingo.client.api.communication.request.ODataBasicRequest; import org.apache.olingo.client.api.communication.request.ODataBasicRequest;
import org.apache.olingo.client.api.communication.request.ODataBatchableRequest;
import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse;
import org.apache.olingo.commons.api.format.Format; import org.apache.olingo.commons.api.format.Format;
/** /**
* This is an abstract representation of an OData retrieve query request returning one or more result item. * This is an abstract representation of an OData retrieve query request returning one or more result item.
*/ */
public interface ODataRetrieveRequest<V, T extends Format> extends ODataBasicRequest<ODataRetrieveResponse<V>, T> { public interface ODataRetrieveRequest<V, T extends Format>
extends ODataBasicRequest<ODataRetrieveResponse<V>, T>, ODataBatchableRequest {
} }

View File

@ -151,7 +151,8 @@ public class ODataBatchRequestImpl extends AbstractODataStreamedRequest<ODataBat
/** /**
* Batch request payload management. * Batch request payload management.
*/ */
public class BatchStreamManagerImpl extends AbstractODataStreamManager<ODataBatchResponse> { public class BatchStreamManagerImpl extends AbstractODataStreamManager<ODataBatchResponse>
implements BatchStreamManager {
/** /**
* Batch request current item. * Batch request current item.
@ -178,6 +179,7 @@ public class ODataBatchRequestImpl extends AbstractODataStreamedRequest<ODataBat
* *
* @return ODataChangeset instance. * @return ODataChangeset instance.
*/ */
@Override
public ODataChangeset addChangeset() { public ODataChangeset addChangeset() {
closeCurrentItem(); closeCurrentItem();
@ -197,6 +199,7 @@ public class ODataBatchRequestImpl extends AbstractODataStreamedRequest<ODataBat
* *
* @return ODataRetrieve instance. * @return ODataRetrieve instance.
*/ */
@Override
public ODataRetrieve addRetrieve() { public ODataRetrieve addRetrieve() {
closeCurrentItem(); closeCurrentItem();

View File

@ -148,8 +148,7 @@ public class ODataBatchUtilities {
} }
} else { } else {
for (int i = 0; for (int i = 0; controller.isValidBatch() && controller.getBatchLineIterator().hasNext() && i < count; i++) {
controller.isValidBatch() && controller.getBatchLineIterator().hasNext() && i < count; i++) {
currentLine = controller.getBatchLineIterator().nextLine(); currentLine = controller.getBatchLineIterator().nextLine();
} }
} }

View File

@ -25,7 +25,6 @@ import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient; import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost; import org.apache.http.client.methods.HttpPost;
import org.apache.olingo.client.api.CommonODataClient; import org.apache.olingo.client.api.CommonODataClient;
import org.apache.olingo.client.api.communication.request.ODataBatchableRequest;
import org.apache.olingo.client.api.communication.request.cud.ODataEntityCreateRequest; import org.apache.olingo.client.api.communication.request.cud.ODataEntityCreateRequest;
import org.apache.olingo.client.api.communication.response.ODataEntityCreateResponse; import org.apache.olingo.client.api.communication.response.ODataEntityCreateResponse;
import org.apache.olingo.commons.api.domain.CommonODataEntity; import org.apache.olingo.commons.api.domain.CommonODataEntity;
@ -44,7 +43,7 @@ import org.apache.olingo.commons.api.data.Entry;
*/ */
public class ODataEntityCreateRequestImpl<E extends CommonODataEntity> public class ODataEntityCreateRequestImpl<E extends CommonODataEntity>
extends AbstractODataBasicRequest<ODataEntityCreateResponse<E>, ODataPubFormat> extends AbstractODataBasicRequest<ODataEntityCreateResponse<E>, ODataPubFormat>
implements ODataEntityCreateRequest<E>, ODataBatchableRequest { implements ODataEntityCreateRequest<E> {
/** /**
* Entity to be created. * Entity to be created.

View File

@ -25,7 +25,6 @@ import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient; import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpEntityEnclosingRequestBase; import org.apache.http.client.methods.HttpEntityEnclosingRequestBase;
import org.apache.olingo.client.api.CommonODataClient; import org.apache.olingo.client.api.CommonODataClient;
import org.apache.olingo.client.api.communication.request.ODataBatchableRequest;
import org.apache.olingo.client.api.communication.request.cud.ODataEntityUpdateRequest; import org.apache.olingo.client.api.communication.request.cud.ODataEntityUpdateRequest;
import org.apache.olingo.client.api.communication.response.ODataEntityUpdateResponse; import org.apache.olingo.client.api.communication.response.ODataEntityUpdateResponse;
import org.apache.olingo.commons.api.domain.CommonODataEntity; import org.apache.olingo.commons.api.domain.CommonODataEntity;
@ -39,11 +38,12 @@ import org.apache.olingo.commons.api.data.Entry;
/** /**
* This class implements an OData update request. * This class implements an OData update request.
*
* @param <E> concrete ODataEntity implementation * @param <E> concrete ODataEntity implementation
*/ */
public class ODataEntityUpdateRequestImpl<E extends CommonODataEntity> public class ODataEntityUpdateRequestImpl<E extends CommonODataEntity>
extends AbstractODataBasicRequest<ODataEntityUpdateResponse<E>, ODataPubFormat> extends AbstractODataBasicRequest<ODataEntityUpdateResponse<E>, ODataPubFormat>
implements ODataEntityUpdateRequest<E>, ODataBatchableRequest { implements ODataEntityUpdateRequest<E> {
/** /**
* Changes to be applied. * Changes to be applied.

View File

@ -23,7 +23,6 @@ import java.net.URI;
import org.apache.http.HttpResponse; import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient; import org.apache.http.client.HttpClient;
import org.apache.olingo.client.api.CommonODataClient; import org.apache.olingo.client.api.CommonODataClient;
import org.apache.olingo.client.api.communication.request.ODataBatchableRequest;
import org.apache.olingo.client.api.communication.request.retrieve.ODataRetrieveRequest; import org.apache.olingo.client.api.communication.request.retrieve.ODataRetrieveRequest;
import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse;
import org.apache.olingo.commons.api.format.Format; import org.apache.olingo.commons.api.format.Format;
@ -36,7 +35,7 @@ import org.apache.olingo.client.core.communication.response.AbstractODataRespons
*/ */
public abstract class AbstractODataRetrieveRequest<V, T extends Format> public abstract class AbstractODataRetrieveRequest<V, T extends Format>
extends AbstractODataBasicRequest<ODataRetrieveResponse<V>, T> extends AbstractODataBasicRequest<ODataRetrieveResponse<V>, T>
implements ODataRetrieveRequest<V, T>, ODataBatchableRequest { implements ODataRetrieveRequest<V, T> {
/** /**
* Private constructor. * Private constructor.

View File

@ -18,389 +18,429 @@
*/ */
package org.apache.olingo.client.core.it.v3; package org.apache.olingo.client.core.it.v3;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.fail;
import java.io.IOException;
import java.net.URI;
import java.util.Iterator;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import org.apache.http.HttpResponse;
import org.apache.olingo.client.api.ODataBatchConstants;
import org.apache.olingo.client.api.communication.request.ODataStreamManager;
import org.apache.olingo.client.api.communication.request.batch.BatchStreamManager;
import org.apache.olingo.client.api.communication.request.batch.ODataBatchRequest;
import org.apache.olingo.client.api.communication.request.batch.ODataBatchResponseItem;
import org.apache.olingo.client.api.communication.request.batch.ODataChangeset;
import org.apache.olingo.client.api.communication.request.batch.ODataRetrieve;
import org.apache.olingo.client.api.communication.request.cud.ODataEntityCreateRequest;
import org.apache.olingo.client.api.communication.request.cud.ODataEntityUpdateRequest;
import org.apache.olingo.client.api.communication.request.cud.v3.UpdateType;
import org.apache.olingo.client.api.communication.request.retrieve.ODataEntityRequest;
import org.apache.olingo.client.api.communication.response.ODataBatchResponse;
import org.apache.olingo.client.api.communication.response.ODataEntityCreateResponse;
import org.apache.olingo.client.api.communication.response.ODataEntityUpdateResponse;
import org.apache.olingo.client.api.communication.response.ODataResponse;
import org.apache.olingo.client.api.uri.v3.URIBuilder;
import org.apache.olingo.client.core.communication.request.AbstractODataStreamManager;
import org.apache.olingo.client.core.communication.request.Wrapper;
import org.apache.olingo.client.core.communication.request.batch.ODataChangesetResponseItem;
import org.apache.olingo.client.core.communication.request.batch.ODataRetrieveResponseItem;
import org.apache.olingo.client.core.communication.request.retrieve.ODataEntityRequestImpl;
import org.apache.olingo.client.core.communication.request.retrieve.ODataEntityRequestImpl.ODataEntityResponseImpl;
import org.apache.olingo.client.core.uri.URIUtils;
import org.apache.olingo.commons.api.domain.v3.ODataEntity;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
import org.apache.olingo.commons.api.format.ODataPubFormat;
import org.junit.Ignore;
import org.junit.Test;
public class BatchTestITCase extends AbstractTestITCase { public class BatchTestITCase extends AbstractTestITCase {
// private static String PREFIX = "!!PREFIX!!"; private static String PREFIX = "!!PREFIX!!";
//
// private static String SUFFIX = "!!SUFFIX!!"; private static String SUFFIX = "!!SUFFIX!!";
//
// private static int MAX = 10000; private static int MAX = 10000;
//
// @Test @Test
// @Ignore public void stringStreaming() {
// public void stringStreaming() { final TestStreamManager streaming = new TestStreamManager();
// final TestStreamManager streaming = new TestStreamManager();
// new StreamingThread(streaming).start();
// new StreamingThread(streaming).start();
// streaming.addObject((PREFIX + "\n").getBytes());
// streaming.addObject((PREFIX + "\n").getBytes());
// for (int i = 0; i <= MAX; i++) {
// for (int i = 0; i <= MAX; i++) { streaming.addObject((i + ") send info\n").getBytes());
// streaming.addObject((i + ") send info\n").getBytes()); }
// }
// streaming.addObject((SUFFIX).getBytes());
// streaming.addObject((SUFFIX).getBytes()); streaming.finalizeBody();
// streaming.finalizeBody(); }
// }
// @Test
// @Test public void emptyBatchRequest() {
// @Ignore // create your request
// public void emptyBatchRequest() { final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL);
// // create your request
// final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL); final BatchStreamManager payload = request.execute();
// final ODataBatchResponse response = payload.getResponse();
// final BatchStreamManager payload = request.execute();
// final ODataBatchResponse response = payload.getResponse(); assertEquals(202, response.getStatusCode());
// assertEquals("Accepted", response.getStatusMessage());
// assertEquals(202, response.getStatusCode());
// assertEquals("Accepted", response.getStatusMessage()); final Iterator<ODataBatchResponseItem> iter = response.getBody();
// assertFalse(iter.hasNext());
// final Iterator<ODataBatchResponseItem> iter = response.getBody(); }
// assertFalse(iter.hasNext());
// } @Test
// public void changesetWithError() {
// @Test // create your request
// @Ignore final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL);
// public void changesetWithError() {
// // create your request final BatchStreamManager payload = request.execute();
// final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL); final ODataChangeset changeset = payload.addChangeset();
//
// final BatchStreamManager payload = request.execute(); URIBuilder targetURI;
// final ODataChangeset changeset = payload.addChangeset(); ODataEntityCreateRequest<ODataEntity> createReq;
//
// URIBuilder<?> targetURI; targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customer");
// ODataEntityCreateRequest createReq; for (int i = 1; i <= 2; i++) {
// // Create Customer into the changeset
// targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customer"); createReq = client.getCUDRequestFactory().getEntityCreateRequest(
// for (int i = 1; i <= 2; i++) { targetURI.build(),
// // Create Customer into the changeset getSampleCustomerProfile(100 + i, "Sample customer", false));
// createReq = client.getCUDRequestFactory().getEntityCreateRequest( createReq.setFormat(ODataPubFormat.JSON);
// targetURI.build(), changeset.addRequest(createReq);
// getSampleCustomerProfile(100 + i, "Sample customer", false)); }
// createReq.setFormat(ODataPubFormat.JSON);
// changeset.addRequest(createReq); targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("WrongEntitySet");
// } createReq = client.getCUDRequestFactory().getEntityCreateRequest(
// targetURI.build(),
// targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("WrongEntitySet"); getSampleCustomerProfile(105, "Sample customer", false));
// createReq = client.getCUDRequestFactory().getEntityCreateRequest( createReq.setFormat(ODataPubFormat.JSON);
// targetURI.build(), changeset.addRequest(createReq);
// getSampleCustomerProfile(105, "Sample customer", false));
// createReq.setFormat(ODataPubFormat.JSON); targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customer");
// changeset.addRequest(createReq); for (int i = 3; i <= 4; i++) {
// // Create Customer into the changeset
// targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customer"); createReq = client.getCUDRequestFactory().getEntityCreateRequest(
// for (int i = 3; i <= 4; i++) { targetURI.build(),
// // Create Customer into the changeset getSampleCustomerProfile(100 + i, "Sample customer", false));
// createReq = client.getCUDRequestFactory().getEntityCreateRequest( createReq.setFormat(ODataPubFormat.ATOM);
// targetURI.build(), changeset.addRequest(createReq);
// getSampleCustomerProfile(100 + i, "Sample customer", false)); }
// createReq.setFormat(ODataPubFormat.ATOM);
// changeset.addRequest(createReq); final ODataBatchResponse response = payload.getResponse();
// } assertEquals(202, response.getStatusCode());
// assertEquals("Accepted", response.getStatusMessage());
// final ODataBatchResponse response = payload.getResponse();
// assertEquals(202, response.getStatusCode()); final Iterator<ODataBatchResponseItem> iter = response.getBody();
// assertEquals("Accepted", response.getStatusMessage()); final ODataChangesetResponseItem chgResponseItem = (ODataChangesetResponseItem) iter.next();
//
// final Iterator<ODataBatchResponseItem> iter = response.getBody(); final ODataResponse res = chgResponseItem.next();
// final ODataChangesetResponseItem chgResponseItem = (ODataChangesetResponseItem) iter.next(); assertEquals(404, res.getStatusCode());
// assertEquals("Not Found", res.getStatusMessage());
// final ODataResponse res = chgResponseItem.next(); assertEquals(Integer.valueOf(3), Integer.valueOf(
// assertEquals(404, res.getStatusCode()); res.getHeader(ODataBatchConstants.CHANGESET_CONTENT_ID_NAME).iterator().next()));
// assertEquals("Not Found", res.getStatusMessage()); assertFalse(chgResponseItem.hasNext());
// assertEquals(Integer.valueOf(3), Integer.valueOf( }
// res.getHeader(ODataBatchConstants.CHANGESET_CONTENT_ID_NAME).iterator().next()));
// assertFalse(chgResponseItem.hasNext()); @Test
// } @Ignore
// @SuppressWarnings("unchecked")
// @Test public void changesetWithReference() throws EdmPrimitiveTypeException {
// @Ignore // create your request
// public void changesetWithReference() { final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL);
// // create your request final BatchStreamManager streamManager = request.execute();
// final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL);
// final BatchStreamManager streamManager = request.execute(); final ODataChangeset changeset = streamManager.addChangeset();
// ODataEntity customer = getSampleCustomerProfile(20, "sample customer", false);
// final ODataChangeset changeset = streamManager.addChangeset();
// ODataEntity customer = getSampleCustomerProfile(20, "sample customer", false); URIBuilder uriBuilder = client.getURIBuilder(testAuthServiceRootURL).appendEntitySetSegment("Customer");
//
// URIBuilder<?> uriBuilder = client.getURIBuilder(testAuthServiceRootURL).appendEntitySetSegment("Customer"); // add create request
// final ODataEntityCreateRequest<ODataEntity> createReq =
// // add create request client.getCUDRequestFactory().getEntityCreateRequest(uriBuilder.build(), customer);
// final ODataEntityCreateRequest createReq =
// client.getCUDRequestFactory().getEntityCreateRequest(uriBuilder.build(), customer); changeset.addRequest(createReq);
//
// changeset.addRequest(createReq); // retrieve request reference
// int createRequestRef = changeset.getLastContentId();
// // retrieve request reference
// int createRequestRef = changeset.getLastContentId(); // add update request: link CustomerInfo(17) to the new customer
// final ODataEntity customerChanges = client.getObjectFactory().newEntity(customer.getTypeName());
// // add update request: link CustomerInfo(17) to the new customer customerChanges.addLink(client.getObjectFactory().newEntityNavigationLink(
// final ODataEntity customerChanges = client.getObjectFactory().newEntity(customer.getName()); "Info",
// customerChanges.addLink(client.getObjectFactory().newEntityNavigationLink( client.getURIBuilder(testAuthServiceRootURL).appendEntitySetSegment("CustomerInfo").
// "Info", appendKeySegment(17).build()));
// client.getURIBuilder(testAuthServiceRootURL).appendEntitySetSegment("CustomerInfo").
// appendKeySegment(17).build())); final ODataEntityUpdateRequest updateReq = client.getCUDRequestFactory().getEntityUpdateRequest(
// URI.create("$" + createRequestRef), UpdateType.PATCH, customerChanges);
// final ODataEntityUpdateRequest updateReq = client.getCUDRequestFactory().getEntityUpdateRequest(
// URI.create("$" + createRequestRef), UpdateType.PATCH, customerChanges); changeset.addRequest(updateReq);
//
// changeset.addRequest(updateReq); final ODataBatchResponse response = streamManager.getResponse();
// assertEquals(202, response.getStatusCode());
// final ODataBatchResponse response = streamManager.getResponse(); assertEquals("Accepted", response.getStatusMessage());
// assertEquals(202, response.getStatusCode());
// assertEquals("Accepted", response.getStatusMessage()); // verify response payload ...
// final Iterator<ODataBatchResponseItem> iter = response.getBody();
// // verify response payload ...
// final Iterator<ODataBatchResponseItem> iter = response.getBody(); final ODataBatchResponseItem item = iter.next();
// assertTrue(item instanceof ODataChangesetResponseItem);
// final ODataBatchResponseItem item = iter.next();
// assertTrue(item instanceof ODataChangesetResponseItem); final ODataChangesetResponseItem chgitem = (ODataChangesetResponseItem) item;
//
// final ODataChangesetResponseItem chgitem = (ODataChangesetResponseItem) item; ODataResponse res = chgitem.next();
// assertEquals(201, res.getStatusCode());
// ODataResponse res = chgitem.next(); assertTrue(res instanceof ODataEntityCreateResponse);
// assertEquals(201, res.getStatusCode());
// assertTrue(res instanceof ODataEntityCreateResponse); customer = ((ODataEntityCreateResponse<ODataEntity>) res).getBody();
//
// customer = ((ODataEntityCreateResponse) res).getBody(); ODataEntityRequest<ODataEntity> req = client.getRetrieveRequestFactory().getEntityRequest(
// URIUtils.getURI(testStaticServiceRootURL, customer.getEditLink().toASCIIString() + "/Info"));
// ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(
// URIUtils.getURI(testStaticServiceRootURL, customer.getEditLink().toASCIIString() + "/Info")); assertEquals(Integer.valueOf(17),
// req.execute().getBody().getProperty("CustomerInfoId").getPrimitiveValue().toCastValue(Integer.class));
// assertEquals(Integer.valueOf(17),
// req.execute().getBody().getProperty("CustomerInfoId").getPrimitiveValue().<Integer>toCastValue()); res = chgitem.next();
// assertEquals(204, res.getStatusCode());
// res = chgitem.next(); assertTrue(res instanceof ODataEntityUpdateResponse);
// assertEquals(204, res.getStatusCode());
// assertTrue(res instanceof ODataEntityUpdateResponse); // clean ...
// assertEquals(204, client.getCUDRequestFactory().getDeleteRequest(
// // clean ... URIUtils.getURI(testStaticServiceRootURL, customer.getEditLink().toASCIIString())).execute().
// assertEquals(204, client.getCUDRequestFactory().getDeleteRequest( getStatusCode());
// URIUtils.getURI(testStaticServiceRootURL, customer.getEditLink().toASCIIString())).execute().
// getStatusCode()); try {
// client.getRetrieveRequestFactory().getEntityRequest(
// try { URIUtils.getURI(testStaticServiceRootURL, customer.getEditLink().toASCIIString())).
// client.getRetrieveRequestFactory().getEntityRequest( execute().getBody();
// URIUtils.getURI(testStaticServiceRootURL, customer.getEditLink().toASCIIString())). fail();
// execute().getBody(); } catch (Exception e) {
// fail(); // ignore
// } catch (Exception e) { }
// // ignore }
// }
// } @Test
// @SuppressWarnings("unchecked")
// @Test public void batchRequest() throws EdmPrimitiveTypeException {
// @Ignore // create your request
// public void batchRequest() { final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL);
// // create your request
// final ODataBatchRequest request = client.getBatchRequestFactory().getBatchRequest(testStaticServiceRootURL); final BatchStreamManager streamManager = request.execute();
//
// final BatchStreamManager streamManager = request.execute(); // -------------------------------------------
// // Add retrieve item
// // ------------------------------------------- // -------------------------------------------
// // Add retrieve item ODataRetrieve retrieve = streamManager.addRetrieve();
// // -------------------------------------------
// ODataRetrieve retrieve = streamManager.addRetrieve(); // prepare URI
// URIBuilder targetURI = client.getURIBuilder(testStaticServiceRootURL);
// // prepare URI targetURI.appendEntitySetSegment("Customer").appendKeySegment(-10).
// URIBuilder<?> targetURI = client.getURIBuilder(testStaticServiceRootURL); expand("Logins").select("CustomerId,Logins/Username");
// targetURI.appendEntitySetSegment("Customer").appendKeySegment(-10).
// expand("Logins").select("CustomerId,Logins/Username"); // create new request
// ODataEntityRequest<ODataEntity> queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build());
// // create new request queryReq.setFormat(ODataPubFormat.ATOM);
// ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build());
// queryReq.setFormat(ODataPubFormat.ATOM); retrieve.setRequest(queryReq);
// // -------------------------------------------
// retrieve.setRequest(queryReq);
// // ------------------------------------------- // -------------------------------------------
// // Add changeset item
// // ------------------------------------------- // -------------------------------------------
// // Add changeset item final ODataChangeset changeset = streamManager.addChangeset();
// // -------------------------------------------
// final ODataChangeset changeset = streamManager.addChangeset(); // Update Product into the changeset
// targetURI = client.getURIBuilder(testStaticServiceRootURL).
// // Update Product into the changeset appendEntitySetSegment("Product").appendKeySegment(-10);
// targetURI = client.getURIBuilder(testStaticServiceRootURL). final URI editLink = targetURI.build();
// appendEntitySetSegment("Product").appendKeySegment(-10);
// final URI editLink = targetURI.build(); final ODataEntity merge = client.getObjectFactory().newEntity(TEST_PRODUCT_TYPE);
// merge.setEditLink(editLink);
// final ODataEntity merge = client.getObjectFactory().newEntity(TEST_PRODUCT_TYPE);
// merge.setEditLink(editLink); merge.getProperties().add(client.getObjectFactory().newPrimitiveProperty(
// "Description",
// merge.getProperties().add(client.getObjectFactory().newPrimitiveProperty( client.getObjectFactory().newPrimitiveValueBuilder().buildString("new description from batch")));
// "Description", client.getPrimitiveValueBuilder().setText("new description from batch").build()));
// final ODataEntityUpdateRequest changeReq =
// final ODataEntityUpdateRequest changeReq = client.getCUDRequestFactory().getEntityUpdateRequest(UpdateType.MERGE, merge);
// client.getCUDRequestFactory().getEntityUpdateRequest(UpdateType.MERGE, merge); changeReq.setFormat(ODataPubFormat.JSON_FULL_METADATA);
// changeReq.setFormat(ODataPubFormat.JSON_FULL_METADATA); changeReq.setIfMatch(getETag(editLink));
// changeReq.setIfMatch(getETag(editLink));
// changeset.addRequest(changeReq);
// changeset.addRequest(changeReq);
// // Create Customer into the changeset
// // Create Customer into the changeset targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customer");
// targetURI = client.getURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customer"); final ODataEntity original = getSampleCustomerProfile(1000, "Sample customer", false);
// final ODataEntity original = getSampleCustomerProfile(1000, "Sample customer", false); final ODataEntityCreateRequest<ODataEntity> createReq =
// final ODataEntityCreateRequest createReq = client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), original);
// client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), original); createReq.setFormat(ODataPubFormat.ATOM);
// createReq.setFormat(ODataPubFormat.ATOM); changeset.addRequest(createReq);
// changeset.addRequest(createReq); // -------------------------------------------
// // -------------------------------------------
// // -------------------------------------------
// // ------------------------------------------- // Add retrieve item
// // Add retrieve item // -------------------------------------------
// // ------------------------------------------- retrieve = streamManager.addRetrieve();
// retrieve = streamManager.addRetrieve();
// // prepare URI
// // prepare URI targetURI = client.getURIBuilder(testStaticServiceRootURL).
// targetURI = client.getURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Product").appendKeySegment(-10);
// appendEntitySetSegment("Product").appendKeySegment(-10);
// // create new request
// // create new request queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build());
// queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build());
// retrieve.setRequest(queryReq);
// retrieve.setRequest(queryReq); // -------------------------------------------
// // -------------------------------------------
// final ODataBatchResponse response = streamManager.getResponse();
// final ODataBatchResponse response = streamManager.getResponse(); assertEquals(202, response.getStatusCode());
// assertEquals(202, response.getStatusCode()); assertEquals("Accepted", response.getStatusMessage());
// assertEquals("Accepted", response.getStatusMessage()); final Iterator<ODataBatchResponseItem> iter = response.getBody();
//
// final Iterator<ODataBatchResponseItem> iter = response.getBody(); // retrive the first item (ODataRetrieve)
// ODataBatchResponseItem item = iter.next();
// // retrive the first item (ODataRetrieve) assertTrue(item instanceof ODataRetrieveResponseItem);
// ODataBatchResponseItem item = iter.next();
// assertTrue(item instanceof ODataRetrieveResponseItem); ODataRetrieveResponseItem retitem = (ODataRetrieveResponseItem) item;
// ODataResponse res = retitem.next();
// ODataRetrieveResponseItem retitem = (ODataRetrieveResponseItem) item; assertTrue(res instanceof ODataEntityResponseImpl);
// ODataResponse res = retitem.next(); assertEquals(200, res.getStatusCode());
// assertTrue(res instanceof ODataEntityResponseImpl); assertEquals("OK", res.getStatusMessage());
// assertEquals(200, res.getStatusCode());
// assertEquals("OK", res.getStatusMessage()); ODataEntityRequestImpl<ODataEntity>.ODataEntityResponseImpl entres =
// (ODataEntityRequestImpl<ODataEntity>.ODataEntityResponseImpl) res;
// ODataEntityResponseImpl entres = (ODataEntityResponseImpl) res;
// ODataEntity entity = entres.getBody(); ODataEntity entity = entres.getBody();
// assertEquals(new Integer(-10), entity.getProperty("CustomerId").getPrimitiveValue().<Integer>toCastValue()); assertEquals(new Integer(-10), entity.getProperty("CustomerId").getPrimitiveValue().toCastValue(Integer.class));
//
// // retrieve the second item (ODataChangeset) // retrieve the second item (ODataChangeset)
// item = iter.next(); item = iter.next();
// assertTrue(item instanceof ODataChangesetResponseItem); assertTrue(item instanceof ODataChangesetResponseItem);
//
// final ODataChangesetResponseItem chgitem = (ODataChangesetResponseItem) item; final ODataChangesetResponseItem chgitem = (ODataChangesetResponseItem) item;
// res = chgitem.next(); res = chgitem.next();
// assertTrue(res instanceof ODataEntityUpdateResponse); assertTrue(res instanceof ODataEntityUpdateResponse);
// assertEquals(204, res.getStatusCode()); assertEquals(204, res.getStatusCode());
// assertEquals("No Content", res.getStatusMessage()); assertEquals("No Content", res.getStatusMessage());
//
// res = chgitem.next(); res = chgitem.next();
// assertTrue(res instanceof ODataEntityCreateResponse); assertTrue(res instanceof ODataEntityCreateResponse);
// assertEquals(201, res.getStatusCode()); assertEquals(201, res.getStatusCode());
// assertEquals("Created", res.getStatusMessage()); assertEquals("Created", res.getStatusMessage());
//
// final ODataEntityCreateResponse createres = (ODataEntityCreateResponse) res; final ODataEntityCreateResponse<ODataEntity> createres = (ODataEntityCreateResponse<ODataEntity>) res;
// entity = createres.getBody(); entity = createres.getBody();
// assertEquals(new Integer(1000), entity.getProperty("CustomerId").getPrimitiveValue().<Integer>toCastValue()); assertEquals(new Integer(1000), entity.getProperty("CustomerId").getPrimitiveValue().toCastValue(Integer.class));
//
// // retrive the third item (ODataRetrieve) // retrive the third item (ODataRetrieve)
// item = iter.next(); item = iter.next();
// assertTrue(item instanceof ODataRetrieveResponseItem); assertTrue(item instanceof ODataRetrieveResponseItem);
//
// retitem = (ODataRetrieveResponseItem) item; retitem = (ODataRetrieveResponseItem) item;
// res = retitem.next(); res = retitem.next();
// assertTrue(res instanceof ODataEntityResponseImpl); assertTrue(res instanceof ODataEntityResponseImpl);
// assertEquals(200, res.getStatusCode()); assertEquals(200, res.getStatusCode());
// assertEquals("OK", res.getStatusMessage()); assertEquals("OK", res.getStatusMessage());
//
// entres = (ODataEntityResponseImpl) res; entres = (ODataEntityRequestImpl<ODataEntity>.ODataEntityResponseImpl) res;
// entity = entres.getBody(); entity = entres.getBody();
// assertEquals("new description from batch", assertEquals("new description from batch",
// entity.getProperty("Description").getPrimitiveValue().<String>toCastValue()); entity.getProperty("Description").getPrimitiveValue().toCastValue(String.class));
//
// assertFalse(iter.hasNext()); assertFalse(iter.hasNext());
// } }
//
// private static class TestStreamManager extends AbstractODataStreamManager<ODataBatchResponse> { private static class TestStreamManager extends AbstractODataStreamManager<ODataBatchResponse> {
//
// public TestStreamManager() { public TestStreamManager() {
// super(new Wrapper<Future<HttpResponse>>()); super(new Wrapper<Future<HttpResponse>>());
// } }
//
// public ODataStreamManager<ODataBatchResponse> addObject(byte[] src) { public ODataStreamManager<ODataBatchResponse> addObject(byte[] src) {
// stream(src); stream(src);
// return this; return this;
// } }
//
// @Override @Override
// protected ODataBatchResponse getResponse(long timeout, TimeUnit unit) { protected ODataBatchResponse getResponse(long timeout, TimeUnit unit) {
// throw new UnsupportedOperationException("Not supported yet."); throw new UnsupportedOperationException("Not supported yet.");
// } }
// }; };
//
// /** /**
// * To be used for debug purposes. * To be used for debug purposes.
// */ */
// private static class StreamingThread extends Thread { private static class StreamingThread extends Thread {
//
// private final TestStreamManager streaming; private final TestStreamManager streaming;
//
// public StreamingThread(final TestStreamManager streaming) { public StreamingThread(final TestStreamManager streaming) {
// this.streaming = streaming; this.streaming = streaming;
// } }
//
// @Override @Override
// public void run() { public void run() {
// try { try {
// final StringBuilder builder = new StringBuilder(); final StringBuilder builder = new StringBuilder();
//
// byte[] buff = new byte[1024]; byte[] buff = new byte[1024];
//
// int len; int len;
//
// while ((len = streaming.getBody().read(buff)) >= 0) { while ((len = streaming.getBody().read(buff)) >= 0) {
// builder.append(new String(buff, 0, len)); builder.append(new String(buff, 0, len));
// } }
//
// assertTrue(builder.toString().startsWith(PREFIX)); assertTrue(builder.toString().startsWith(PREFIX));
// assertTrue(builder.toString().contains((MAX / 2) + ") send info")); assertTrue(builder.toString().contains((MAX / 2) + ") send info"));
// assertTrue(builder.toString().contains((MAX / 3) + ") send info")); assertTrue(builder.toString().contains((MAX / 3) + ") send info"));
// assertTrue(builder.toString().contains((MAX / 20) + ") send info")); assertTrue(builder.toString().contains((MAX / 20) + ") send info"));
// assertTrue(builder.toString().contains((MAX / 30) + ") send info")); assertTrue(builder.toString().contains((MAX / 30) + ") send info"));
// assertTrue(builder.toString().contains(MAX + ") send info")); assertTrue(builder.toString().contains(MAX + ") send info"));
// assertTrue(builder.toString().endsWith(SUFFIX)); assertTrue(builder.toString().endsWith(SUFFIX));
//
// } catch (IOException e) { } catch (IOException e) {
// fail(); fail();
// } }
// } }
// } }
//
// private static class BatchStreamingThread extends Thread { private static class BatchStreamingThread extends Thread {
//
// private final BatchStreamManager streaming; private final BatchStreamManager streaming;
//
// public BatchStreamingThread(final BatchStreamManager streaming) { public BatchStreamingThread(final BatchStreamManager streaming) {
// this.streaming = streaming; this.streaming = streaming;
// } }
//
// @Override @Override
// public void run() { public void run() {
// try { try {
// final StringBuilder builder = new StringBuilder(); final StringBuilder builder = new StringBuilder();
//
// byte[] buff = new byte[1024]; byte[] buff = new byte[1024];
//
// int len; int len;
//
// while ((len = streaming.getBody().read(buff)) >= 0) { while ((len = streaming.getBody().read(buff)) >= 0) {
// builder.append(new String(buff, 0, len)); builder.append(new String(buff, 0, len));
// } }
//
// LOG.debug("Batch request {}", builder.toString()); LOG.debug("Batch request {}", builder.toString());
//
// assertTrue(builder.toString().contains("Content-Id:2")); assertTrue(builder.toString().contains("Content-Id:2"));
// assertTrue(builder.toString().contains("GET " + servicesODataServiceRootURL)); assertTrue(builder.toString().contains("GET " + testStaticServiceRootURL));
// } catch (IOException e) { } catch (IOException e) {
// fail(); fail();
// } }
// } }
// } }
} }