diff --git a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/AbstractService.java b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/AbstractService.java index f8506c22a..0fd8c46e6 100644 --- a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/AbstractService.java +++ b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/AbstractService.java @@ -34,7 +34,7 @@ import org.apache.olingo.client.core.edm.ClientCsdlEdmProvider; import org.apache.olingo.commons.api.ODataRuntimeException; import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmProviderImpl; import org.apache.olingo.ext.proxy.api.AbstractTerm; import org.apache.olingo.ext.proxy.api.PersistenceManager; @@ -96,7 +96,7 @@ public abstract class AbstractService { } this.client = ODataClientFactory.getEdmEnabledClient(serviceRoot, edm, metadataETag); - this.client.getConfiguration().setDefaultPubFormat(ODataFormat.JSON_FULL_METADATA); + this.client.getConfiguration().setDefaultPubFormat(ContentType.JSON_FULL_METADATA); this.transactional = transactional; this.context = new Context(); } diff --git a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityContainerInvocationHandler.java b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityContainerInvocationHandler.java index b31e624c0..f3f1b4d7b 100644 --- a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityContainerInvocationHandler.java +++ b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityContainerInvocationHandler.java @@ -24,6 +24,7 @@ import java.lang.annotation.Annotation; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.net.URI; + import org.apache.commons.lang3.ArrayUtils; import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.commons.api.edm.FullQualifiedName; diff --git a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityInvocationHandler.java b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityInvocationHandler.java index 66bc66c97..c124402d3 100644 --- a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityInvocationHandler.java +++ b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntityInvocationHandler.java @@ -33,12 +33,12 @@ import org.apache.commons.lang3.StringUtils; import org.apache.olingo.client.api.communication.request.retrieve.ODataEntityRequest; import org.apache.olingo.client.api.communication.request.retrieve.ODataMediaRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; -import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.client.api.domain.ClientAnnotation; import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientProperty; +import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.ext.proxy.AbstractService; import org.apache.olingo.ext.proxy.api.AbstractTerm; import org.apache.olingo.ext.proxy.api.Annotatable; @@ -335,7 +335,7 @@ public class EntityInvocationHandler extends AbstractStructuredInvocationHandler getClient().getRetrieveRequestFactory().getMediaEntityRequest(contentSource); if (StringUtils.isNotBlank(getEntity().getMediaContentType())) { - retrieveReq.setFormat(ODataFormat.fromString(getEntity().getMediaContentType())); + retrieveReq.setFormat(ContentType.parse(getEntity().getMediaContentType())); } final ODataRetrieveResponse res = retrieveReq.execute(); diff --git a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntitySetInvocationHandler.java b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntitySetInvocationHandler.java index 6c8d35f89..8250f7224 100644 --- a/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntitySetInvocationHandler.java +++ b/ext/client-proxy/src/main/java/org/apache/olingo/ext/proxy/commons/EntitySetInvocationHandler.java @@ -29,11 +29,11 @@ import java.util.concurrent.Future; import org.apache.commons.lang3.tuple.Triple; import org.apache.olingo.client.api.communication.request.retrieve.ODataValueRequest; -import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.client.api.domain.ClientAnnotation; import org.apache.olingo.client.api.domain.ClientEntity; +import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.ext.proxy.AbstractService; import org.apache.olingo.ext.proxy.api.AbstractEntitySet; import org.apache.olingo.ext.proxy.api.AbstractSingleton; @@ -95,7 +95,7 @@ public class EntitySetInvocationHandler< public Long count() { final ODataValueRequest req = getClient().getRetrieveRequestFactory(). getValueRequest(getClient().newURIBuilder(this.uri.build().toASCIIString()).count().build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); return Long.valueOf(req.execute().getBody().asPrimitive().toString()); } diff --git a/ext/pojogen-maven-plugin/src/main/java/org/apache/olingo/ext/pojogen/AbstractPOJOGenMojo.java b/ext/pojogen-maven-plugin/src/main/java/org/apache/olingo/ext/pojogen/AbstractPOJOGenMojo.java index 9321c6429..295d1c24a 100644 --- a/ext/pojogen-maven-plugin/src/main/java/org/apache/olingo/ext/pojogen/AbstractPOJOGenMojo.java +++ b/ext/pojogen-maven-plugin/src/main/java/org/apache/olingo/ext/pojogen/AbstractPOJOGenMojo.java @@ -55,7 +55,7 @@ import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.EdmEnumType; import org.apache.olingo.commons.api.edm.EdmSchema; import org.apache.olingo.commons.api.edm.EdmTerm; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.velocity.Template; import org.apache.velocity.VelocityContext; import org.apache.velocity.app.Velocity; @@ -218,7 +218,7 @@ public abstract class AbstractPOJOGenMojo extends AbstractMojo { } else if (StringUtils.isNotEmpty(localEdm)) { final FileInputStream fis = new FileInputStream(FileUtils.getFile(localEdm)); try { - metadata = getClient().getDeserializer(ODataFormat.XML).toMetadata(fis); + metadata = getClient().getDeserializer(ContentType.APPLICATION_XML).toMetadata(fis); edm = getClient().getReader().readMetadata(metadata.getSchemaByNsOrAlias()); } finally { IOUtils.closeQuietly(fis); diff --git a/fit/src/main/java/org/apache/olingo/fit/AbstractServices.java b/fit/src/main/java/org/apache/olingo/fit/AbstractServices.java index 690e00497..8dae5c364 100644 --- a/fit/src/main/java/org/apache/olingo/fit/AbstractServices.java +++ b/fit/src/main/java/org/apache/olingo/fit/AbstractServices.java @@ -148,7 +148,7 @@ public abstract class AbstractServices { atomDeserializer = new FITAtomDeserializer(); jsonDeserializer = new JsonDeserializer(true); atomSerializer = new AtomSerializer(true); - jsonSerializer = new JsonSerializer(true); + jsonSerializer = new JsonSerializer(true, ContentType.JSON_FULL_METADATA); xml = new XMLUtilities(metadata); json = new JSONUtilities(metadata); diff --git a/fit/src/main/java/org/apache/olingo/fit/utils/AbstractUtilities.java b/fit/src/main/java/org/apache/olingo/fit/utils/AbstractUtilities.java index 73eae08f7..0d350d579 100644 --- a/fit/src/main/java/org/apache/olingo/fit/utils/AbstractUtilities.java +++ b/fit/src/main/java/org/apache/olingo/fit/utils/AbstractUtilities.java @@ -55,6 +55,7 @@ import org.apache.olingo.commons.api.data.Link; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.fit.UnsupportedMediaTypeException; import org.apache.olingo.fit.metadata.Metadata; import org.apache.olingo.fit.metadata.NavigationProperty; @@ -104,7 +105,7 @@ public abstract class AbstractUtilities { atomDeserializer = new FITAtomDeserializer(); jsonDeserializer = new JsonDeserializer(true); atomSerializer = new AtomSerializer(true); - jsonSerializer = new JsonSerializer(true); + jsonSerializer = new JsonSerializer(true, ContentType.JSON_FULL_METADATA); } public boolean isMediaContent(final String entityName) { diff --git a/fit/src/main/java/org/apache/olingo/fit/utils/FSManager.java b/fit/src/main/java/org/apache/olingo/fit/utils/FSManager.java index 0dad1e673..4e4785d30 100644 --- a/fit/src/main/java/org/apache/olingo/fit/utils/FSManager.java +++ b/fit/src/main/java/org/apache/olingo/fit/utils/FSManager.java @@ -44,6 +44,7 @@ import org.apache.olingo.client.core.serialization.JsonSerializer; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; +import org.apache.olingo.commons.api.format.ContentType; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -125,7 +126,7 @@ public class FSManager { putInMemory(new ByteArrayInputStream(content.toByteArray()), getAbsolutePath(relativePath, Accept.ATOM)); content.reset(); - new JsonSerializer(true).write(writer, container); + new JsonSerializer(true, ContentType.JSON_FULL_METADATA).write(writer, container); writer.flush(); putInMemory(new ByteArrayInputStream(content.toByteArray()), getAbsolutePath(relativePath, Accept.JSON_FULLMETA)); diff --git a/fit/src/test/java/org/apache/olingo/fit/AbstractBaseTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/AbstractBaseTestITCase.java index 58dd2a35d..f7d49a195 100644 --- a/fit/src/test/java/org/apache/olingo/fit/AbstractBaseTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/AbstractBaseTestITCase.java @@ -36,7 +36,7 @@ import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.api.serialization.ODataSerializerException; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.EntityCollection; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.fit.server.TomcatTestServer; import org.apache.olingo.server.tecsvc.TechnicalServlet; import org.junit.BeforeClass; @@ -72,7 +72,7 @@ public abstract class AbstractBaseTestITCase { if (LOG.isDebugEnabled()) { final StringWriter writer = new StringWriter(); try { - getClient().getSerializer(ODataFormat.JSON).write(writer, entity); + getClient().getSerializer(ContentType.JSON).write(writer, entity); } catch (final ODataSerializerException e) { // Debug } @@ -85,7 +85,7 @@ public abstract class AbstractBaseTestITCase { if (LOG.isDebugEnabled()) { final StringWriter writer = new StringWriter(); try { - getClient().getSerializer(ODataFormat.JSON).write(writer, entitySet); + getClient().getSerializer(ContentType.JSON).write(writer, entitySet); } catch (final ODataSerializerException e) { // Debug } @@ -106,7 +106,8 @@ public abstract class AbstractBaseTestITCase { if (LOG.isDebugEnabled()) { StringWriter writer = new StringWriter(); try { - getClient().getSerializer(ODataFormat.ATOM).write(writer, getClient().getBinder().getEntity(entity)); + getClient().getSerializer(ContentType.APPLICATION_ATOM_XML).write(writer, getClient().getBinder() + .getEntity(entity)); } catch (final ODataSerializerException e) { // Debug } @@ -115,7 +116,7 @@ public abstract class AbstractBaseTestITCase { writer = new StringWriter(); try { - getClient().getSerializer(ODataFormat.JSON).write(writer, getClient().getBinder().getEntity(entity)); + getClient().getSerializer(ContentType.JSON).write(writer, getClient().getBinder().getEntity(entity)); } catch (final ODataSerializerException e) { // Debug } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ActionImportITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ActionImportITCase.java index f29fbe301..316f0ce1c 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ActionImportITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ActionImportITCase.java @@ -44,7 +44,7 @@ import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; @@ -309,7 +309,7 @@ public class ActionImportITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON_NO_METADATA); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON_NO_METADATA); return odata; } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BasicITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BasicITCase.java index 64062413e..3466d469b 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BasicITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BasicITCase.java @@ -28,6 +28,7 @@ import static org.junit.Assert.assertThat; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; +import java.math.BigDecimal; import java.net.URI; import java.util.Collections; import java.util.Iterator; @@ -41,16 +42,19 @@ import org.apache.olingo.client.api.communication.header.HeaderName; import org.apache.olingo.client.api.communication.request.cud.ODataDeleteRequest; 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.ODataPropertyUpdateRequest; import org.apache.olingo.client.api.communication.request.cud.UpdateType; import org.apache.olingo.client.api.communication.request.retrieve.EdmMetadataRequest; import org.apache.olingo.client.api.communication.request.retrieve.ODataEntityRequest; import org.apache.olingo.client.api.communication.request.retrieve.ODataEntitySetRequest; +import org.apache.olingo.client.api.communication.request.retrieve.ODataPropertyRequest; import org.apache.olingo.client.api.communication.request.retrieve.ODataServiceDocumentRequest; import org.apache.olingo.client.api.communication.request.retrieve.ODataValueRequest; import org.apache.olingo.client.api.communication.request.retrieve.XMLMetadataRequest; import org.apache.olingo.client.api.communication.response.ODataDeleteResponse; 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.ODataPropertyUpdateResponse; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.domain.ClientAnnotation; import org.apache.olingo.client.api.domain.ClientComplexValue; @@ -71,16 +75,31 @@ import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; +import org.junit.Ignore; import org.junit.Test; public class BasicITCase extends AbstractBaseTestITCase { - + + private static final String CONTENT_TYPE_JSON_IEEE754_COMPATIBLE = "application/json;odata.metadata=minimal;" + + "IEEE754Compatible=true"; + private static final String SERVICE_NAMESPACE = "olingo.odata.test1"; + private static final String ET_ALL_PRIM_NAME = "ETAllPrim"; + private static final FullQualifiedName ET_ALL_PRIM = new FullQualifiedName(SERVICE_NAMESPACE, ET_ALL_PRIM_NAME); + + private static final String PROPERTY_INT16 = "PropertyInt16"; + private static final String PROPERTY_INT64 = "PropertyInt64"; + private static final String PROPERTY_DECIMAL = "PropertyDecimal"; + private static final String PROPERTY_COMP_ALL_PRIM = "PropertyCompAllPrim"; + private static final String NAV_PROPERTY_ET_TWO_PRIM_ONE = "NavPropertyETTwoPrimOne"; + private static final String SERVICE_URI = TecSvcConst.BASE_URI; + private static final String ES_ALL_PRIM = "ESAllPrim"; + private static final String ES_TWO_PRIM = "ESTwoPrim"; + private static final String ES_KEY_NAV = "ESKeyNav"; @Test public void readServiceDocument() { @@ -377,7 +396,7 @@ public class BasicITCase extends AbstractBaseTestITCase { ClientEntity newEntity = factory.newEntity(new FullQualifiedName("olingo.odata.test1", "ETAllPrim")); newEntity.getProperties().add(factory.newPrimitiveProperty("PropertyInt64", factory.newPrimitiveValueBuilder().buildInt32(42))); - newEntity.addLink(factory.newEntityNavigationLink("NavPropertyETTwoPrimOne", + newEntity.addLink(factory.newEntityNavigationLink(NAV_PROPERTY_ET_TWO_PRIM_ONE, client.newURIBuilder(SERVICE_URI) .appendEntitySetSegment("ESTwoPrim") .appendKeySegment(32766) @@ -422,7 +441,7 @@ public class BasicITCase extends AbstractBaseTestITCase { @Test public void readEntityWithExpandedNavigationProperty() { final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); - client.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); final URI uri = client.newURIBuilder(SERVICE_URI) .appendEntitySetSegment("ESKeyNav") @@ -927,11 +946,356 @@ public class BasicITCase extends AbstractBaseTestITCase { .get("PropertyInt16") .hasNullValue()); } + + @Test + public void createEntityWithIEEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM).build(); + final URI linkURI = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_TWO_PRIM) + .appendKeySegment(32767).build(); + + final ClientEntity newEntity = of.newEntity(ET_ALL_PRIM); + newEntity.getProperties().add(of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildInt64(Long.MAX_VALUE))); + newEntity.getProperties().add(of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildDecimal(BigDecimal.valueOf(34)))); + newEntity.addLink(of.newEntityNavigationLink(NAV_PROPERTY_ET_TWO_PRIM_ONE, linkURI)); + + final ODataEntityCreateRequest request = client.getCUDRequestFactory() + .getEntityCreateRequest(uri, newEntity); + request.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataEntityCreateResponse response = request.execute(); + + assertEquals(Long.MAX_VALUE, response.getBody().getProperty(PROPERTY_INT64).getPrimitiveValue().toValue()); + assertEquals(BigDecimal.valueOf(34), response.getBody().getProperty(PROPERTY_DECIMAL) + .getPrimitiveValue().toValue()); + } + + @Test + public void createEntityWithIEEE754CompatibleParameterNull() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM).build(); + final URI linkURI = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_TWO_PRIM) + .appendKeySegment(32767).build(); + + final ClientEntity newEntity = of.newEntity(ET_ALL_PRIM); + newEntity.getProperties().add(of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildInt64(null))); + newEntity.getProperties().add(of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildDecimal(null))); + newEntity.addLink(of.newEntityNavigationLink(NAV_PROPERTY_ET_TWO_PRIM_ONE, linkURI)); + + final ODataEntityCreateRequest request = client.getCUDRequestFactory() + .getEntityCreateRequest(uri, newEntity); + request.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataEntityCreateResponse response = request.execute(); + + assertTrue(response.getBody().getProperty(PROPERTY_INT64).hasNullValue()); + assertTrue(response.getBody().getProperty(PROPERTY_DECIMAL).hasNullValue()); + } + + @Test + public void updateEntityWithIEEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM).appendKeySegment(0).build(); + + final ClientEntity entity = of.newEntity(ET_ALL_PRIM); + entity.getProperties().add(of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildInt64(Long.MAX_VALUE))); + entity.getProperties().add(of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildDecimal(BigDecimal.valueOf(Long.MAX_VALUE)))); + final ODataEntityUpdateRequest requestUpdate = client.getCUDRequestFactory() + .getEntityUpdateRequest(uri, UpdateType.PATCH, entity); + requestUpdate.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + requestUpdate.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataEntityUpdateResponse responseUpdate = requestUpdate.execute(); + + String cookie = responseUpdate.getHeader(HttpHeader.SET_COOKIE).iterator().next(); + + final ODataEntityRequest requestGet = client.getRetrieveRequestFactory().getEntityRequest(uri); + requestGet.addCustomHeader(HttpHeader.COOKIE, cookie); + requestGet.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse responseGet = requestGet.execute(); + + assertEquals(Long.MAX_VALUE, responseGet.getBody().getProperty(PROPERTY_INT64).getPrimitiveValue().toValue()); + assertEquals(BigDecimal.valueOf(Long.MAX_VALUE), responseGet.getBody().getProperty(PROPERTY_DECIMAL) + .getPrimitiveValue() + .toValue()); + } + + @Test + public void updateEntityWithIEEE754CompatibleParameterNull() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM).appendKeySegment(0).build(); + + final ClientEntity entity = of.newEntity(ET_ALL_PRIM); + entity.getProperties().add(of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildInt64(null))); + entity.getProperties().add(of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildDecimal(null))); + + final ODataEntityUpdateRequest requestUpdate = client.getCUDRequestFactory() + .getEntityUpdateRequest(uri, UpdateType.PATCH, entity); + requestUpdate.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + requestUpdate.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataEntityUpdateResponse responseUpdate = requestUpdate.execute(); + + String cookie = responseUpdate.getHeader(HttpHeader.SET_COOKIE).iterator().next(); + + final ODataEntityRequest requestGet = client.getRetrieveRequestFactory().getEntityRequest(uri); + requestGet.addCustomHeader(HttpHeader.COOKIE, cookie); + requestGet.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse responseGet = requestGet.execute(); + + assertTrue(responseGet.getBody().getProperty(PROPERTY_INT64).hasNullValue()); + assertTrue(responseGet.getBody().getProperty(PROPERTY_DECIMAL).hasNullValue()); + } + + @Test + public void updateEntityWithIEEE754CompatibleParameterWithNullString() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM).appendKeySegment(0).build(); + + final ClientEntity entity = of.newEntity(ET_ALL_PRIM); + entity.getProperties().add(of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildString("null"))); + entity.getProperties().add(of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildString("null"))); + + final ODataEntityUpdateRequest requestUpdate = client.getCUDRequestFactory() + .getEntityUpdateRequest(uri, UpdateType.PATCH, entity); + requestUpdate.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + requestUpdate.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + + try { + requestUpdate.execute(); + fail(); + } catch(ODataClientErrorException e) { + assertEquals(HttpStatusCode.BAD_REQUEST.getStatusCode(), e.getStatusLine().getStatusCode()); + } + } + + @Test + public void updateEdmInt64PropertyWithIEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM) + .appendKeySegment(0) + .appendPropertySegment(PROPERTY_INT64).build(); + + final ODataPropertyUpdateRequest requestUpdate = client.getCUDRequestFactory() + .getPropertyPrimitiveValueUpdateRequest(uri, + of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildInt64(Long.MAX_VALUE))); + + requestUpdate.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + requestUpdate.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataPropertyUpdateResponse responseUpdate = requestUpdate.execute(); + String cookie = responseUpdate.getHeader(HttpHeader.SET_COOKIE).iterator().next(); + + final ODataPropertyRequest requestGet = client.getRetrieveRequestFactory().getPropertyRequest(uri); + requestGet.addCustomHeader(HttpHeader.COOKIE, cookie); + requestGet.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse responseGet = requestGet.execute(); + + assertEquals(Long.MAX_VALUE, responseGet.getBody().getPrimitiveValue().toValue()); + } + + @Test + public void updateComplexPropertyWithIEEE754CompatibleParamter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) + .appendKeySegment(1) + .appendPropertySegment(PROPERTY_COMP_ALL_PRIM).build(); + + final ODataPropertyUpdateRequest requestUpdate = client.getCUDRequestFactory() + .getPropertyComplexValueUpdateRequest(uri, UpdateType.PATCH, + of.newComplexProperty(PROPERTY_COMP_ALL_PRIM, + of.newComplexValue("CTAllPrim") + .add(of.newPrimitiveProperty(PROPERTY_INT64, + of.newPrimitiveValueBuilder().buildInt64(Long.MIN_VALUE))) + .add(of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildDecimal(BigDecimal.valueOf(12345678912L)))) + .add(of.newPrimitiveProperty(PROPERTY_INT16, + of.newPrimitiveValueBuilder().buildInt16((short) 2))))); + + requestUpdate.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + requestUpdate.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataPropertyUpdateResponse responseUpdate = requestUpdate.execute(); + String cookie = responseUpdate.getHeader(HttpHeader.SET_COOKIE).iterator().next(); + + final ODataPropertyRequest requestGet = client.getRetrieveRequestFactory().getPropertyRequest(uri); + requestGet.addCustomHeader(HttpHeader.COOKIE, cookie); + requestGet.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse responseGet = requestGet.execute(); + + final ClientComplexValue complexValue = responseGet.getBody().getComplexValue(); + + assertEquals(Long.MIN_VALUE, complexValue.get(PROPERTY_INT64).getPrimitiveValue().toValue()); + assertEquals(BigDecimal.valueOf(12345678912L), complexValue.get(PROPERTY_DECIMAL).getPrimitiveValue().toValue()); + assertEquals(2, complexValue.get(PROPERTY_INT16).getPrimitiveValue().toValue()); + } + + @Test + public void updateProperyEdmDecimaltWithIEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); + final ClientObjectFactory of = client.getObjectFactory(); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM) + .appendKeySegment(0) + .appendPropertySegment(PROPERTY_DECIMAL).build(); + + final ODataPropertyUpdateRequest requestUpdate = client.getCUDRequestFactory() + .getPropertyPrimitiveValueUpdateRequest(uri, + of.newPrimitiveProperty(PROPERTY_DECIMAL, + of.newPrimitiveValueBuilder().buildInt64(Long.MAX_VALUE))); + + requestUpdate.setContentType(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + requestUpdate.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataPropertyUpdateResponse responseUpdate = requestUpdate.execute(); + String cookie = responseUpdate.getHeader(HttpHeader.SET_COOKIE).iterator().next(); + + final ODataPropertyRequest requestGet = client.getRetrieveRequestFactory().getPropertyRequest(uri); + requestGet.addCustomHeader(HttpHeader.COOKIE, cookie); + requestGet.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse responseGet = requestGet.execute(); + + assertEquals(BigDecimal.valueOf(Long.MAX_VALUE), responseGet.getBody().getPrimitiveValue().toValue()); + } + + @Test + public void readESAllPrimCollectionWithIEEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM) + .orderBy(PROPERTY_INT16) + .build(); + + final ODataEntitySetRequest request = client.getRetrieveRequestFactory().getEntitySetRequest(uri); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse response = request.execute(); + + assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); + final List entities = response.getBody().getEntities(); + assertEquals(3, entities.size()); + + ClientEntity entity = entities.get(0); + assertEquals(-32768, entity.getProperty(PROPERTY_INT16).getPrimitiveValue().toValue()); + assertEquals(Long.MIN_VALUE, entity.getProperty(PROPERTY_INT64).getPrimitiveValue().toValue()); + assertEquals(BigDecimal.valueOf(-34), entity.getProperty(PROPERTY_DECIMAL).getPrimitiveValue().toValue()); + + entity = entities.get(1); + assertEquals(0, entity.getProperty(PROPERTY_INT16).getPrimitiveValue().toValue()); + assertEquals(0L, entity.getProperty(PROPERTY_INT64).getPrimitiveValue().toValue()); + assertEquals(BigDecimal.valueOf(0), entity.getProperty(PROPERTY_DECIMAL).getPrimitiveValue().toValue()); + + entity = entities.get(2); + assertEquals(32767, entity.getProperty(PROPERTY_INT16).getPrimitiveValue().toValue()); + assertEquals(Long.MAX_VALUE, entity.getProperty(PROPERTY_INT64).getPrimitiveValue().toValue()); + assertEquals(BigDecimal.valueOf(34), entity.getProperty(PROPERTY_DECIMAL).getPrimitiveValue().toValue()); + } + + @Test + public void readESKeyNavCheckComplexPropertyWithIEEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV).appendKeySegment(1).build(); + + final ODataEntityRequest request = client.getRetrieveRequestFactory().getEntityRequest(uri); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse response = request.execute(); + + assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); + assertEquals(1, response.getBody().getProperty(PROPERTY_INT16).getPrimitiveValue().toValue()); + + assertEquals(BigDecimal.valueOf(34), response.getBody().getProperty(PROPERTY_COMP_ALL_PRIM) + .getComplexValue() + .get(PROPERTY_DECIMAL) + .getPrimitiveValue() + .toValue()); + + assertEquals(Long.MAX_VALUE, response.getBody().getProperty(PROPERTY_COMP_ALL_PRIM) + .getComplexValue() + .get(PROPERTY_INT64) + .getPrimitiveValue() + .toValue()); + } + + @Test + public void readESKEyNavComplexPropertyWithIEEE754CompatibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) + .appendKeySegment(1) + .appendNavigationSegment(PROPERTY_COMP_ALL_PRIM) + .build(); + ODataPropertyRequest request = client.getRetrieveRequestFactory().getPropertyRequest(uri); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse response = request.execute(); + assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); + + assertEquals(BigDecimal.valueOf(34), response.getBody().getComplexValue() + .get(PROPERTY_DECIMAL) + .getPrimitiveValue() + .toValue()); + + assertEquals(Long.MAX_VALUE, response.getBody().getComplexValue() + .get(PROPERTY_INT64) + .getPrimitiveValue() + .toValue()); + } + + @Test + @Ignore + public void readEdmInt64PropertyWithIEEE754ComaptibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) + .appendKeySegment(1) + .appendPropertySegment(PROPERTY_COMP_ALL_PRIM) + .appendPropertySegment(PROPERTY_INT64) + .build(); + ODataPropertyRequest request = client.getRetrieveRequestFactory().getPropertyRequest(uri); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse response = request.execute(); + assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); + + assertEquals(Long.MAX_VALUE, response.getBody().getPrimitiveValue().toValue()); + } + + @Test + @Ignore + public void readEdmDecimalPropertyWithIEEE754ComaptibleParameter() { + final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); + final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV) + .appendKeySegment(1) + .appendPropertySegment(PROPERTY_COMP_ALL_PRIM) + .appendPropertySegment(PROPERTY_DECIMAL) + .build(); + ODataPropertyRequest request = client.getRetrieveRequestFactory().getPropertyRequest(uri); + request.setAccept(CONTENT_TYPE_JSON_IEEE754_COMPATIBLE); + final ODataRetrieveResponse response = request.execute(); + assertEquals(HttpStatusCode.OK.getStatusCode(), response.getStatusCode()); + + assertEquals(BigDecimal.valueOf(34), response.getBody().getPrimitiveValue().toValue()); + } + @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BatchClientITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BatchClientITCase.java index e56165dbf..0039db617 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BatchClientITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BatchClientITCase.java @@ -51,7 +51,6 @@ import org.apache.olingo.client.core.communication.request.batch.ODataChangesetR import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.tecsvc.TecSvcConst; @@ -122,7 +121,7 @@ public class BatchClientITCase extends AbstractTestITCase { assertTrue(changeSetResponse.isBreaking()); assertEquals(HttpStatusCode.NOT_FOUND.getStatusCode(), updateResponse.getStatusCode()); - assertEquals(ODataFormat.JSON.toString(), updateResponse.getContentType()); + assertEquals(ContentType.JSON.toContentTypeString(), updateResponse.getContentType()); } @Test @@ -252,7 +251,7 @@ public class BatchClientITCase extends AbstractTestITCase { final BatchManager payload = request.payloadManager(); final URI uri = new URI(SERVICE_URI + "/../ESAllPrim(32767)"); final ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(uri); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); payload.addRequest(queryReq); // Fetch result @@ -276,7 +275,7 @@ public class BatchClientITCase extends AbstractTestITCase { final BatchManager payload = request.payloadManager(); final URI uri = new URI("http://otherhost/odata/ESAllPrim(32767)"); final ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(uri); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); payload.addRequest(queryReq); // Fetch result @@ -290,7 +289,7 @@ public class BatchClientITCase extends AbstractTestITCase { final BatchManager payload = request.payloadManager(); final URI uri = new URI("/ESAllPrim(32767)"); final ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(uri); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); payload.addRequest(queryReq); // Fetch result @@ -379,7 +378,7 @@ public class BatchClientITCase extends AbstractTestITCase { // add create request final ODataEntityCreateRequest createReq = client.getCUDRequestFactory().getEntityCreateRequest(uriBuilder.build(), entityESAllPrim); - createReq.setFormat(ODataFormat.JSON); + createReq.setFormat(ContentType.JSON); changeset.addRequest(createReq); // retrieve request reference @@ -393,7 +392,7 @@ public class BatchClientITCase extends AbstractTestITCase { final ODataEntityUpdateRequest updateReq = client.getCUDRequestFactory().getEntityUpdateRequest( URI.create("$" + createRequestRef), UpdateType.PATCH, entityUpdate); - updateReq.setFormat(ODataFormat.JSON); + updateReq.setFormat(ContentType.JSON); changeset.addRequest(updateReq); @@ -419,7 +418,7 @@ public class BatchClientITCase extends AbstractTestITCase { final ODataEntitySetRequest req = client.getRetrieveRequestFactory().getEntitySetRequest( new URI(createResponse.getHeader(HttpHeader.LOCATION).iterator().next() + "/NavPropertyETTwoPrimMany")); - req.setFormat(ODataFormat.JSON); + req.setFormat(ContentType.JSON); req.addCustomHeader(HttpHeader.COOKIE, cookie); final ODataRetrieveResponse getResponse = req.execute(); @@ -466,7 +465,7 @@ public class BatchClientITCase extends AbstractTestITCase { final ODataEntityCreateRequest createRequest = client.getCUDRequestFactory().getEntityCreateRequest(editLink, postEntity); - createRequest.setFormat(ODataFormat.JSON); + createRequest.setFormat(ContentType.JSON); changeset.addRequest(createRequest); @@ -485,7 +484,7 @@ public class BatchClientITCase extends AbstractTestITCase { ODataEntityUpdateRequest changeReq = client.getCUDRequestFactory().getEntityUpdateRequest(UpdateType.PATCH, patchEntity); - changeReq.setFormat(ODataFormat.JSON); + changeReq.setFormat(ContentType.JSON); changeset.addRequest(changeReq); // ------------------------ @@ -506,7 +505,7 @@ public class BatchClientITCase extends AbstractTestITCase { .build())); changeReq = client.getCUDRequestFactory().getEntityUpdateRequest(UpdateType.PATCH, patchEntity); - changeReq.setFormat(ODataFormat.JSON); + changeReq.setFormat(ContentType.JSON); changeset.addRequest(changeReq); // ----------------------------- @@ -586,7 +585,7 @@ public class BatchClientITCase extends AbstractTestITCase { final URI uri = (isRelative) ? new URI(SERVICE_URI).relativize(targetURI.build()) : targetURI.build(); ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(uri); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); manager.addRequest(queryReq); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BindingITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BindingITCase.java index 48c4a0028..9be4cc8ad 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BindingITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/BindingITCase.java @@ -43,7 +43,7 @@ import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -324,7 +324,7 @@ public class BindingITCase extends AbstractBaseTestITCase { @Test public void testDeepInsertWithBindingSameNavigationProperty() { final EdmEnabledODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); - client.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); final ClientObjectFactory of = client.getObjectFactory(); final ClientEntity entity = of.newEntity(ET_KEY_NAV); @@ -392,7 +392,7 @@ public class BindingITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ConditionalITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ConditionalITCase.java index e03505959..1a024da83 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ConditionalITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ConditionalITCase.java @@ -51,7 +51,7 @@ import org.apache.olingo.client.api.domain.ClientServiceDocument; import org.apache.olingo.client.api.http.HttpClientException; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.Edm; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -281,7 +281,7 @@ public final class ConditionalITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/DeepInsertITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/DeepInsertITCase.java index b4b8efeff..d1b4a8dda 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/DeepInsertITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/DeepInsertITCase.java @@ -51,7 +51,7 @@ import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -91,7 +91,7 @@ public class DeepInsertITCase extends AbstractBaseTestITCase { @Test public void testDeepInsertExpandedResponse() { final ODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); - client.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); final URI createURI = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_KEY_NAV).build(); final ClientObjectFactory of = client.getObjectFactory(); final ClientEntity entity = of.newEntity(ET_KEY_NAV); @@ -900,7 +900,7 @@ public class DeepInsertITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/EntityReferencesITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/EntityReferencesITCase.java index e6c2bcff0..3e3377e35 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/EntityReferencesITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/EntityReferencesITCase.java @@ -39,7 +39,7 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.uri.QueryOption; import org.apache.olingo.client.core.ODataClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -1002,7 +1002,7 @@ public class EntityReferencesITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { final EdmEnabledODataClient client = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); - client.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + client.getConfiguration().setDefaultPubFormat(ContentType.JSON); return client; } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ExpandWithSystemQueryOptionsITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ExpandWithSystemQueryOptionsITCase.java index 7516e4df9..75cdecfc6 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ExpandWithSystemQueryOptionsITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/ExpandWithSystemQueryOptionsITCase.java @@ -35,7 +35,7 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.uri.QueryOption; import org.apache.olingo.client.core.ODataClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -471,7 +471,7 @@ public class ExpandWithSystemQueryOptionsITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { EdmEnabledODataClient odata = ODataClientFactory.getEdmEnabledClient(SERVICE_URI); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FilterSystemQueryITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FilterSystemQueryITCase.java index 1e27357b1..8bfd70c4e 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FilterSystemQueryITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FilterSystemQueryITCase.java @@ -34,7 +34,7 @@ import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientObjectFactory; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -1008,7 +1008,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FunctionImportITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FunctionImportITCase.java index 5632bda19..f2ea75e1f 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FunctionImportITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/FunctionImportITCase.java @@ -39,7 +39,7 @@ import org.apache.olingo.client.api.domain.ClientPrimitiveValue; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.core.ODataClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; @@ -223,7 +223,7 @@ public class FunctionImportITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/MediaITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/MediaITCase.java index 3bd14c1e4..e5952a18c 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/MediaITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/MediaITCase.java @@ -43,7 +43,6 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -156,7 +155,7 @@ public final class MediaITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/NavigationITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/NavigationITCase.java index e20d44ed7..e8147a4ed 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/NavigationITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/NavigationITCase.java @@ -27,7 +27,7 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.core.ODataClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; @@ -135,7 +135,7 @@ public final class NavigationITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/OrderBySystemQueryITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/OrderBySystemQueryITCase.java index aa91ed979..f576afa3c 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/OrderBySystemQueryITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/OrderBySystemQueryITCase.java @@ -30,7 +30,7 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.core.ODataClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; @@ -164,7 +164,7 @@ public class OrderBySystemQueryITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/PrimitiveComplexITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/PrimitiveComplexITCase.java index 02d77082f..c129ec8c9 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/PrimitiveComplexITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/PrimitiveComplexITCase.java @@ -51,7 +51,6 @@ import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; @@ -421,7 +420,7 @@ public class PrimitiveComplexITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType.JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/SystemQueryOptionITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/SystemQueryOptionITCase.java index 13ca917cb..94f0d11c7 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/SystemQueryOptionITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/client/SystemQueryOptionITCase.java @@ -31,7 +31,7 @@ import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.core.ODataClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; @@ -311,7 +311,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase { @Override protected ODataClient getClient() { ODataClient odata = ODataClientFactory.getClient(); - odata.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + odata.getConfiguration().setDefaultPubFormat(ContentType .JSON); return odata; } } diff --git a/fit/src/test/java/org/apache/olingo/fit/tecsvc/http/BasicHttpITCase.java b/fit/src/test/java/org/apache/olingo/fit/tecsvc/http/BasicHttpITCase.java index 1a66f11dd..dc32808a4 100644 --- a/fit/src/test/java/org/apache/olingo/fit/tecsvc/http/BasicHttpITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/tecsvc/http/BasicHttpITCase.java @@ -19,15 +19,20 @@ package org.apache.olingo.fit.tecsvc.http; import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; +import java.io.InputStream; +import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpHeader; +import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.apache.olingo.fit.tecsvc.TecSvcConst; +import org.apache.olingo.server.core.deserializer.batch.BufferedReaderIncludingLineEndings; import org.junit.Test; public class BasicHttpITCase extends AbstractBaseTestITCase { @@ -116,7 +121,54 @@ public class BasicHttpITCase extends AbstractBaseTestITCase { String v = connection.getHeaderField(HttpHeader.ODATA_VERSION); assertEquals("4.0", v); } - + + @Test + public void testIEEE754ParameterContentNegotiation() throws Exception { + final URL url = new URL(SERVICE_URI + "/ESAllPrim(32767)?$format=application/json;IEEE754Compatible=true"); + final HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.setRequestMethod("GET"); + connection.setRequestProperty(HttpHeader.ACCEPT, "application/json;IEEE754Compatible=false"); + connection.connect(); + + assertEquals(HttpStatusCode.OK.getStatusCode(), connection.getResponseCode()); + assertEquals(ContentType.create("application/json;IEEE754Compatible=true;odata.metadata=minimal"), + ContentType.create(connection.getContentType())); + final String content = inputStreamToString(connection.getInputStream()); + + assertTrue(content.contains("\"PropertyDecimal\":\"34\"")); + assertTrue(content.contains("\"PropertyInt64\":\"9223372036854775807\"")); + } + + @Test + public void testIEEE754ParameterViaAcceptHeader() throws Exception { + final URL url = new URL(SERVICE_URI + "/ESAllPrim(32767)"); + final HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.setRequestMethod("GET"); + connection.setRequestProperty(HttpHeader.ACCEPT, "application/json;IEEE754Compatible=true"); + connection.connect(); + + assertEquals(HttpStatusCode.OK.getStatusCode(), connection.getResponseCode()); + assertEquals(ContentType.create("application/json;IEEE754Compatible=true;odata.metadata=minimal"), + ContentType.create(connection.getContentType())); + final String content = inputStreamToString(connection.getInputStream()); + + assertTrue(content.contains("\"PropertyDecimal\":\"34\"")); + assertTrue(content.contains("\"PropertyInt64\":\"9223372036854775807\"")); + } + + private String inputStreamToString(final InputStream in) throws Exception { + final BufferedReaderIncludingLineEndings reader = new BufferedReaderIncludingLineEndings(new InputStreamReader(in)); + final StringBuffer buffer = new StringBuffer(); + String current; + + while((current = reader.readLine()) != null) { + buffer.append(current); + } + + reader.close(); + return buffer.toString(); + } + @Override protected ODataClient getClient() { return null; diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/AbstractTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/AbstractTestITCase.java index 5339bffee..6f1645002 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/AbstractTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/AbstractTestITCase.java @@ -46,7 +46,6 @@ import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.fit.AbstractBaseTestITCase; import org.junit.BeforeClass; @@ -97,23 +96,23 @@ public abstract class AbstractTestITCase extends AbstractBaseTestITCase { return client; } - protected ClientEntity read(final ODataFormat format, final URI editLink) { + protected ClientEntity read(final ContentType contentType, final URI editLink) { final ODataEntityRequest req = getClient().getRetrieveRequestFactory().getEntityRequest(editLink); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); final ClientEntity entity = res.getBody(); assertNotNull(entity); - if (ODataFormat.JSON_FULL_METADATA == format || ODataFormat.ATOM == format) { + if (ContentType.JSON_FULL_METADATA == contentType || ContentType.APPLICATION_ATOM_XML == contentType) { assertEquals(req.getURI(), entity.getEditLink()); } return entity; } - protected void createAndDeleteOrder(final String serviceRoot, final ODataFormat format, final int id) { + protected void createAndDeleteOrder(final String serviceRoot, final ContentType contentType, final int id) { final ClientEntity order = getClient().getObjectFactory().newEntity( new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.Order")); @@ -147,19 +146,19 @@ public abstract class AbstractTestITCase extends AbstractBaseTestITCase { final ODataEntityCreateRequest req = getClient().getCUDRequestFactory().getEntityCreateRequest( getClient().newURIBuilder(serviceRoot). appendEntitySetSegment("Orders").build(), order); - req.setFormat(format); + req.setFormat(contentType); final ClientEntity created = req.execute().getBody(); assertNotNull(created); assertEquals(2, created.getProperty("OrderShelfLifes").getCollectionValue().size()); - if (format == ODataFormat.JSON_NO_METADATA) { + if (contentType.equals(ContentType.JSON_NO_METADATA)) { assertEquals(0, created.getNavigationLinks().size()); assertNull(created.getEditLink()); - } else if (format == ODataFormat.JSON_FULL_METADATA) { + } else if (contentType.equals(ContentType.JSON_FULL_METADATA)) { assertEquals(3, created.getNavigationLinks().size()); assertThat(created.getTypeName().getNamespace(), is("Microsoft.Test.OData.Services.ODataWCFService")); assertThat(created.getEditLink().toASCIIString(), startsWith("http://localhost:9080/stub/StaticService")); - } else if (format == ODataFormat.JSON || format == ODataFormat.APPLICATION_JSON) { + } else if (contentType.equals(ContentType.JSON) || contentType.equals(ContentType.APPLICATION_JSON)) { assertEquals(0, created.getNavigationLinks().size()); assertNull(created.getEditLink()); } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/AsyncTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/AsyncTestITCase.java index ded0d97d9..a9436b1ff 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/AsyncTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/AsyncTestITCase.java @@ -39,7 +39,7 @@ import org.apache.olingo.client.api.domain.ClientInlineEntity; import org.apache.olingo.client.api.domain.ClientLink; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.uri.URIBuilder; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class AsyncTestITCase extends AbstractTestITCase { @@ -62,13 +62,13 @@ public class AsyncTestITCase extends AbstractTestITCase { assertFalse(res.getBody().getEntities().isEmpty()); } - private void withInlineEntry(final ODataFormat format) { + private void withInlineEntry(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Customers").appendKeySegment(1).expand("Company"); final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final AsyncRequestWrapper> async = client.getAsyncRequestFactory().> getAsyncRequestWrapper(req); @@ -86,7 +86,7 @@ public class AsyncTestITCase extends AbstractTestITCase { assertEquals(3, entity.getNavigationLinks().size()); - if (ODataFormat.ATOM == format) { + if (ContentType.APPLICATION_ATOM_XML.equals(contentType)) { assertTrue(entity.getAssociationLinks().isEmpty()); // In JSON, association links for each $ref link will exist. } @@ -121,22 +121,22 @@ public class AsyncTestITCase extends AbstractTestITCase { @Test public void withInlineEntryAsAtom() { - withInlineEntry(ODataFormat.ATOM); + withInlineEntry(ContentType.APPLICATION_ATOM_XML); } @Test public void withInlineEntryAsJSON() { // this needs to be full, otherwise there is no mean to recognize links - withInlineEntry(ODataFormat.JSON_FULL_METADATA); + withInlineEntry(ContentType.JSON_FULL_METADATA); } - private void asyncOrders(final ODataFormat format) { + private void asyncOrders(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("async").appendEntitySetSegment("Orders"); final ODataEntitySetRequest req = client.getRetrieveRequestFactory().getEntitySetRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final AsyncRequestWrapper> async = client.getAsyncRequestFactory().> getAsyncRequestWrapper(req); @@ -155,11 +155,11 @@ public class AsyncTestITCase extends AbstractTestITCase { @Test public void asyncOrdersAsAtom() { - asyncOrders(ODataFormat.ATOM); + asyncOrders(ContentType.APPLICATION_ATOM_XML); } @Test public void asyncOrdersAsJSON() { - asyncOrders(ODataFormat.JSON); + asyncOrders(ContentType.JSON); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/AuthBatchTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/AuthBatchTestITCase.java index 47d50c053..123dcd91c 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/AuthBatchTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/AuthBatchTestITCase.java @@ -39,7 +39,6 @@ import org.apache.olingo.client.core.http.BasicAuthHttpClientFactory; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.junit.Test; public class AuthBatchTestITCase extends AbstractTestITCase { @@ -84,7 +83,7 @@ public class AuthBatchTestITCase extends AbstractTestITCase { // create new request ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build()); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); streamManager.addRequest(queryReq); // ------------------------------------------- @@ -108,7 +107,7 @@ public class AuthBatchTestITCase extends AbstractTestITCase { final ODataEntityUpdateRequest changeReq = client.getCUDRequestFactory().getEntityUpdateRequest(UpdateType.PATCH, patch); - changeReq.setFormat(ODataFormat.JSON_FULL_METADATA); + changeReq.setFormat(ContentType.JSON_FULL_METADATA); changeset.addRequest(changeReq); // ------------------------------------------- diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/BatchTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/BatchTestITCase.java index 50a62603c..d039ab272 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/BatchTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/BatchTestITCase.java @@ -67,7 +67,6 @@ import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.junit.Test; public class BatchTestITCase extends AbstractTestITCase { @@ -128,20 +127,20 @@ public class BatchTestITCase extends AbstractTestITCase { for (int i = 1; i <= 2; i++) { // Create Customer into the changeset createReq = client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), newOrder(100 + i)); - createReq.setFormat(ODataFormat.JSON); + createReq.setFormat(ContentType.JSON); changeset.addRequest(createReq); } targetURI = client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("WrongEntitySet"); createReq = client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), newOrder(105)); - createReq.setFormat(ODataFormat.JSON); + createReq.setFormat(ContentType.JSON); changeset.addRequest(createReq); targetURI = client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Orders"); for (int i = 3; i <= 4; i++) { // Create Customer into the changeset createReq = client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), newOrder(100 + i)); - createReq.setFormat(ODataFormat.JSON); + createReq.setFormat(ContentType.JSON); changeset.addRequest(createReq); } @@ -193,7 +192,7 @@ public class BatchTestITCase extends AbstractTestITCase { // create new request ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build()); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); streamManager.addRequest(queryReq); // ------------------------------------------- @@ -340,7 +339,7 @@ public class BatchTestITCase extends AbstractTestITCase { // create new request ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build()); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); streamManager.addRequest(queryReq); // ------------------------------------------- @@ -353,7 +352,7 @@ public class BatchTestITCase extends AbstractTestITCase { final ClientEntity original = newOrder(2000); final ODataEntityCreateRequest createReq = client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), original); - createReq.setFormat(ODataFormat.JSON); + createReq.setFormat(ContentType.JSON); streamManager.addRequest(createReq); // ------------------------------------------- @@ -407,7 +406,7 @@ public class BatchTestITCase extends AbstractTestITCase { // create new request ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build()); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); streamManager.addRequest(queryReq); // ------------------------------------------- @@ -431,7 +430,7 @@ public class BatchTestITCase extends AbstractTestITCase { final ODataEntityUpdateRequest changeReq = client.getCUDRequestFactory().getEntityUpdateRequest(UpdateType.PATCH, patch); - changeReq.setFormat(ODataFormat.JSON_FULL_METADATA); + changeReq.setFormat(ContentType.JSON_FULL_METADATA); changeset.addRequest(changeReq); @@ -440,7 +439,7 @@ public class BatchTestITCase extends AbstractTestITCase { final ClientEntity original = newOrder(1000); final ODataEntityCreateRequest createReq = client.getCUDRequestFactory().getEntityCreateRequest(targetURI.build(), original); - createReq.setFormat(ODataFormat.JSON); + createReq.setFormat(ContentType.JSON); changeset.addRequest(createReq); // ------------------------------------------- @@ -531,7 +530,7 @@ public class BatchTestITCase extends AbstractTestITCase { // create new request ODataEntityRequest queryReq = client.getRetrieveRequestFactory().getEntityRequest(targetURI.build()); - queryReq.setFormat(ODataFormat.JSON); + queryReq.setFormat(ContentType.JSON); async.addRetrieve(queryReq); // ------------------------------------------- diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/BoundOperationInvokeTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/BoundOperationInvokeTestITCase.java index 890b8787c..9782ff0d8 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/BoundOperationInvokeTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/BoundOperationInvokeTestITCase.java @@ -45,17 +45,17 @@ import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class BoundOperationInvokeTestITCase extends AbstractTestITCase { - private void functions(final ODataFormat format) throws EdmPrimitiveTypeException { + private void functions(final ContentType contentType) throws EdmPrimitiveTypeException { // GetEmployeesCount URIBuilder builder = client.newURIBuilder(testStaticServiceRootURL).appendSingletonSegment("Company"); final ODataEntityRequest singletonReq = client.getRetrieveRequestFactory().getSingletonRequest(builder.build()); - singletonReq.setFormat(format); + singletonReq.setFormat(contentType); final ClientSingleton company = singletonReq.execute().getBody(); assertNotNull(company); @@ -64,7 +64,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getEmployeesCountReq = client.getInvokeRequestFactory().getFunctionInvokeRequest(boundOp.getTarget(), ClientProperty.class); - getEmployeesCountReq.setFormat(format); + getEmployeesCountReq.setFormat(contentType); final ClientProperty getEmployeesCountRes = getEmployeesCountReq.execute().getBody(); assertNotNull(getEmployeesCountRes); assertTrue(getEmployeesCountRes.hasPrimitiveValue()); @@ -74,7 +74,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { appendEntitySetSegment("Products").appendKeySegment(5); ODataEntityRequest entityReq = client.getRetrieveRequestFactory(). getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); ClientEntity entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -85,7 +85,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getProductDetailsReq = client.getInvokeRequestFactory().getFunctionInvokeRequest(boundOp.getTarget(), ClientEntitySet.class, Collections. singletonMap("count", count)); - getProductDetailsReq.setFormat(format); + getProductDetailsReq.setFormat(contentType); final ClientEntitySet getProductDetailsRes = getProductDetailsReq.execute().getBody(); assertNotNull(getProductDetailsRes); assertEquals(1, getProductDetailsRes.getEntities().size()); @@ -97,7 +97,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { builder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("ProductDetails").appendKeySegment(keyMap); entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -106,7 +106,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getRelatedProductReq = client.getInvokeRequestFactory().getFunctionInvokeRequest(boundOp.getTarget(), ClientEntity.class); - getRelatedProductReq.setFormat(format); + getRelatedProductReq.setFormat(contentType); final ClientEntity getRelatedProductRes = getRelatedProductReq.execute().getBody(); assertNotNull(getRelatedProductRes); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Product", @@ -117,7 +117,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { builder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Accounts").appendKeySegment(102); entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -126,7 +126,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getDefaultPIReq = client.getInvokeRequestFactory().getFunctionInvokeRequest(boundOp.getTarget(), ClientEntity.class); - getDefaultPIReq.setFormat(format); + getDefaultPIReq.setFormat(contentType); final ClientEntity getDefaultPIRes = getDefaultPIReq.execute().getBody(); assertNotNull(getDefaultPIRes); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.PaymentInstrument", @@ -140,7 +140,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getAccountInfoReq = client.getInvokeRequestFactory().getFunctionInvokeRequest(boundOp.getTarget(), ClientProperty.class); - getAccountInfoReq.setFormat(format); + getAccountInfoReq.setFormat(contentType); final ClientProperty getAccountInfoRes = getAccountInfoReq.execute().getBody(); assertNotNull(getAccountInfoRes); assertTrue(getAccountInfoRes.hasComplexValue()); @@ -150,7 +150,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { // GetActualAmount entityReq = client.getRetrieveRequestFactory().getEntityRequest( entity.getNavigationLink("MyGiftCard").getLink()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); entity = entityReq.execute().getBody(); assertNotNull(entity); assertEquals(301, entity.getProperty("GiftCardID").getPrimitiveValue().toCastValue(Integer.class), 0); @@ -162,7 +162,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getActualAmountReq = client.getInvokeRequestFactory().getFunctionInvokeRequest(boundOp.getTarget(), ClientProperty.class, Collections. singletonMap("bonusRate", bonusRate)); - getActualAmountReq.setFormat(format); + getActualAmountReq.setFormat(contentType); final ClientProperty getActualAmountRes = getActualAmountReq.execute().getBody(); assertNotNull(getActualAmountRes); assertEquals(41.79, getActualAmountRes.getPrimitiveValue().toCastValue(Double.class), 0); @@ -170,12 +170,12 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { @Test public void atomFunctions() throws EdmPrimitiveTypeException { - functions(ODataFormat.ATOM); + functions(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonFunctions() throws EdmPrimitiveTypeException { - functions(ODataFormat.JSON_FULL_METADATA); + functions(ContentType.JSON_FULL_METADATA); } @Test @@ -264,12 +264,12 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { assertEquals(41.79, getActualAmountRes.getPrimitiveValue().toCastValue(Double.class), 0); } - private void actions(final ODataFormat format) throws EdmPrimitiveTypeException { + private void actions(final ContentType contentType) throws EdmPrimitiveTypeException { // IncreaseRevenue URIBuilder builder = client.newURIBuilder(testStaticServiceRootURL).appendSingletonSegment("Company"); ODataEntityRequest entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); ClientEntity entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -281,7 +281,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest increaseRevenueReq = client.getInvokeRequestFactory().getActionInvokeRequest(boundOp.getTarget(), ClientProperty.class, Collections. singletonMap("IncreaseValue", increaseValue)); - increaseRevenueReq.setFormat(format); + increaseRevenueReq.setFormat(contentType); final ClientProperty increaseRevenueRes = increaseRevenueReq.execute().getBody(); assertNotNull(increaseRevenueRes); assertTrue(increaseRevenueRes.hasPrimitiveValue()); @@ -290,7 +290,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { builder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Products").appendKeySegment(5); entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -302,7 +302,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getProductDetailsReq = client.getInvokeRequestFactory().getActionInvokeRequest(boundOp.getTarget(), ClientProperty.class, Collections. singletonMap("accessRight", accessRight)); - getProductDetailsReq.setFormat(format); + getProductDetailsReq.setFormat(contentType); final ClientProperty getProductDetailsRes = getProductDetailsReq.execute().getBody(); assertNotNull(getProductDetailsRes); assertTrue(getProductDetailsRes.hasEnumValue()); @@ -311,7 +311,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { builder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Customers").appendKeySegment(2); entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -336,7 +336,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { params.put("index", index); final ODataInvokeRequest resetAddressReq = client.getInvokeRequestFactory().getActionInvokeRequest(boundOp.getTarget(), ClientEntity.class, params); - resetAddressReq.setFormat(format); + resetAddressReq.setFormat(contentType); final ClientEntity resetAddressRes = resetAddressReq.execute().getBody(); assertNotNull(resetAddressRes); assertEquals(2, resetAddressRes.getProperty("PersonID").getPrimitiveValue().toCastValue(Integer.class), 0); @@ -345,7 +345,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { builder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Accounts").appendKeySegment(102); entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -359,7 +359,7 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest getDefaultPIReq = client.getInvokeRequestFactory().getActionInvokeRequest(boundOp.getTarget(), ClientEntity.class, Collections. singletonMap("newDate", newDate)); - getDefaultPIReq.setFormat(format); + getDefaultPIReq.setFormat(contentType); final ClientEntity getDefaultPIRes = getDefaultPIReq.execute().getBody(); assertNotNull(getDefaultPIRes); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.PaymentInstrument", @@ -370,12 +370,12 @@ public class BoundOperationInvokeTestITCase extends AbstractTestITCase { @Test public void atomActions() throws EdmPrimitiveTypeException { - actions(ODataFormat.ATOM); + actions(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonActions() throws EdmPrimitiveTypeException { - actions(ODataFormat.JSON_FULL_METADATA); + actions(ContentType.JSON_FULL_METADATA); } @Test diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/ConformanceTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/ConformanceTestITCase.java index 472928f97..2e9fe5ae3 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/ConformanceTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/ConformanceTestITCase.java @@ -54,7 +54,7 @@ import org.apache.olingo.client.core.http.DefaultHttpClientFactory; import org.apache.olingo.client.core.uri.URIUtils; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; /** @@ -118,7 +118,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { final ODataEntityCreateRequest req = getClient().getCUDRequestFactory().getEntityCreateRequest( getClient().newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Orders").build(), order); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); // check for OData-Version assertEquals("4.0", req.getHeader("OData-Version")); @@ -126,13 +126,13 @@ public class ConformanceTestITCase extends AbstractTestITCase { // check for Content-Type assertEquals( - ODataFormat.JSON_FULL_METADATA.getContentType().toContentTypeString(), + ContentType.JSON_FULL_METADATA.toContentTypeString(), req.getHeader("Content-Type")); assertEquals( - ODataFormat.JSON_FULL_METADATA.getContentType().toContentTypeString(), + ContentType.JSON_FULL_METADATA.toContentTypeString(), req.getHeader(HeaderName.contentType.toString())); assertEquals( - ODataFormat.JSON_FULL_METADATA.getContentType().toContentTypeString(), + ContentType.JSON_FULL_METADATA.toContentTypeString(), req.getContentType()); final ClientEntity created = req.execute().getBody(); @@ -179,7 +179,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { ODataEntitySetRequest req = client.getRetrieveRequestFactory(). getEntitySetRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); req.setPrefer(client.newPreferences().maxPageSize(5)); ODataRetrieveResponse res = req.execute(); @@ -196,7 +196,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { assertEquals(expected, found); req = client.getRetrieveRequestFactory().getEntitySetRequest(found); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); res = req.execute(); feed = res.getBody(); @@ -236,7 +236,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { final URIBuilder builder = getClient().newURIBuilder(testOpenTypeServiceRootURL). appendEntitySetSegment("RowIndex").appendKeySegment(id); - rowIndex = read(ODataFormat.JSON_FULL_METADATA, builder.build()); + rowIndex = read(ContentType.JSON_FULL_METADATA, builder.build()); assertNotNull(rowIndex); assertEquals(EdmPrimitiveTypeKind.Int32, rowIndex.getProperty("Id").getPrimitiveValue().getTypeKind()); assertEquals(EdmPrimitiveTypeKind.String, rowIndex.getProperty("aString").getPrimitiveValue().getTypeKind()); @@ -269,7 +269,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { final ODataEntityUpdateResponse res = req.execute(); assertEquals(204, res.getStatusCode()); - final ClientEntity actual = read(ODataFormat.JSON, uri); + final ClientEntity actual = read(ContentType.JSON, uri); assertEquals(newname, actual.getProperty("FirstName").getPrimitiveValue().toString()); } @@ -288,7 +288,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); assertNotNull(req.execute().getBody()); @@ -305,7 +305,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { appendRefSegment(); ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); ODataRetrieveResponse res = req.execute(); assertNotNull(res); @@ -318,7 +318,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { appendEntityIdSegment(entity.getId().toASCIIString()).build(); req = client.getRetrieveRequestFactory().getEntityRequest(referenceURI); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); res = req.execute(); assertNotNull(res); @@ -339,7 +339,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { assertNotNull(customers.getDeltaLink()); final ODataDeltaRequest deltaReq = client.getRetrieveRequestFactory().getDeltaRequest(customers.getDeltaLink()); - deltaReq.setFormat(ODataFormat.JSON_FULL_METADATA); + deltaReq.setFormat(ContentType.JSON_FULL_METADATA); final ClientDelta delta = deltaReq.execute().getBody(); assertNotNull(delta); @@ -381,7 +381,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { final ODataEntitySetRequest req = client.getRetrieveRequestFactory().getEntitySetRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); final AsyncRequestWrapper> async = client.getAsyncRequestFactory().> getAsyncRequestWrapper(req); @@ -408,7 +408,7 @@ public class ConformanceTestITCase extends AbstractTestITCase { final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON); + req.setFormat(ContentType.JSON); assertEquals("application/json;odata.metadata=minimal", req.getHeader("Accept")); assertEquals("application/json;odata.metadata=minimal", req.getHeader(HeaderName.accept.toString())); diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/DeltaTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/DeltaTestITCase.java index 1d021418f..dc2c24663 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/DeltaTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/DeltaTestITCase.java @@ -27,12 +27,12 @@ import org.apache.olingo.client.api.communication.request.retrieve.ODataEntitySe import org.apache.olingo.client.api.domain.ClientDelta; import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientProperty; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class DeltaTestITCase extends AbstractTestITCase { - private void parse(final ODataFormat format) { + private void parse(final ContentType format) { final ODataEntitySetRequest req = client.getRetrieveRequestFactory().getEntitySetRequest( client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Customers").build()); req.setPrefer(client.newPreferences().trackChanges()); @@ -76,11 +76,11 @@ public class DeltaTestITCase extends AbstractTestITCase { @Test public void atomParse() { - parse(ODataFormat.ATOM); + parse(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonParse() { - parse(ODataFormat.JSON); + parse(ContentType.JSON); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/DerivedTypeTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/DerivedTypeTestITCase.java index 401f6e8e1..47e71e0d7 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/DerivedTypeTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/DerivedTypeTestITCase.java @@ -36,19 +36,19 @@ import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class DerivedTypeTestITCase extends AbstractTestITCase { - private void read(final ODataFormat format) { + private void read(final ContentType contentType) { // 1. entity set URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People"). appendDerivedEntityTypeSegment("Microsoft.Test.OData.Services.ODataWCFService.Customer"); ODataEntitySetRequest req = client.getRetrieveRequestFactory(). getEntitySetRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); for (ClientEntity customer : req.execute().getBody().getEntities()) { assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", customer.getTypeName().toString()); @@ -60,7 +60,7 @@ public class DerivedTypeTestITCase extends AbstractTestITCase { appendNavigationSegment("MyPaymentInstruments"). appendDerivedEntityTypeSegment("Microsoft.Test.OData.Services.ODataWCFService.CreditCardPI"); req = client.getRetrieveRequestFactory().getEntitySetRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); for (ClientEntity customer : req.execute().getBody().getEntities()) { assertEquals("Microsoft.Test.OData.Services.ODataWCFService.CreditCardPI", customer.getTypeName().toString()); @@ -69,15 +69,15 @@ public class DerivedTypeTestITCase extends AbstractTestITCase { @Test public void readfromAtom() { - read(ODataFormat.ATOM); + read(ContentType.APPLICATION_ATOM_XML); } @Test public void readfromJSON() { - read(ODataFormat.JSON_FULL_METADATA); + read(ContentType.JSON_FULL_METADATA); } - private void createDelete(final ODataFormat format) { + private void createDelete(final ContentType conentType) { final ClientEntity customer = client.getObjectFactory(). newEntity(new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.Customer")); @@ -119,7 +119,7 @@ public class DerivedTypeTestITCase extends AbstractTestITCase { getEntityCreateRequest( client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("People").build(), customer); - createReq.setFormat(format); + createReq.setFormat(conentType); final ODataEntityCreateResponse createRes = createReq.execute(); assertEquals(201, createRes.getStatusCode()); @@ -127,7 +127,7 @@ public class DerivedTypeTestITCase extends AbstractTestITCase { final ODataEntityRequest fetchReq = client.getRetrieveRequestFactory(). getEntityRequest(client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(976).build()); - fetchReq.setFormat(format); + fetchReq.setFormat(conentType); final ClientEntity actual = fetchReq.execute().getBody(); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", actual.getTypeName().toString()); @@ -140,11 +140,11 @@ public class DerivedTypeTestITCase extends AbstractTestITCase { @Test public void createDeleteAsAtom() { - createDelete(ODataFormat.ATOM); + createDelete(ContentType.APPLICATION_ATOM_XML); } @Test public void createDeleteAsJSON() { - createDelete(ODataFormat.JSON_FULL_METADATA); + createDelete(ContentType.JSON_FULL_METADATA); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/EntityCreateTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/EntityCreateTestITCase.java index 796649523..781396663 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/EntityCreateTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/EntityCreateTestITCase.java @@ -35,24 +35,24 @@ import org.apache.olingo.client.api.domain.ClientLink; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class EntityCreateTestITCase extends AbstractTestITCase { @Test public void atomCreateAndDelete() { - createAndDeleteOrder(testStaticServiceRootURL, ODataFormat.ATOM, 1000); + createAndDeleteOrder(testStaticServiceRootURL, ContentType.APPLICATION_ATOM_XML, 1000); } @Test public void jsonCreateAndDelete() { - createAndDeleteOrder(testStaticServiceRootURL, ODataFormat.JSON, 1001); - createAndDeleteOrder(testStaticServiceRootURL, ODataFormat.JSON_NO_METADATA, 1001); - createAndDeleteOrder(testStaticServiceRootURL, ODataFormat.JSON_FULL_METADATA, 1001); + createAndDeleteOrder(testStaticServiceRootURL, ContentType.JSON, 1001); + createAndDeleteOrder(testStaticServiceRootURL, ContentType.JSON_NO_METADATA, 1001); + createAndDeleteOrder(testStaticServiceRootURL, ContentType.JSON_FULL_METADATA, 1001); } - private void onContained(final ODataFormat format) { + private void onContained(final ContentType contentType) { final URI uri = getClient().newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Accounts"). appendKeySegment(101).appendNavigationSegment("MyPaymentInstruments").build(); @@ -77,7 +77,7 @@ public class EntityCreateTestITCase extends AbstractTestITCase { // 3. create it as contained entity final ODataEntityCreateRequest req = getClient().getCUDRequestFactory(). getEntityCreateRequest(uri, instrument); - req.setFormat(format); + req.setFormat(contentType); final ODataEntityCreateResponse res = req.execute(); assertEquals(201, res.getStatusCode()); @@ -102,15 +102,15 @@ public class EntityCreateTestITCase extends AbstractTestITCase { @Test public void atomOnContained() { - onContained(ODataFormat.ATOM); + onContained(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonOnContained() { - onContained(ODataFormat.JSON); + onContained(ContentType.JSON); } - private void deepInsert(final ODataFormat format, final int productId, final int productDetailId) + private void deepInsert(final ContentType contentType, final int productId, final int productDetailId) throws EdmPrimitiveTypeException { final ClientEntity product = getClient().getObjectFactory(). @@ -161,7 +161,7 @@ public class EntityCreateTestITCase extends AbstractTestITCase { final ODataEntityCreateRequest req = getClient().getCUDRequestFactory().getEntityCreateRequest( getClient().newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Products").build(), product); - req.setFormat(format); + req.setFormat(contentType); final ODataEntityCreateResponse res = req.execute(); assertEquals(201, res.getStatusCode()); @@ -181,11 +181,11 @@ public class EntityCreateTestITCase extends AbstractTestITCase { @Test public void atomDeepInsert() throws EdmPrimitiveTypeException { - deepInsert(ODataFormat.ATOM, 10, 10); + deepInsert(ContentType.APPLICATION_ATOM_XML, 10, 10); } @Test public void jsonDeepInsert() throws EdmPrimitiveTypeException { - deepInsert(ODataFormat.JSON_FULL_METADATA, 11, 11); + deepInsert(ContentType.JSON_FULL_METADATA, 11, 11); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/EntityRetrieveTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/EntityRetrieveTestITCase.java index 91461dbf4..58fc16077 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/EntityRetrieveTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/EntityRetrieveTestITCase.java @@ -45,7 +45,7 @@ import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; /** @@ -53,13 +53,13 @@ import org.junit.Test; */ public class EntityRetrieveTestITCase extends AbstractTestITCase { - private void withInlineEntity(final ODataClient client, final ODataFormat format) { + private void withInlineEntity(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Customers").appendKeySegment(1).expand("Company"); final ODataEntityRequest req = client.getRetrieveRequestFactory(). getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); final ClientEntity entity = res.getBody(); @@ -70,11 +70,14 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { assertEquals("Edm.GeographyPoint", entity.getProperty("Home").getPrimitiveValue().getTypeName()); // In JSON with minimal metadata, links are not provided - if (format == ODataFormat.ATOM || format == ODataFormat.JSON_FULL_METADATA) { + if(contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC, ContentType.APPLICATION_ATOM_XML) + || (contentType.isCompatible(ContentType.JSON) + && ContentType.VALUE_ODATA_METADATA_FULL + .equals(contentType.getParameter(ContentType.PARAMETER_ODATA_METADATA)))) { assertEquals(testStaticServiceRootURL + "/Customers(1)", entity.getEditLink().toASCIIString()); assertEquals(3, entity.getNavigationLinks().size()); - if (ODataFormat.ATOM == format) { + if (ContentType.APPLICATION_ATOM_XML == contentType) { assertTrue(entity.getAssociationLinks().isEmpty()); // In JSON, association links for each $ref link will exist. } @@ -110,26 +113,26 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void withInlineEntityFromAtom() { - withInlineEntity(client, ODataFormat.ATOM); + withInlineEntity(client, ContentType.APPLICATION_ATOM_XML); } @Test public void withInlineEntityFromFullJSON() { - withInlineEntity(client, ODataFormat.JSON_FULL_METADATA); + withInlineEntity(client, ContentType.JSON_FULL_METADATA); } @Test public void withInlineEntityFromJSON() { - withInlineEntity(edmClient, ODataFormat.JSON); + withInlineEntity(edmClient, ContentType.JSON); } - private void withInlineEntitySet(final ODataClient client, final ODataFormat format) { + private void withInlineEntitySet(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Customers").appendKeySegment(1).expand("Orders"); final ODataEntityRequest req = client.getRetrieveRequestFactory(). getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); final ClientEntity entity = res.getBody(); @@ -137,7 +140,7 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", entity.getTypeName().toString()); // In JSON with minimal metadata, links are not provided - if (format == ODataFormat.ATOM || format == ODataFormat.JSON_FULL_METADATA) { + if (contentType.equals(ContentType.APPLICATION_ATOM_XML) || contentType.equals(ContentType.JSON_FULL_METADATA)) { boolean found = false; for (ClientLink link : entity.getNavigationLinks()) { if (link instanceof ClientInlineEntitySet) { @@ -153,25 +156,25 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void withInlineEntitySetFromAtom() { - withInlineEntitySet(client, ODataFormat.ATOM); + withInlineEntitySet(client, ContentType.APPLICATION_ATOM_XML); } @Test public void withInlineEntitySetFromFullJSON() { - withInlineEntitySet(client, ODataFormat.JSON_FULL_METADATA); + withInlineEntitySet(client, ContentType.JSON_FULL_METADATA); } @Test public void withInlineEntitySetFromJSON() { - withInlineEntitySet(edmClient, ODataFormat.JSON); + withInlineEntitySet(edmClient, ContentType.JSON); } - private void rawRequest(final ODataFormat format) { + private void rawRequest(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5); final ODataRawRequest req = client.getRetrieveRequestFactory().getRawRequest(uriBuilder.build()); - req.setFormat(format.getContentType().toContentTypeString()); + req.setFormat(contentType.toContentTypeString()); final ODataRawResponse res = req.execute(); assertNotNull(res); @@ -185,16 +188,16 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void rawRequestAsAtom() { - rawRequest(ODataFormat.ATOM); + rawRequest(ContentType.APPLICATION_ATOM_XML); } @Test public void rawRequestAsJSON() { // this needs to be full, otherwise reference will not be provided - rawRequest(ODataFormat.JSON_FULL_METADATA); + rawRequest(ContentType.JSON_FULL_METADATA); } - private void multiKey(final ODataFormat format) throws EdmPrimitiveTypeException { + private void multiKey(final ContentType contentType) throws EdmPrimitiveTypeException { final LinkedHashMap multiKey = new LinkedHashMap(); multiKey.put("ProductID", "6"); multiKey.put("ProductDetailID", 1); @@ -204,7 +207,7 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); final ClientEntity entity = res.getBody(); @@ -215,21 +218,21 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void multiKeyAsAtom() throws EdmPrimitiveTypeException { - multiKey(ODataFormat.ATOM); + multiKey(ContentType.APPLICATION_ATOM_XML); } @Test public void multiKeyAsJSON() throws EdmPrimitiveTypeException { - multiKey(ODataFormat.JSON_FULL_METADATA); + multiKey(ContentType.JSON_FULL_METADATA); } - private void checkForETag(final ODataClient client, final ODataFormat format) { + private void checkForETag(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("Orders").appendKeySegment(8); final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); assertEquals(200, res.getStatusCode()); @@ -248,17 +251,17 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void checkForETagAsAtom() { - checkForETag(client, ODataFormat.ATOM); + checkForETag(client, ContentType.APPLICATION_ATOM_XML); } @Test public void checkForETagAsFullJSON() { - checkForETag(client, ODataFormat.JSON_FULL_METADATA); + checkForETag(client, ContentType.JSON_FULL_METADATA); } @Test public void checkForETagAsJSON() { - checkForETag(edmClient, ODataFormat.JSON); + checkForETag(edmClient, ContentType.JSON); } @Test(expected = IllegalArgumentException.class) @@ -267,20 +270,20 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON); + req.setFormat(ContentType.JSON); // this statement should cause an IllegalArgumentException bearing JsonParseException // since we are attempting to parse an EntitySet as if it was an Entity req.execute().getBody(); } - private void reference(final ODataFormat format) { + private void reference(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Orders").appendKeySegment(8).appendNavigationSegment("CustomerForOrder"). appendRefSegment(); ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); ODataRetrieveResponse res = req.execute(); assertNotNull(res); @@ -293,7 +296,7 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { appendEntityIdSegment(entity.getId().toASCIIString()).build(); req = client.getRetrieveRequestFactory().getEntityRequest(referenceURI); - req.setFormat(format); + req.setFormat(contentType); res = req.execute(); assertNotNull(res); @@ -302,20 +305,20 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void atomReference() { - reference(ODataFormat.ATOM); + reference(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonReference() { - reference(ODataFormat.JSON_FULL_METADATA); + reference(ContentType.JSON_FULL_METADATA); } - private void contained(final ODataClient client, final ODataFormat format) throws EdmPrimitiveTypeException { + private void contained(final ODataClient client, final ContentType contentType) throws EdmPrimitiveTypeException { final URI uri = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Accounts").appendKeySegment(101). appendNavigationSegment("MyPaymentInstruments").appendKeySegment(101902).build(); final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uri); - req.setFormat(format); + req.setFormat(contentType); final ClientEntity contained = req.execute().getBody(); assertNotNull(contained); @@ -328,30 +331,30 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void containedFromAtom() throws EdmPrimitiveTypeException { - contained(client, ODataFormat.ATOM); + contained(client, ContentType.APPLICATION_ATOM_XML); } @Test public void containedFromFullJSON() throws EdmPrimitiveTypeException { - contained(client, ODataFormat.JSON_FULL_METADATA); + contained(client, ContentType.JSON_FULL_METADATA); } @Test public void containedFromJSON() throws EdmPrimitiveTypeException { - contained(edmClient, ODataFormat.JSON); + contained(edmClient, ContentType.JSON); } - private void entitySetNavigationLink(final ODataClient client, final ODataFormat format) { + private void entitySetNavigationLink(final ODataClient client, final ContentType contentType) { final URI uri = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Accounts").appendKeySegment(101).build(); final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uri); - req.setFormat(format); + req.setFormat(contentType); final ClientEntity entity = req.execute().getBody(); assertNotNull(entity); // With JSON, entity set navigation links are only recognizable via Edm - if (format == ODataFormat.ATOM || client instanceof EdmEnabledODataClient) { + if (contentType.equals(ContentType.APPLICATION_ATOM_XML) || client instanceof EdmEnabledODataClient) { assertEquals(ClientLinkType.ENTITY_SET_NAVIGATION, entity.getNavigationLink("MyPaymentInstruments").getType()); assertEquals(ClientLinkType.ENTITY_SET_NAVIGATION, entity.getNavigationLink("ActiveSubscriptions").getType()); } @@ -359,13 +362,13 @@ public class EntityRetrieveTestITCase extends AbstractTestITCase { @Test public void entitySetNavigationLinkFromAtom() { - entitySetNavigationLink(client, ODataFormat.ATOM); + entitySetNavigationLink(client, ContentType.APPLICATION_ATOM_XML); } @Test public void entitySetNavigationLinkFromJSON() { // only JSON_FULL_METADATA has links, only Edm can recognize entity set navigation - entitySetNavigationLink(edmClient, ODataFormat.JSON_FULL_METADATA); + entitySetNavigationLink(edmClient, ContentType.JSON_FULL_METADATA); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/EntitySetTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/EntitySetTestITCase.java index b94e891c1..64d425b04 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/EntitySetTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/EntitySetTestITCase.java @@ -37,7 +37,7 @@ import org.apache.olingo.client.api.domain.ClientEntitySetIterator; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.client.core.uri.URIUtils; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; /** @@ -45,11 +45,11 @@ import org.junit.Test; */ public class EntitySetTestITCase extends AbstractTestITCase { - private void rawRequest(final ODataFormat format) { + private void rawRequest(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("People"); final ODataRawRequest req = client.getRetrieveRequestFactory().getRawRequest(uriBuilder.build()); - req.setFormat(format.getContentType().toContentTypeString()); + req.setFormat(contentType.toContentTypeString()); final ODataRawResponse res = req.execute(); assertNotNull(res); @@ -61,20 +61,20 @@ public class EntitySetTestITCase extends AbstractTestITCase { @Test public void rawRequestAsAtom() throws IOException { - rawRequest(ODataFormat.ATOM); + rawRequest(ContentType.APPLICATION_ATOM_XML); } @Test public void rawRequestAsJSON() throws IOException { - rawRequest(ODataFormat.JSON); + rawRequest(ContentType.JSON); } - private void readWithInlineCount(final ODataClient client, final ODataFormat format) { + private void readWithInlineCount(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").count(true); final ODataRawRequest req = client.getRetrieveRequestFactory().getRawRequest(uriBuilder.build()); - req.setFormat(format.getContentType().toContentTypeString()); + req.setFormat(contentType.toContentTypeString()); final ODataRawResponse res = req.execute(); assertNotNull(res); @@ -88,25 +88,25 @@ public class EntitySetTestITCase extends AbstractTestITCase { @Test public void readWithInlineCountAsJSON() throws IOException { - readWithInlineCount(edmClient, ODataFormat.JSON); + readWithInlineCount(edmClient, ContentType.JSON); } @Test public void readWithInlineCountAsFullJSON() throws IOException { - readWithInlineCount(client, ODataFormat.JSON_FULL_METADATA); + readWithInlineCount(client, ContentType.JSON_FULL_METADATA); } @Test public void readWithInlineCountAsAtom() throws IOException { - readWithInlineCount(client, ODataFormat.ATOM); + readWithInlineCount(client, ContentType.APPLICATION_ATOM_XML); } - private void readODataEntitySetIterator(final ODataFormat format) { + private void readODataEntitySetIterator(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("People"); final ODataEntitySetIteratorRequest req = client.getRetrieveRequestFactory().getEntitySetIteratorRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse> res = req.execute(); final ClientEntitySetIterator feedIterator = res.getBody(); @@ -125,25 +125,25 @@ public class EntitySetTestITCase extends AbstractTestITCase { @Test public void readODataEntitySetIteratorFromAtom() { - readODataEntitySetIterator(ODataFormat.ATOM); + readODataEntitySetIterator(ContentType.APPLICATION_ATOM_XML); } @Test public void readODataEntitySetIteratorFromJSON() { - readODataEntitySetIterator(ODataFormat.JSON); + readODataEntitySetIterator(ContentType.JSON); } @Test public void readODataEntitySetIteratorFromJSONFull() { - readODataEntitySetIterator(ODataFormat.JSON_FULL_METADATA); + readODataEntitySetIterator(ContentType.JSON_FULL_METADATA); } @Test public void readODataEntitySetIteratorFromJSONNo() { - readODataEntitySetIterator(ODataFormat.JSON_NO_METADATA); + readODataEntitySetIterator(ContentType.JSON_NO_METADATA); } - private void readWithNext(final ODataFormat format) { + private void readWithNext(final ContentType format) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL).appendEntitySetSegment("People"); final ODataEntitySetRequest req = client.getRetrieveRequestFactory(). @@ -167,12 +167,12 @@ public class EntitySetTestITCase extends AbstractTestITCase { @Test public void readWithNextFromAtom() { - readWithNext(ODataFormat.ATOM); + readWithNext(ContentType.APPLICATION_ATOM_XML); } @Test public void readWithNextFromJSON() { - readWithNext(ODataFormat.JSON_FULL_METADATA); + readWithNext(ContentType.JSON_FULL_METADATA); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/EntityUpdateTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/EntityUpdateTestITCase.java index 6ac0e8da5..875034895 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/EntityUpdateTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/EntityUpdateTestITCase.java @@ -37,13 +37,13 @@ import org.apache.olingo.client.api.domain.ClientLink; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Ignore; import org.junit.Test; public class EntityUpdateTestITCase extends AbstractTestITCase { - private void upsert(final UpdateType updateType, final ODataFormat format) { + private void upsert(final UpdateType updateType, final ContentType contentType) { final ClientEntity order = getClient().getObjectFactory(). newEntity(new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.Order")); @@ -61,11 +61,11 @@ public class EntityUpdateTestITCase extends AbstractTestITCase { appendEntitySetSegment("Orders").appendKeySegment(9).build(); final ODataEntityUpdateRequest req = getClient().getCUDRequestFactory(). getEntityUpdateRequest(upsertURI, updateType, order); - req.setFormat(format); + req.setFormat(contentType); req.execute(); try { - final ClientEntity read = read(format, upsertURI); + final ClientEntity read = read(contentType, upsertURI); assertNotNull(read); assertEquals(order.getProperty("OrderID"), read.getProperty("OrderID")); assertEquals(order.getProperty("OrderDate").getPrimitiveValue().toString(), @@ -103,17 +103,17 @@ public class EntityUpdateTestITCase extends AbstractTestITCase { @Test public void atomUpsert() { - upsert(UpdateType.PATCH, ODataFormat.ATOM); - upsert(UpdateType.REPLACE, ODataFormat.ATOM); + upsert(UpdateType.PATCH, ContentType.APPLICATION_ATOM_XML); + upsert(UpdateType.REPLACE, ContentType.APPLICATION_ATOM_XML); } @Test public void jsonUpsert() { - upsert(UpdateType.PATCH, ODataFormat.JSON); - upsert(UpdateType.REPLACE, ODataFormat.JSON); + upsert(UpdateType.PATCH, ContentType.JSON); + upsert(UpdateType.REPLACE, ContentType.JSON); } - private void onContained(final ODataFormat format) { + private void onContained(final ContentType contentType) { final String newName = UUID.randomUUID().toString(); final ClientEntity changes = getClient().getObjectFactory().newEntity( new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.PaymentInstrument")); @@ -125,7 +125,7 @@ public class EntityUpdateTestITCase extends AbstractTestITCase { appendNavigationSegment("MyPaymentInstruments").appendKeySegment(101901).build(); final ODataEntityUpdateRequest req = getClient().getCUDRequestFactory(). getEntityUpdateRequest(uri, UpdateType.PATCH, changes); - req.setFormat(format); + req.setFormat(contentType); final ODataEntityUpdateResponse res = req.execute(); assertEquals(204, res.getStatusCode()); @@ -137,15 +137,15 @@ public class EntityUpdateTestITCase extends AbstractTestITCase { @Test public void atomOnContained() { - onContained(ODataFormat.ATOM); + onContained(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonOnContained() { - onContained(ODataFormat.JSON); + onContained(ContentType.JSON); } - private void bindOperation(final ODataFormat format) throws EdmPrimitiveTypeException { + private void bindOperation(final ContentType contentType) throws EdmPrimitiveTypeException { final ClientEntity changes = getClient().getObjectFactory().newEntity( new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.Customer")); final ClientLink parent = getClient().getObjectFactory().newEntityNavigationLink("Parent", @@ -157,7 +157,7 @@ public class EntityUpdateTestITCase extends AbstractTestITCase { appendEntitySetSegment("People").appendKeySegment(5).build(); final ODataEntityUpdateRequest req = getClient().getCUDRequestFactory(). getEntityUpdateRequest(uri, UpdateType.PATCH, changes); - req.setFormat(format); + req.setFormat(contentType); final ODataEntityUpdateResponse res = req.execute(); assertEquals(204, res.getStatusCode()); @@ -175,11 +175,11 @@ public class EntityUpdateTestITCase extends AbstractTestITCase { @Test public void atomBindOperation() throws EdmPrimitiveTypeException { - bindOperation(ODataFormat.ATOM); + bindOperation(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonBindOperation() throws EdmPrimitiveTypeException { - bindOperation(ODataFormat.JSON); + bindOperation(ContentType.JSON); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/ErrorResponseTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/ErrorResponseTestITCase.java index 33d3ba4d5..983957669 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/ErrorResponseTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/ErrorResponseTestITCase.java @@ -27,7 +27,7 @@ import java.util.Map; import org.apache.olingo.client.api.communication.ODataClientErrorException; import org.apache.olingo.commons.api.ODataError; import org.apache.olingo.commons.api.ODataErrorDetail; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class ErrorResponseTestITCase extends AbstractTestITCase { @@ -39,7 +39,7 @@ public class ErrorResponseTestITCase extends AbstractTestITCase { build(); try { - read(ODataFormat.JSON, readURI); + read(ContentType.JSON, readURI); fail("should have got exception"); } catch (Exception ex) { final ODataError err = ((ODataClientErrorException) ex).getODataError(); diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/FilterFactoryTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/FilterFactoryTestITCase.java index b7a4f8c29..f25cfd3b7 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/FilterFactoryTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/FilterFactoryTestITCase.java @@ -27,7 +27,7 @@ import org.apache.olingo.client.api.uri.FilterArgFactory; import org.apache.olingo.client.api.uri.FilterFactory; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.client.api.uri.URIFilter; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class FilterFactoryTestITCase extends AbstractTestITCase { @@ -50,7 +50,7 @@ public class FilterFactoryTestITCase extends AbstractTestITCase { final ODataEntitySetRequest req = client.getRetrieveRequestFactory().getEntitySetRequest(uriBuilder.build()); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); final ClientEntitySet feed = req.execute().getBody(); assertEquals(3, feed.getEntities().size()); diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/JSONFormatConformanceTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/JSONFormatConformanceTestITCase.java index 648dcec2c..f738ed47a 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/JSONFormatConformanceTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/JSONFormatConformanceTestITCase.java @@ -40,7 +40,7 @@ import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; /** @@ -91,7 +91,7 @@ public class JSONFormatConformanceTestITCase extends AbstractTestITCase { final URI uri = edmClient.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Accounts").appendKeySegment(102).build(); final ODataEntityRequest req = edmClient.getRetrieveRequestFactory().getEntityRequest(uri); - req.setFormat(ODataFormat.JSON_FULL_METADATA); + req.setFormat(ContentType.JSON_FULL_METADATA); // request format (via Accept header) is set to full metadata assertEquals("application/json;odata.metadata=full", req.getAccept()); @@ -148,7 +148,7 @@ public class JSONFormatConformanceTestITCase extends AbstractTestITCase { + "\"GeographyPoint\": {\"type\": \"Point\",\"coordinates\":[142.1,64.1]}" + "}"; - final ClientEntity entity = client.getReader().readEntity(IOUtils.toInputStream(fromSection71), ODataFormat.JSON); + final ClientEntity entity = client.getReader().readEntity(IOUtils.toInputStream(fromSection71), ContentType.JSON); assertTrue(entity.getProperty("NullValue").hasNullValue()); @@ -219,7 +219,7 @@ public class JSONFormatConformanceTestITCase extends AbstractTestITCase { + "}"; final ResWrap entity = - client.getDeserializer(ODataFormat.JSON).toEntity(IOUtils.toInputStream(fromSection45_1)); + client.getDeserializer(ContentType.JSON).toEntity(IOUtils.toInputStream(fromSection45_1)); assertEquals("http://host/service/$metadata#Customers/$entity", entity.getContextURL().toASCIIString()); assertEquals("W/\"A1FF3E230954908F\"", entity.getMetadataETag()); @@ -241,7 +241,7 @@ public class JSONFormatConformanceTestITCase extends AbstractTestITCase { + "}"; final ResWrap entitySet = - client.getDeserializer(ODataFormat.JSON).toEntitySet(IOUtils.toInputStream(fromSection45_2)); + client.getDeserializer(ContentType.JSON).toEntitySet(IOUtils.toInputStream(fromSection45_2)); assertEquals(5, entitySet.getPayload().getCount(), 0); assertEquals("Customers?$expand=Orders&$skipToken=5", entitySet.getPayload().getNext().toASCIIString()); @@ -271,7 +271,7 @@ public class JSONFormatConformanceTestITCase extends AbstractTestITCase { + "}"; final ClientEntitySet entitySet = client.getReader(). - readEntitySet(IOUtils.toInputStream(sample), ODataFormat.JSON); + readEntitySet(IOUtils.toInputStream(sample), ContentType.JSON); assertEquals(2, entitySet.getAnnotations().size()); diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/KeyAsSegmentTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/KeyAsSegmentTestITCase.java index f3e7d76db..54206fb51 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/KeyAsSegmentTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/KeyAsSegmentTestITCase.java @@ -33,7 +33,7 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.AfterClass; import org.junit.BeforeClass; import org.junit.Test; @@ -50,20 +50,20 @@ public class KeyAsSegmentTestITCase extends AbstractTestITCase { client.getConfiguration().setKeyAsSegment(false); } - private void read(final ODataFormat format) { + private void read(final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testKeyAsSegmentServiceRootURL). appendEntitySetSegment("Accounts").appendKeySegment(101); final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); final ClientEntity entity = res.getBody(); assertNotNull(entity); // In JSON with minimal metadata, links are not provided - if (format == ODataFormat.ATOM || format == ODataFormat.JSON_FULL_METADATA) { + if (contentType.equals(ContentType.APPLICATION_ATOM_XML) || contentType.equals(ContentType.JSON_FULL_METADATA)) { assertFalse(entity.getEditLink().toASCIIString().contains("(")); assertFalse(entity.getEditLink().toASCIIString().contains(")")); } @@ -71,25 +71,25 @@ public class KeyAsSegmentTestITCase extends AbstractTestITCase { @Test public void atomRead() { - read(ODataFormat.ATOM); + read(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonRead() { - read(ODataFormat.JSON); + read(ContentType.JSON); } @Test public void atomCreateAndDelete() { - createAndDeleteOrder(testKeyAsSegmentServiceRootURL, ODataFormat.ATOM, 1000); + createAndDeleteOrder(testKeyAsSegmentServiceRootURL, ContentType.APPLICATION_ATOM_XML, 1000); } @Test public void jsonCreateAndDelete() { - createAndDeleteOrder(testKeyAsSegmentServiceRootURL, ODataFormat.JSON_FULL_METADATA, 1001); + createAndDeleteOrder(testKeyAsSegmentServiceRootURL, ContentType.JSON_FULL_METADATA, 1001); } - private void update(final ODataFormat format) { + private void update(final ContentType contentType) { final ClientEntity changes = getClient().getObjectFactory().newEntity( new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.Customer")); final ClientProperty middleName = getClient().getObjectFactory().newPrimitiveProperty("MiddleName", @@ -100,7 +100,7 @@ public class KeyAsSegmentTestITCase extends AbstractTestITCase { appendEntitySetSegment("People").appendKeySegment(5).build(); final ODataEntityUpdateRequest req = getClient().getCUDRequestFactory(). getEntityUpdateRequest(uri, UpdateType.PATCH, changes); - req.setFormat(format); + req.setFormat(contentType); final ODataEntityUpdateResponse res = req.execute(); assertEquals(204, res.getStatusCode()); @@ -117,11 +117,11 @@ public class KeyAsSegmentTestITCase extends AbstractTestITCase { @Test public void atomUpdate() { - update(ODataFormat.ATOM); + update(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonUpdate() { - update(ODataFormat.JSON); + update(ContentType.JSON); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/MediaEntityTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/MediaEntityTestITCase.java index a39e71b88..0c6352dc8 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/MediaEntityTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/MediaEntityTestITCase.java @@ -52,18 +52,18 @@ import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class MediaEntityTestITCase extends AbstractTestITCase { - private void read(final ODataClient client, final ODataFormat format) throws IOException { + private void read(final ODataClient client, final ContentType contentType) throws IOException { final URIBuilder builder = client.newURIBuilder(testDemoServiceRootURL). appendEntitySetSegment("Advertisements"). appendKeySegment(UUID.fromString("f89dee73-af9f-4cd4-b330-db93c25ff3c7")); final ODataEntityRequest entityReq = client.getRetrieveRequestFactory().getEntityRequest(builder.build()); - entityReq.setFormat(format); + entityReq.setFormat(contentType); final ClientEntity entity = entityReq.execute().getBody(); assertNotNull(entity); @@ -83,20 +83,20 @@ public class MediaEntityTestITCase extends AbstractTestITCase { @Test public void readAsAtom() throws IOException { - read(client, ODataFormat.ATOM); + read(client, ContentType.APPLICATION_ATOM_XML); } @Test public void readAsJSON() throws IOException { - read(ODataClientFactory.getEdmEnabledClient(testDemoServiceRootURL), ODataFormat.JSON); + read(ODataClientFactory.getEdmEnabledClient(testDemoServiceRootURL), ContentType.JSON); } @Test public void readAsJSONFull() throws IOException { - read(client, ODataFormat.JSON_FULL_METADATA); + read(client, ContentType.JSON_FULL_METADATA); } - private void create(final ODataFormat format) throws IOException { + private void create(final ContentType contentType) throws IOException { final String random = RandomStringUtils.random(110); final InputStream input = IOUtils.toInputStream(random); @@ -120,7 +120,7 @@ public class MediaEntityTestITCase extends AbstractTestITCase { final ODataEntityUpdateRequest updateReq = getClient().getCUDRequestFactory(). getEntityUpdateRequest(createdLocation, UpdateType.PATCH, changes); - updateReq.setFormat(format); + updateReq.setFormat(contentType); final ODataEntityUpdateResponse updateRes = updateReq.execute(); assertEquals(204, updateRes.getStatusCode()); @@ -137,15 +137,15 @@ public class MediaEntityTestITCase extends AbstractTestITCase { @Test public void createAsAtom() throws IOException { - create(ODataFormat.ATOM); + create(ContentType.APPLICATION_ATOM_XML); } @Test public void createAsJSON() throws IOException { - create(ODataFormat.JSON); + create(ContentType.JSON); } - private void update(final ODataFormat format) throws IOException, EdmPrimitiveTypeException { + private void update(final ContentType contentType) throws IOException, EdmPrimitiveTypeException { final URI uri = client.newURIBuilder(testDemoServiceRootURL). appendEntitySetSegment("Advertisements"). appendKeySegment(UUID.fromString("f89dee73-af9f-4cd4-b330-db93c25ff3c7")).build(); @@ -155,7 +155,7 @@ public class MediaEntityTestITCase extends AbstractTestITCase { // 1. update providing media content final ODataMediaEntityUpdateRequest updateReq = client.getCUDRequestFactory(). getMediaEntityUpdateRequest(uri, IOUtils.toInputStream(random)); - updateReq.setFormat(format); + updateReq.setFormat(contentType); final MediaEntityUpdateStreamManager streamManager = updateReq.payloadManager(); final ODataMediaEntityUpdateResponse createRes = streamManager.getResponse(); @@ -173,11 +173,11 @@ public class MediaEntityTestITCase extends AbstractTestITCase { @Test public void updateAsAtom() throws IOException, EdmPrimitiveTypeException { - update(ODataFormat.ATOM); + update(ContentType.APPLICATION_ATOM_XML); } @Test public void updateAsJSON() throws IOException, EdmPrimitiveTypeException { - update(ODataFormat.JSON); + update(ContentType.JSON); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/OAuth2TestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/OAuth2TestITCase.java index 7e8c13158..1285fa201 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/OAuth2TestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/OAuth2TestITCase.java @@ -32,7 +32,7 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.client.core.http.DefaultHttpClientFactory; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.fit.CXFOAuth2HttpClientFactory; import org.junit.AfterClass; import org.junit.BeforeClass; @@ -76,13 +76,13 @@ public class OAuth2TestITCase extends AbstractTestITCase { return _edmClient; } - private void read(final ODataClient client, final ODataFormat format) { + private void read(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testOAuth2ServiceRootURL).appendEntitySetSegment("Orders").appendKeySegment(8); final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); assertEquals(200, res.getStatusCode()); @@ -127,19 +127,19 @@ public class OAuth2TestITCase extends AbstractTestITCase { } public void readAsAtom() { - read(getLocalClient(), ODataFormat.ATOM); + read(getLocalClient(), ContentType.APPLICATION_ATOM_XML); } public void readAsFullJSON() { - read(getLocalClient(), ODataFormat.JSON_FULL_METADATA); + read(getLocalClient(), ContentType.JSON_FULL_METADATA); } public void readAsJSON() { - read(getEdmClient(), ODataFormat.JSON); + read(getEdmClient(), ContentType.JSON); } public void createAndDelete() { - createAndDeleteOrder(testOAuth2ServiceRootURL, ODataFormat.JSON, 1002); + createAndDeleteOrder(testOAuth2ServiceRootURL, ContentType.JSON, 1002); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/OpenTypeTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/OpenTypeTestITCase.java index f4fe4f8d0..c3b033704 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/OpenTypeTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/OpenTypeTestITCase.java @@ -36,7 +36,7 @@ import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmSchema; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class OpenTypeTestITCase extends AbstractTestITCase { @@ -53,32 +53,32 @@ public class OpenTypeTestITCase extends AbstractTestITCase { assertTrue(metadata.getEntityType(new FullQualifiedName(schema.getNamespace(), "RowIndex")).isOpenType()); } - private ClientEntity readRow(final ODataFormat format, final String uuid) { + private ClientEntity readRow(final ContentType contentType, final String uuid) { final URIBuilder builder = getClient().newURIBuilder(testOpenTypeServiceRootURL). appendEntitySetSegment("Row").appendKeySegment(UUID.fromString(uuid)); - return read(format, builder.build()); + return read(contentType, builder.build()); } - private void read(final ODataFormat format) { - ClientEntity row = readRow(format, "71f7d0dc-ede4-45eb-b421-555a2aa1e58f"); + private void read(final ContentType contentType) { + ClientEntity row = readRow(contentType, "71f7d0dc-ede4-45eb-b421-555a2aa1e58f"); assertEquals(EdmPrimitiveTypeKind.Double, row.getProperty("Double").getPrimitiveValue().getTypeKind()); assertEquals(EdmPrimitiveTypeKind.Guid, row.getProperty("Id").getPrimitiveValue().getTypeKind()); - row = readRow(format, "672b8250-1e6e-4785-80cf-b94b572e42b3"); + row = readRow(contentType, "672b8250-1e6e-4785-80cf-b94b572e42b3"); assertEquals(EdmPrimitiveTypeKind.Decimal, row.getProperty("Decimal").getPrimitiveValue().getTypeKind()); } @Test public void readAsAtom() { - read(ODataFormat.ATOM); + read(ContentType.APPLICATION_ATOM_XML); } @Test public void readAsJSON() { - read(ODataFormat.JSON_FULL_METADATA); + read(ContentType.JSON_FULL_METADATA); } - private void cud(final ODataFormat format) { + private void cud(final ContentType contentType) { final Integer id = 1426; ClientEntity rowIndex = getClient().getObjectFactory().newEntity( @@ -154,13 +154,13 @@ public class OpenTypeTestITCase extends AbstractTestITCase { final ODataEntityCreateRequest createReq = getClient().getCUDRequestFactory(). getEntityCreateRequest(getClient().newURIBuilder(testOpenTypeServiceRootURL). appendEntitySetSegment("RowIndex").build(), rowIndex); - createReq.setFormat(format); + createReq.setFormat(contentType); final ODataEntityCreateResponse createRes = createReq.execute(); assertEquals(201, createRes.getStatusCode()); final URIBuilder builder = getClient().newURIBuilder(testOpenTypeServiceRootURL). appendEntitySetSegment("RowIndex").appendKeySegment(id); - rowIndex = read(format, builder.build()); + rowIndex = read(contentType, builder.build()); assertNotNull(rowIndex); assertEquals(EdmPrimitiveTypeKind.Int32, rowIndex.getProperty("Id").getPrimitiveValue().getTypeKind()); assertEquals(EdmPrimitiveTypeKind.String, rowIndex.getProperty("aString").getPrimitiveValue().getTypeKind()); @@ -179,12 +179,12 @@ public class OpenTypeTestITCase extends AbstractTestITCase { @Test public void cudAsAtom() { - cud(ODataFormat.ATOM); + cud(ContentType.APPLICATION_ATOM_XML); } @Test public void cudAsJSON() { - cud(ODataFormat.JSON_FULL_METADATA); + cud(ContentType.JSON_FULL_METADATA); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/OperationImportInvokeTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/OperationImportInvokeTestITCase.java index 1b27efa06..d6d535bae 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/OperationImportInvokeTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/OperationImportInvokeTestITCase.java @@ -37,17 +37,17 @@ import org.apache.olingo.client.api.domain.ClientPrimitiveValue; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class OperationImportInvokeTestITCase extends AbstractTestITCase { - private void functionImports(final ODataFormat format) throws EdmPrimitiveTypeException { + private void functionImports(final ContentType contentType) throws EdmPrimitiveTypeException { // GetDefaultColor final ODataInvokeRequest defaultColorReq = getClient().getInvokeRequestFactory(). getFunctionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("GetDefaultColor").build(), ClientProperty.class); - defaultColorReq.setFormat(format); + defaultColorReq.setFormat(contentType); final ClientProperty defaultColor = defaultColorReq.execute().getBody(); assertNotNull(defaultColor); assertTrue(defaultColor.hasEnumValue()); @@ -61,7 +61,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { getFunctionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("GetPerson2").build(), ClientEntity.class, Collections. singletonMap("city", city)); - person2Req.setFormat(format); + person2Req.setFormat(contentType); final ClientEntity person2 = person2Req.execute().getBody(); assertNotNull(person2); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", person2.getTypeName().toString()); @@ -81,7 +81,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { getFunctionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("GetPerson").build(), ClientEntity.class, Collections. singletonMap("address", address)); - personReq.setFormat(format); + personReq.setFormat(contentType); final ClientEntity person = personReq.execute().getBody(); assertNotNull(person); assertEquals(person2, person); @@ -90,7 +90,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { final ODataInvokeRequest productsReq = getClient().getInvokeRequestFactory() .getFunctionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("GetAllProducts").build(), ClientEntitySet.class); - productsReq.setFormat(format); + productsReq.setFormat(contentType); final ClientEntitySet products = productsReq.execute().getBody(); assertNotNull(products); assertEquals(5, products.getEntities().size()); @@ -103,7 +103,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { getFunctionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("GetProductsByAccessLevel").build(), ClientProperty.class, Collections. singletonMap("accessLevel", accessLevel)); - prodByALReq.setFormat(format); + prodByALReq.setFormat(contentType); final ClientProperty prodByAL = prodByALReq.execute().getBody(); assertNotNull(prodByAL); assertTrue(prodByAL.hasCollectionValue()); @@ -113,12 +113,12 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { @Test public void atomFunctionImports() throws EdmPrimitiveTypeException { - functionImports(ODataFormat.ATOM); + functionImports(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonFunctionImports() throws EdmPrimitiveTypeException { - functionImports(ODataFormat.JSON_FULL_METADATA); + functionImports(ContentType.JSON_FULL_METADATA); } @Test @@ -182,14 +182,14 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { assertTrue(prodByAL.getCollectionValue().asJavaCollection().contains("Car")); } - private void actionImports(final ODataFormat format) { + private void actionImports(final ContentType contentType) { // Discount final ClientPrimitiveValue percentage = getClient().getObjectFactory().newPrimitiveValueBuilder().buildInt32(22); final ODataInvokeRequest discountReq = getClient().getInvokeRequestFactory(). getActionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("Discount").build(), ClientNoContent.class, Collections. singletonMap("percentage", percentage)); - discountReq.setFormat(format); + discountReq.setFormat(contentType); final ClientNoContent discount = discountReq.execute().getBody(); assertNotNull(discount); @@ -207,7 +207,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { getActionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("ResetBossAddress").build(), ClientProperty.class, Collections. singletonMap("address", address)); - resetBossAddressReq.setFormat(format); + resetBossAddressReq.setFormat(contentType); final ClientProperty resetBossAddress = resetBossAddressReq.execute().getBody(); assertNotNull(resetBossAddress); assertEquals(address, resetBossAddress.getComplexValue()); @@ -215,12 +215,12 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { @Test public void atomActionImports() { - actionImports(ODataFormat.ATOM); + actionImports(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonActionImports() { - actionImports(ODataFormat.JSON_FULL_METADATA); + actionImports(ContentType.JSON_FULL_METADATA); } @Test @@ -251,7 +251,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { assertEquals(address.getTypeName(), resetBossAddress.getComplexValue().getTypeName()); } - private void bossEmails(final ODataFormat format) { + private void bossEmails(final ContentType contentType) { // ResetBossEmail final ClientCollectionValue emails = getClient().getObjectFactory().newCollectionValue("Collection(Edm.String)"); @@ -261,7 +261,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { getActionInvokeRequest(getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("ResetBossEmail").build(), ClientProperty.class, Collections. singletonMap("emails", emails)); - bossEmailsReq.setFormat(format); + bossEmailsReq.setFormat(contentType); final ClientProperty bossEmails = bossEmailsReq.execute().getBody(); assertNotNull(bossEmails); assertTrue(bossEmails.hasCollectionValue()); @@ -273,7 +273,7 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { bossEmailsReq = getClient().getInvokeRequestFactory().getFunctionInvokeRequest( getClient().newURIBuilder(testStaticServiceRootURL). appendOperationCallSegment("GetBossEmails").build(), ClientProperty.class, params); - bossEmailsReq.setFormat(format); + bossEmailsReq.setFormat(contentType); final ClientProperty bossEmailsViaGET = bossEmailsReq.execute().getBody(); assertNotNull(bossEmailsViaGET); assertTrue(bossEmailsViaGET.hasCollectionValue()); @@ -284,11 +284,11 @@ public class OperationImportInvokeTestITCase extends AbstractTestITCase { @Test public void atomBossEmails() throws EdmPrimitiveTypeException { - bossEmails(ODataFormat.ATOM); + bossEmails(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonBossEmails() throws EdmPrimitiveTypeException { - bossEmails(ODataFormat.JSON_FULL_METADATA); + bossEmails(ContentType.JSON_FULL_METADATA); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/PropertyTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/PropertyTestITCase.java index e2c625045..cb94f83fe 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/PropertyTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/PropertyTestITCase.java @@ -37,18 +37,18 @@ import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.api.uri.URIBuilder; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; import org.junit.Test; public class PropertyTestITCase extends AbstractTestITCase { - private void _enum(final ODataClient client, final ODataFormat format) { + private void _enum(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Products").appendKeySegment(5).appendPropertySegment("CoverColors"); final ODataPropertyRequest req = client.getRetrieveRequestFactory(). getPropertyRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ClientProperty prop = req.execute().getBody(); assertNotNull(prop); @@ -59,25 +59,25 @@ public class PropertyTestITCase extends AbstractTestITCase { @Test public void enumFromXML() { - _enum(client, ODataFormat.XML); + _enum(client, ContentType.APPLICATION_XML); } @Test public void enumFromJSON() { - _enum(edmClient, ODataFormat.JSON); + _enum(edmClient, ContentType.JSON); } @Test public void enumFromFullJSON() { - _enum(client, ODataFormat.JSON_FULL_METADATA); + _enum(client, ContentType.JSON_FULL_METADATA); } - private void geospatial(final ODataClient client, final ODataFormat format) { + private void geospatial(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("Home"); final ODataPropertyRequest req = client.getRetrieveRequestFactory(). getPropertyRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ClientProperty prop = req.execute().getBody(); assertNotNull(prop); @@ -87,25 +87,25 @@ public class PropertyTestITCase extends AbstractTestITCase { @Test public void geospatialFromXML() { - geospatial(client, ODataFormat.XML); + geospatial(client, ContentType.APPLICATION_XML); } @Test public void geospatialFromJSON() { - geospatial(edmClient, ODataFormat.JSON); + geospatial(edmClient, ContentType.JSON); } @Test public void geospatialFromFullJSON() { - geospatial(client, ODataFormat.JSON_FULL_METADATA); + geospatial(client, ContentType.JSON_FULL_METADATA); } - private void complex(final ODataClient client, final ODataFormat format) { + private void complex(final ODataClient client, final ContentType contentType) { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Customers").appendKeySegment(2).appendPropertySegment("HomeAddress"); final ODataPropertyRequest req = client.getRetrieveRequestFactory(). getPropertyRequest(uriBuilder.build()); - req.setFormat(format); + req.setFormat(contentType); final ClientProperty prop = req.execute().getBody(); assertNotNull(prop); @@ -116,26 +116,26 @@ public class PropertyTestITCase extends AbstractTestITCase { @Test public void complexFromXML() { - complex(client, ODataFormat.XML); + complex(client, ContentType.APPLICATION_XML); } @Test public void complexFromJSON() { - complex(edmClient, ODataFormat.JSON); + complex(edmClient, ContentType.JSON); } @Test public void complexFromFullJSON() { - complex(client, ODataFormat.JSON_FULL_METADATA); + complex(client, ContentType.JSON_FULL_METADATA); } - private void updateComplexProperty(final ODataFormat format, final UpdateType type) throws IOException { + private void updateComplexProperty(final ContentType contentType, final UpdateType type) throws IOException { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Customers").appendKeySegment(1).appendPropertySegment("HomeAddress"); ODataPropertyRequest retrieveReq = client.getRetrieveRequestFactory().getPropertyRequest(uriBuilder.build()); - retrieveReq.setFormat(format); + retrieveReq.setFormat(contentType); ODataRetrieveResponse retrieveRes = retrieveReq.execute(); assertEquals(200, retrieveRes.getStatusCode()); @@ -153,13 +153,13 @@ public class PropertyTestITCase extends AbstractTestITCase { } else { assertEquals(type.getMethod(), updateReq.getMethod()); } - updateReq.setFormat(format); + updateReq.setFormat(contentType); final ODataPropertyUpdateResponse updateRes = updateReq.execute(); assertEquals(204, updateRes.getStatusCode()); retrieveReq = client.getRetrieveRequestFactory().getPropertyRequest(uriBuilder.build()); - retrieveReq.setFormat(format); + retrieveReq.setFormat(contentType); retrieveRes = retrieveReq.execute(); assertEquals(200, retrieveRes.getStatusCode()); @@ -170,7 +170,7 @@ public class PropertyTestITCase extends AbstractTestITCase { @Test public void patchComplexPropertyAsJSON() throws IOException { - updateComplexProperty(ODataFormat.JSON_FULL_METADATA, UpdateType.PATCH); + updateComplexProperty(ContentType.JSON_FULL_METADATA, UpdateType.PATCH); } @Test diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/PropertyValueTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/PropertyValueTestITCase.java index 123c1696a..c2eadc231 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/PropertyValueTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/PropertyValueTestITCase.java @@ -32,7 +32,7 @@ import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class PropertyValueTestITCase extends AbstractTestITCase { @@ -42,7 +42,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("PersonID"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); assertEquals("5", req.execute().getBody().toString()); } @@ -51,7 +51,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("IsRegistered"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); assertEquals("true", req.execute().getBody().toString()); } @@ -60,7 +60,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("FirstName"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); assertEquals("Peter", req.execute().getBody().toString()); } @@ -69,7 +69,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("Orders").appendKeySegment(8).appendPropertySegment("OrderDate"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); final ClientPrimitiveValue property = req.execute().getBody(); assertEquals("2011-03-04T16:03:57Z", property.toString()); } @@ -79,7 +79,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("Height"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); final ClientPrimitiveValue property = req.execute().getBody(); assertEquals("179", property.toString()); } @@ -89,7 +89,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("PDC"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); final ClientPrimitiveValue property = req.execute().getBody(); assertEquals("fi653p3+MklA/LdoBlhWgnMTUUEo8tEgtbMXnF0a3CUNL9BZxXpSRiD9ebTnmNR0zWPjJ" + "VIDx4tdmCnq55XrJh+RW9aI/b34wAogK3kcORw=", property.toString()); @@ -100,7 +100,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("PDC"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setAccept(ODataFormat.ATOM.getContentType().toContentTypeString()); + req.setAccept(ContentType.APPLICATION_ATOM_XML.toContentTypeString()); req.execute().getBody(); } @@ -109,7 +109,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("PDC"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setAccept(ODataFormat.XML.getContentType().toContentTypeString()); + req.setAccept(ContentType.APPLICATION_XML.toContentTypeString()); req.execute().getBody(); } @@ -119,7 +119,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("Numbers"); final ODataPropertyRequest req = client.getRetrieveRequestFactory(). getPropertyRequest(uriBuilder.build()); - req.setFormat(ODataFormat.XML); + req.setFormat(ContentType.APPLICATION_XML); final ClientProperty property = req.execute().getBody(); // cast to workaround JDK 6 bug, fixed in JDK 7 assertTrue(((ClientValuable) property).getValue().isCollection()); @@ -131,7 +131,7 @@ public class PropertyValueTestITCase extends AbstractTestITCase { final URIBuilder uriBuilder = client.newURIBuilder(testStaticServiceRootURL). appendEntitySetSegment("People").appendKeySegment(5).appendPropertySegment("HomeAddress"); final ODataValueRequest req = client.getRetrieveRequestFactory().getPropertyValueRequest(uriBuilder.build()); - req.setFormat(ODataFormat.TEXT_PLAIN); + req.setFormat(ContentType.TEXT_PLAIN); final ClientPrimitiveValue property = req.execute().getBody(); assertTrue(StringUtils.isBlank(property.toString())); } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/QueryOptionsTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/QueryOptionsTestITCase.java index 19af510d4..b9119f8b7 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/QueryOptionsTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/QueryOptionsTestITCase.java @@ -36,7 +36,7 @@ import org.apache.olingo.client.api.domain.ClientInlineEntitySet; import org.apache.olingo.client.api.uri.QueryOption; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; /** @@ -128,12 +128,12 @@ public class QueryOptionsTestITCase extends AbstractTestITCase { final ODataEntityRequest req = client.getRetrieveRequestFactory().getEntityRequest(uriBuilder.build()); - req.setFormat(ODataFormat.ATOM); + req.setFormat(ContentType.APPLICATION_ATOM_XML); final ODataRetrieveResponse res = req.execute(); assertNotNull(res); assertTrue(res.getContentType().replaceAll(" ", ""). - startsWith(ODataFormat.JSON.getContentType().toContentTypeString())); + startsWith(ContentType.JSON.toContentTypeString())); } /** diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/ServiceDocumentTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/ServiceDocumentTestITCase.java index 13f762855..69a869c3b 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/ServiceDocumentTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/ServiceDocumentTestITCase.java @@ -25,15 +25,15 @@ import java.net.URI; import org.apache.olingo.client.api.communication.request.retrieve.ODataServiceDocumentRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.domain.ClientServiceDocument; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class ServiceDocumentTestITCase extends AbstractTestITCase { - private void retrieveServiceDocument(final ODataFormat format) { + private void retrieveServiceDocument(final ContentType contentType) { final ODataServiceDocumentRequest req = client.getRetrieveRequestFactory().getServiceDocumentRequest(testStaticServiceRootURL); - req.setFormat(format); + req.setFormat(contentType); final ODataRetrieveResponse res = req.execute(); assertEquals(200, res.getStatusCode()); @@ -53,11 +53,11 @@ public class ServiceDocumentTestITCase extends AbstractTestITCase { @Test public void retrieveServiceDocumentAsXML() { - retrieveServiceDocument(ODataFormat.XML); + retrieveServiceDocument(ContentType.APPLICATION_XML); } @Test public void retrieveServiceDocumentAsJSON() { - retrieveServiceDocument(ODataFormat.JSON); + retrieveServiceDocument(ContentType.JSON); } } diff --git a/fit/src/test/java/org/apache/olingo/fit/v4/SingletonTestITCase.java b/fit/src/test/java/org/apache/olingo/fit/v4/SingletonTestITCase.java index 14d9f1faa..7f4e2f8d2 100644 --- a/fit/src/test/java/org/apache/olingo/fit/v4/SingletonTestITCase.java +++ b/fit/src/test/java/org/apache/olingo/fit/v4/SingletonTestITCase.java @@ -36,16 +36,16 @@ import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.api.uri.URIBuilder; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; public class SingletonTestITCase extends AbstractTestITCase { - private void read(final ODataClient client, final ODataFormat format) throws EdmPrimitiveTypeException { + private void read(final ODataClient client, final ContentType contentType) throws EdmPrimitiveTypeException { final URIBuilder builder = client.newURIBuilder(testStaticServiceRootURL).appendSingletonSegment("Company"); final ODataEntityRequest singleton = client.getRetrieveRequestFactory().getSingletonRequest(builder.build()); - singleton.setFormat(format); + singleton.setFormat(contentType); final ClientSingleton company = singleton.execute().getBody(); assertNotNull(company); @@ -58,26 +58,26 @@ public class SingletonTestITCase extends AbstractTestITCase { @Test public void readFromAtom() throws EdmPrimitiveTypeException { - read(client, ODataFormat.ATOM); + read(client, ContentType.APPLICATION_ATOM_XML); } @Test public void readFromJSON() throws EdmPrimitiveTypeException { - read(edmClient, ODataFormat.JSON); + read(edmClient, ContentType.JSON); } @Test public void readfromJSONFull() throws EdmPrimitiveTypeException { - read(client, ODataFormat.JSON_FULL_METADATA); + read(client, ContentType.JSON_FULL_METADATA); } - private void readWithAnnotations(final ODataClient client, final ODataFormat format) + private void readWithAnnotations(final ODataClient client, final ContentType contentType) throws EdmPrimitiveTypeException { final URIBuilder builder = client.newURIBuilder(testStaticServiceRootURL).appendSingletonSegment("Boss"); final ODataEntityRequest singleton = client.getRetrieveRequestFactory().getSingletonRequest(builder.build()); - singleton.setFormat(format); + singleton.setFormat(contentType); singleton.setPrefer(client.newPreferences().includeAnnotations("*")); final ClientSingleton boss = singleton.execute().getBody(); assertNotNull(boss); @@ -89,20 +89,20 @@ public class SingletonTestITCase extends AbstractTestITCase { @Test public void readWithAnnotationsFromAtom() throws EdmPrimitiveTypeException { - readWithAnnotations(client, ODataFormat.ATOM); + readWithAnnotations(client, ContentType.APPLICATION_ATOM_XML); } @Test public void readWithAnnotationsFromJSON() throws EdmPrimitiveTypeException { - readWithAnnotations(edmClient, ODataFormat.JSON); + readWithAnnotations(edmClient, ContentType.JSON); } @Test public void readWithAnnotationsFromJSONFull() throws EdmPrimitiveTypeException { - readWithAnnotations(client, ODataFormat.JSON_FULL_METADATA); + readWithAnnotations(client, ContentType.JSON_FULL_METADATA); } - private void update(final ODataFormat format) throws EdmPrimitiveTypeException { + private void update(final ContentType contentType) throws EdmPrimitiveTypeException { final ClientSingleton changes = getClient().getObjectFactory().newSingleton( new FullQualifiedName("Microsoft.Test.OData.Services.ODataWCFService.Company")); changes.getProperties().add(getClient().getObjectFactory().newPrimitiveProperty("Revenue", @@ -111,7 +111,7 @@ public class SingletonTestITCase extends AbstractTestITCase { final URI uri = client.newURIBuilder(testStaticServiceRootURL).appendSingletonSegment("Company").build(); final ODataEntityUpdateRequest req = getClient().getCUDRequestFactory(). getSingletonUpdateRequest(uri, UpdateType.PATCH, changes); - req.setFormat(format); + req.setFormat(contentType); final ODataEntityUpdateResponse res = req.execute(); assertEquals(204, res.getStatusCode()); @@ -124,12 +124,12 @@ public class SingletonTestITCase extends AbstractTestITCase { @Test public void atomUpdate() throws EdmPrimitiveTypeException { - update(ODataFormat.ATOM); + update(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonUpdate() throws EdmPrimitiveTypeException { - update(ODataFormat.JSON); + update(ContentType.JSON); } } diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/Configuration.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/Configuration.java index a02780069..f9ef1cc46 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/Configuration.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/Configuration.java @@ -23,7 +23,6 @@ import java.util.concurrent.ExecutorService; import org.apache.olingo.client.api.http.HttpClientFactory; import org.apache.olingo.client.api.http.HttpUriRequestFactory; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; /** * Configuration wrapper. @@ -49,16 +48,15 @@ public interface Configuration { * JSON_FULL_METADATA format will be used as default. * * @return configured OData format for AtomPub if specified; JSON_FULL_METADATA format otherwise. - * @see ODataFormat#JSON_FULL_METADATA */ - ODataFormat getDefaultPubFormat(); + ContentType getDefaultPubFormat(); /** * Sets the default OData format for AtomPub exchanges. * * @param format default format. */ - void setDefaultPubFormat(ODataFormat format); + void setDefaultPubFormat(ContentType format); /** * Gets the configured OData format. This value depends on what is returned from getDefaultPubFormat(). @@ -66,23 +64,22 @@ public interface Configuration { * @return configured OData format * @see #getDefaultPubFormat() */ - ODataFormat getDefaultFormat(); + ContentType getDefaultFormat(); /** * Gets the configured OData value format. If this configuration parameter doesn't exist the TEXT format will be used * as default. * * @return configured OData value format if specified; TEXT_PLAIN format otherwise. - * @see ODataFormat#TEXT_PLAIN */ - ODataFormat getDefaultValueFormat(); + ContentType getDefaultValueFormat(); /** * Sets the default OData value format. * * @param format default format. */ - void setDefaultValueFormat(ODataFormat format); + void setDefaultValueFormat(ContentType format); /** * Gets the configured OData media format. If this configuration parameter doesn't exist the APPLICATION_OCTET_STREAM @@ -90,14 +87,14 @@ public interface Configuration { * * @return configured OData media format if specified; APPLICATION_OCTET_STREAM format otherwise. */ - ODataFormat getDefaultMediaFormat(); + ContentType getDefaultMediaFormat(); /** * Sets the default OData media format. * * @param format default format. */ - void setDefaultMediaFormat(ODataFormat format); + void setDefaultMediaFormat(ContentType format); /** * Gets the HttpClient factory to be used for executing requests. diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClient.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClient.java index b8d58305e..842dcf663 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClient.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClient.java @@ -25,6 +25,7 @@ import org.apache.olingo.client.api.communication.request.batch.BatchRequestFact import org.apache.olingo.client.api.communication.request.cud.CUDRequestFactory; import org.apache.olingo.client.api.communication.request.invoke.InvokeRequestFactory; import org.apache.olingo.client.api.communication.request.retrieve.RetrieveRequestFactory; +import org.apache.olingo.client.api.domain.ClientObjectFactory; import org.apache.olingo.client.api.serialization.ClientODataDeserializer; import org.apache.olingo.client.api.serialization.ODataBinder; import org.apache.olingo.client.api.serialization.ODataReader; @@ -33,9 +34,9 @@ import org.apache.olingo.client.api.serialization.ODataWriter; import org.apache.olingo.client.api.uri.FilterFactory; import org.apache.olingo.client.api.uri.SearchFactory; import org.apache.olingo.client.api.uri.URIBuilder; -import org.apache.olingo.client.api.domain.ClientObjectFactory; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; + public interface ODataClient { @@ -47,13 +48,13 @@ public interface ODataClient { ODataPreferences newPreferences(); - ODataSerializer getSerializer(ODataFormat format); + ODataSerializer getSerializer(ContentType contentType); ODataWriter getWriter(); InvokeRequestFactory getInvokeRequestFactory(); - ClientODataDeserializer getDeserializer(ODataFormat format); + ClientODataDeserializer getDeserializer(ContentType contentType); ODataReader getReader(); diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClientBuilder.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClientBuilder.java index bd3cbdeae..99949776f 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClientBuilder.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/ODataClientBuilder.java @@ -18,12 +18,12 @@ */ package org.apache.olingo.client.api; -import org.apache.olingo.commons.api.edm.Edm; -import org.apache.olingo.commons.api.format.ODataFormat; - import java.lang.reflect.Constructor; import java.lang.reflect.InvocationTargetException; +import org.apache.olingo.commons.api.edm.Edm; +import org.apache.olingo.commons.api.format.ContentType; + /** *

* Builder to create an ODataClient for the API client library. @@ -142,7 +142,7 @@ public final class ODataClientBuilder { loadClass(EdmEnabledODataClient.class, clientImplClassName, new Class[] { String.class, Edm.class, String.class }, new Object[] { serviceRoot, edm, metadataETag }); - instance.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + instance.getConfiguration().setDefaultPubFormat(ContentType.JSON); return instance; } diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/ODataBasicRequest.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/ODataBasicRequest.java index 6bcb3b8ea..c977a0b48 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/ODataBasicRequest.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/ODataBasicRequest.java @@ -21,7 +21,7 @@ package org.apache.olingo.client.api.communication.request; import java.util.concurrent.Future; import org.apache.olingo.client.api.communication.response.ODataResponse; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; /** * Basic OData request. @@ -45,9 +45,9 @@ public interface ODataBasicRequest extends ODataRequest Future asyncExecute(); /** - * Override configured request format. + * Override configured request Content-Type. * - * @param format request format. + * @param contentType request Content-Type. */ - void setFormat(ODataFormat format); + void setFormat(ContentType contentType); } diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/streamed/ODataStreamedEntityRequest.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/streamed/ODataStreamedEntityRequest.java index a34e41c4b..0221285a3 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/streamed/ODataStreamedEntityRequest.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/communication/request/streamed/ODataStreamedEntityRequest.java @@ -21,7 +21,7 @@ package org.apache.olingo.client.api.communication.request.streamed; import org.apache.olingo.client.api.communication.request.ODataPayloadManager; import org.apache.olingo.client.api.communication.request.ODataStreamedRequest; import org.apache.olingo.client.api.communication.response.ODataResponse; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; /** * Abstract class representing a request concerning a streamed entity. @@ -38,13 +38,12 @@ public interface ODataStreamedEntityRequest= 0) { - jsonEntity = odataClient.getDeserializer(ODataFormat.JSON).toEntity( + jsonEntity = odataClient.getDeserializer(ContentType.JSON).toEntity( new ByteArrayInputStream(entity.toByteArray())); } } else { @@ -240,7 +240,7 @@ public class ClientEntitySetIterator".getBytes(Constants.UTF8)); if (consume(input, "", entity, true) >= 0) { - atomEntity = odataClient.getDeserializer(ODataFormat.ATOM). + atomEntity = odataClient.getDeserializer(ContentType.APPLICATION_ATOM_XML). toEntity(new ByteArrayInputStream(entity.toByteArray())); } } diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/domain/ClientPrimitiveValue.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/domain/ClientPrimitiveValue.java index 350efdbed..445af8435 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/domain/ClientPrimitiveValue.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/domain/ClientPrimitiveValue.java @@ -23,6 +23,7 @@ import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmType; +import java.math.BigDecimal; import java.util.UUID; public interface ClientPrimitiveValue extends ClientValue { @@ -54,6 +55,8 @@ public interface ClientPrimitiveValue extends ClientValue { ClientPrimitiveValue buildGuid(UUID value); ClientPrimitiveValue buildBinary(byte[] value); + + ClientPrimitiveValue buildDecimal(BigDecimal value); } EdmPrimitiveTypeKind getTypeKind(); diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataReader.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataReader.java index 4360cd848..07342ebd3 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataReader.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataReader.java @@ -21,15 +21,16 @@ package org.apache.olingo.client.api.serialization; import java.io.InputStream; import java.util.Map; -import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; -import org.apache.olingo.commons.api.ODataError; import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientServiceDocument; +import org.apache.olingo.commons.api.ODataError; +import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.provider.CsdlSchema; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; + /** * OData reader. @@ -60,51 +61,52 @@ public interface ODataReader { * Parses an OData service document. * * @param input stream to de-serialize. - * @param format de-serialize as XML or JSON + * @param contentType de-serialize as XML or JSON * @return List of URIs. * @throws ODataDeserializerException */ - ClientServiceDocument readServiceDocument(InputStream input, ODataFormat format) throws ODataDeserializerException; + ClientServiceDocument readServiceDocument(InputStream input, ContentType contentType) + throws ODataDeserializerException; /** * De-Serializes a stream into an OData entity set. * * @param input stream to de-serialize. - * @param format de-serialize format + * @param contentType de-serialize format * @return de-serialized entity set. * @throws ODataDeserializerException */ - ClientEntitySet readEntitySet(InputStream input, ODataFormat format) throws ODataDeserializerException; + ClientEntitySet readEntitySet(InputStream input, ContentType contentType) throws ODataDeserializerException; /** * Parses a stream taking care to de-serializes the first OData entity found. * * @param input stream to de-serialize. - * @param format de-serialize format + * @param contentType de-serialize format * @return entity de-serialized. * @throws ODataDeserializerException */ - ClientEntity readEntity(InputStream input, ODataFormat format) throws ODataDeserializerException; + ClientEntity readEntity(InputStream input, ContentType contentType) throws ODataDeserializerException; /** * Parses a stream taking care to de-serialize the first OData entity property found. * * @param input stream to de-serialize. - * @param format de-serialize as XML or JSON + * @param contentType de-serialize as XML or JSON * @return OData entity property de-serialized. * @throws ODataDeserializerException */ - ClientProperty readProperty(InputStream input, ODataFormat format) throws ODataDeserializerException; + ClientProperty readProperty(InputStream input, ContentType contentType) throws ODataDeserializerException; /** * Parses a stream into an OData error. * * @param inputStream stream to de-serialize. - * @param format format + * @param contentType format * @return OData error. * @throws ODataDeserializerException */ - ODataError readError(InputStream inputStream, ODataFormat format) throws ODataDeserializerException; + ODataError readError(InputStream inputStream, ContentType contentType) throws ODataDeserializerException; /** * Parses a stream into the object type specified by the given reference. diff --git a/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataWriter.java b/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataWriter.java index 7b5dc5b76..1a6d65a6e 100644 --- a/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataWriter.java +++ b/lib/client-api/src/main/java/org/apache/olingo/client/api/serialization/ODataWriter.java @@ -22,11 +22,11 @@ import java.io.InputStream; import java.net.URI; import java.util.Collection; -import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.client.api.domain.ClientEntity; -import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientLink; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.client.api.domain.ClientProperty; +import org.apache.olingo.commons.api.data.ResWrap; +import org.apache.olingo.commons.api.format.ContentType; /** * OData writer. @@ -41,54 +41,54 @@ public interface ODataWriter { * Writes a collection of OData entities. * * @param entities entities to be serialized. - * @param format serialization format. + * @param contentType serialization format. * @return stream of serialized objects. * @throws ODataSerializerException */ - InputStream writeEntities(Collection entities, ODataFormat format) + InputStream writeEntities(Collection entities, ContentType contentType) throws ODataSerializerException; /** * Serializes a single OData entity. * * @param entity entity to be serialized. - * @param format serialization format. + * @param contentType serialization format. * @return stream of serialized object. * @throws ODataSerializerException */ - InputStream writeEntity(ClientEntity entity, ODataFormat format) + InputStream writeEntity(ClientEntity entity, ContentType format) throws ODataSerializerException; /** * Writes a single OData entity property. * * @param property entity property to be serialized. - * @param format serialization format. + * @param contentType serialization format. * @return stream of serialized object. * @throws ODataSerializerException */ - InputStream writeProperty(ClientProperty property, ODataFormat format) + InputStream writeProperty(ClientProperty property, ContentType format) throws ODataSerializerException; /** * Writes an OData link. * * @param link link to be serialized. - * @param format serialization format. + * @param contentType serialization format. * @return stream of serialized object. * @throws ODataSerializerException */ - InputStream writeLink(ClientLink link, ODataFormat format) + InputStream writeLink(ClientLink link, ContentType format) throws ODataSerializerException; /** * Writes a entity reference * * @param reference reference to be serialized - * @param format serialization format + * @param contentType serialization format * @return stream of serialized objects * @throws ODataSerializerException */ - InputStream writeReference(ResWrap reference, ODataFormat format) + InputStream writeReference(ResWrap reference, ContentType format) throws ODataSerializerException; } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/ConfigurationImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/ConfigurationImpl.java index cd17ad0d4..14c59d6e8 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/ConfigurationImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/ConfigurationImpl.java @@ -29,7 +29,6 @@ import org.apache.olingo.client.api.http.HttpUriRequestFactory; import org.apache.olingo.client.core.http.DefaultHttpClientFactory; import org.apache.olingo.client.core.http.DefaultHttpUriRequestFactory; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; public class ConfigurationImpl implements Configuration { @@ -96,39 +95,39 @@ public class ConfigurationImpl implements Configuration { } @Override - public ODataFormat getDefaultPubFormat() { - return (ODataFormat) getProperty(DEFAULT_PUB_FORMAT, ODataFormat.JSON_FULL_METADATA); + public ContentType getDefaultPubFormat() { + return (ContentType) getProperty(DEFAULT_PUB_FORMAT, ContentType.JSON_FULL_METADATA); } @Override - public void setDefaultPubFormat(final ODataFormat format) { - setProperty(DEFAULT_PUB_FORMAT, format); + public void setDefaultPubFormat(final ContentType contentType) { + setProperty(DEFAULT_PUB_FORMAT, contentType); } @Override - public ODataFormat getDefaultFormat() { - final ODataFormat format = getDefaultPubFormat(); - return format == ODataFormat.ATOM ? ODataFormat.XML : format; + public ContentType getDefaultFormat() { + final ContentType contenType = getDefaultPubFormat(); + return contenType == ContentType.APPLICATION_ATOM_XML ? ContentType.APPLICATION_XML : contenType; } @Override - public ODataFormat getDefaultValueFormat() { - return (ODataFormat) getProperty(DEFAULT_VALUE_FORMAT, ODataFormat.TEXT_PLAIN); + public ContentType getDefaultValueFormat() { + return (ContentType) getProperty(DEFAULT_VALUE_FORMAT, ContentType.TEXT_PLAIN); } @Override - public void setDefaultValueFormat(final ODataFormat format) { - setProperty(DEFAULT_VALUE_FORMAT, format); + public void setDefaultValueFormat(final ContentType contentType) { + setProperty(DEFAULT_VALUE_FORMAT, contentType); } @Override - public ODataFormat getDefaultMediaFormat() { - return (ODataFormat) getProperty(DEFAULT_VALUE_FORMAT, ODataFormat.APPLICATION_OCTET_STREAM); + public ContentType getDefaultMediaFormat() { + return (ContentType) getProperty(DEFAULT_VALUE_FORMAT, ContentType.APPLICATION_OCTET_STREAM); } @Override - public void setDefaultMediaFormat(final ODataFormat format) { - setProperty(DEFAULT_MEDIA_FORMAT, format); + public void setDefaultMediaFormat(final ContentType contentType) { + setProperty(DEFAULT_MEDIA_FORMAT, contentType); } @Override diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientFactory.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientFactory.java index b9f18a89c..d8b54e993 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientFactory.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientFactory.java @@ -21,7 +21,7 @@ package org.apache.olingo.client.core; import org.apache.olingo.client.api.EdmEnabledODataClient; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.commons.api.edm.Edm; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; public final class ODataClientFactory { @@ -38,7 +38,7 @@ public final class ODataClientFactory { final EdmEnabledODataClient instance = new EdmEnabledODataClientImpl(serviceRoot, edm, metadataETag); - instance.getConfiguration().setDefaultPubFormat(ODataFormat.JSON); + instance.getConfiguration().setDefaultPubFormat(ContentType.JSON); return instance; } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientImpl.java index c490daeaa..b00d3a88e 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/ODataClientImpl.java @@ -28,6 +28,7 @@ import org.apache.olingo.client.api.communication.request.batch.BatchRequestFact import org.apache.olingo.client.api.communication.request.cud.CUDRequestFactory; import org.apache.olingo.client.api.communication.request.invoke.InvokeRequestFactory; import org.apache.olingo.client.api.communication.request.retrieve.RetrieveRequestFactory; +import org.apache.olingo.client.api.domain.ClientObjectFactory; import org.apache.olingo.client.api.serialization.ClientODataDeserializer; import org.apache.olingo.client.api.serialization.ODataBinder; import org.apache.olingo.client.api.serialization.ODataReader; @@ -42,6 +43,7 @@ import org.apache.olingo.client.core.communication.request.batch.BatchRequestFac import org.apache.olingo.client.core.communication.request.cud.CUDRequestFactoryImpl; import org.apache.olingo.client.core.communication.request.invoke.InvokeRequestFactoryImpl; import org.apache.olingo.client.core.communication.request.retrieve.RetrieveRequestFactoryImpl; +import org.apache.olingo.client.core.domain.ClientObjectFactoryImpl; import org.apache.olingo.client.core.serialization.AtomSerializer; import org.apache.olingo.client.core.serialization.ClientODataDeserializerImpl; import org.apache.olingo.client.core.serialization.JsonSerializer; @@ -50,10 +52,8 @@ import org.apache.olingo.client.core.serialization.ODataReaderImpl; import org.apache.olingo.client.core.serialization.ODataWriterImpl; import org.apache.olingo.client.core.uri.FilterFactoryImpl; import org.apache.olingo.client.core.uri.URIBuilderImpl; -import org.apache.olingo.client.api.domain.ClientObjectFactory; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.apache.olingo.client.core.domain.ClientObjectFactoryImpl; +import org.apache.olingo.commons.api.format.ContentType; public class ODataClientImpl implements ODataClient { @@ -125,15 +125,16 @@ public class ODataClientImpl implements ODataClient { } @Override - public ClientODataDeserializer getDeserializer(final ODataFormat format) { - return new ClientODataDeserializerImpl(false, format); + public ClientODataDeserializer getDeserializer(final ContentType contentType) { + return new ClientODataDeserializerImpl(false, contentType); } @Override - public ODataSerializer getSerializer(final ODataFormat format) { - return format == ODataFormat.ATOM || format == ODataFormat.XML ? - new AtomSerializer() : - new JsonSerializer(false, format); + public ODataSerializer getSerializer(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC, ContentType.APPLICATION_ATOM_XML, + ContentType.APPLICATION_XML) ? + new AtomSerializer() : new JsonSerializer(false, contentType); + } @Override diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/header/ODataErrorResponseChecker.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/header/ODataErrorResponseChecker.java index e359e2990..53f35d5e9 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/header/ODataErrorResponseChecker.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/header/ODataErrorResponseChecker.java @@ -1,18 +1,18 @@ /* * Licensed to the Apache Software Foundation (ASF) under one - * or more contributor license agreements. See the NOTICE file + * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information - * regarding copyright ownership. The ASF licenses this file + * 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 - * + * 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 + * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ @@ -24,10 +24,11 @@ import org.apache.http.StatusLine; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.ODataClientErrorException; import org.apache.olingo.client.api.communication.ODataServerErrorException; -import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.commons.api.ODataRuntimeException; import org.apache.olingo.commons.api.ODataError; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.ODataRuntimeException; +import org.apache.olingo.commons.api.format.ContentType; +import org.apache.olingo.client.api.serialization.ODataDeserializerException; + import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -43,29 +44,29 @@ public final class ODataErrorResponseChecker { } public static ODataRuntimeException checkResponse( - final ODataClient odataClient, final StatusLine statusLine, final InputStream entity, - final String accept) { + final ODataClient odataClient, final StatusLine statusLine, final InputStream entity, + final String accept) { ODataRuntimeException result = null; if (entity == null) { result = new ODataClientErrorException(statusLine); } else { - final ODataFormat format = accept.contains("xml") ? ODataFormat.XML : ODataFormat.JSON; + final ContentType contentType = accept.contains("xml") ? ContentType.APPLICATION_ATOM_XML : ContentType.JSON; ODataError error; try { - error = odataClient.getReader().readError(entity, format); + error = odataClient.getReader().readError(entity, contentType); } catch (final RuntimeException e) { LOG.warn("Error deserializing error response", e); error = getGenericError( - statusLine.getStatusCode(), - statusLine.getReasonPhrase()); + statusLine.getStatusCode(), + statusLine.getReasonPhrase()); } catch (final ODataDeserializerException e) { LOG.warn("Error deserializing error response", e); error = getGenericError( - statusLine.getStatusCode(), - statusLine.getReasonPhrase()); + statusLine.getStatusCode(), + statusLine.getReasonPhrase()); } if (statusLine.getStatusCode() >= 500) { diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataBasicRequest.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataBasicRequest.java index c5c313cac..7a5346829 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataBasicRequest.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataBasicRequest.java @@ -32,7 +32,7 @@ import org.apache.olingo.client.api.communication.request.ODataBasicRequest; import org.apache.olingo.client.api.communication.request.ODataStreamer; import org.apache.olingo.client.api.communication.request.batch.ODataBatchRequest; import org.apache.olingo.client.api.communication.response.ODataResponse; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -55,9 +55,9 @@ public abstract class AbstractODataBasicRequest } @Override - public void setFormat(final ODataFormat format) { - if (format != null) { - final String formatString = format.getContentType().toContentTypeString(); + public void setFormat(final ContentType contentType) { + if (contentType != null) { + final String formatString = contentType.toContentTypeString(); setAccept(formatString); setContentType(formatString); } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataRequest.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataRequest.java index bdfd11831..4037a6f41 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataRequest.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/AbstractODataRequest.java @@ -41,7 +41,7 @@ import org.apache.olingo.client.api.communication.request.ODataStreamer; import org.apache.olingo.client.api.communication.response.ODataResponse; import org.apache.olingo.client.api.http.HttpClientException; import org.apache.olingo.commons.api.ODataRuntimeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -102,7 +102,7 @@ public abstract class AbstractODataRequest extends AbstractRequest implements OD this.request = odataClient.getConfiguration().getHttpUriRequestFactory().create(this.method, uri); } - public abstract ODataFormat getDefaultFormat(); + public abstract ContentType getDefaultFormat(); @Override public URI getURI() { @@ -178,7 +178,7 @@ public abstract class AbstractODataRequest extends AbstractRequest implements OD public String getAccept() { final String acceptHead = odataHeaders.getHeader(HeaderName.accept); return StringUtils.isBlank(acceptHead) - ? getDefaultFormat().getContentType().toContentTypeString() + ? getDefaultFormat().toContentTypeString() : acceptHead; } @@ -201,7 +201,7 @@ public abstract class AbstractODataRequest extends AbstractRequest implements OD public String getContentType() { final String contentTypeHead = odataHeaders.getHeader(HeaderName.contentType); return StringUtils.isBlank(contentTypeHead) - ? getDefaultFormat().getContentType().toContentTypeString() + ? getDefaultFormat().toContentTypeString() : contentTypeHead; } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataDeleteRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataDeleteRequestImpl.java index 35f51185a..245c9b548 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataDeleteRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataDeleteRequestImpl.java @@ -28,7 +28,7 @@ import org.apache.olingo.client.api.communication.request.cud.ODataDeleteRequest import org.apache.olingo.client.api.communication.response.ODataDeleteResponse; import org.apache.olingo.client.core.communication.request.AbstractODataBasicRequest; import org.apache.olingo.client.core.communication.response.AbstractODataResponse; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -42,7 +42,7 @@ public class ODataDeleteRequestImpl extends AbstractODataBasicRequest } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultPubFormat(); } @Override protected InputStream getPayload() { try { - return odataClient.getWriter().writeEntity(entity, ODataFormat.fromString(getContentType())); + return odataClient.getWriter().writeEntity(entity, ContentType.parse(getContentType())); } catch (final ODataSerializerException e) { throw new IllegalArgumentException(e); } @@ -112,7 +112,7 @@ public class ODataEntityCreateRequestImpl public E getBody() { if (resEntity == null) { try { - final ResWrap resource = odataClient.getDeserializer(ODataFormat.fromString(getAccept())). + final ResWrap resource = odataClient.getDeserializer(ContentType.parse(getAccept())). toEntity(getRawResponse()); resEntity = (E) odataClient.getBinder().getODataEntity(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataEntityUpdateRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataEntityUpdateRequestImpl.java index 44ff4715e..8a40e33dc 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataEntityUpdateRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataEntityUpdateRequestImpl.java @@ -29,15 +29,15 @@ import org.apache.http.client.methods.HttpEntityEnclosingRequestBase; import org.apache.olingo.client.api.ODataClient; 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.domain.ClientEntity; import org.apache.olingo.client.core.communication.request.AbstractODataBasicRequest; import org.apache.olingo.client.core.communication.response.AbstractODataResponse; import org.apache.olingo.client.core.uri.URIUtils; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientEntity; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.client.api.serialization.ODataSerializerException; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -70,14 +70,14 @@ public class ODataEntityUpdateRequestImpl } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultPubFormat(); } @Override protected InputStream getPayload() { try { - return odataClient.getWriter().writeEntity(changes, ODataFormat.fromString(getContentType())); + return odataClient.getWriter().writeEntity(changes, ContentType.parse(getContentType())); } catch (final ODataSerializerException e) { throw new IllegalArgumentException(e); } @@ -122,7 +122,7 @@ public class ODataEntityUpdateRequestImpl public E getBody() { if (entity == null) { try { - final ResWrap resource = odataClient.getDeserializer(ODataFormat.fromString(getAccept())). + final ResWrap resource = odataClient.getDeserializer(ContentType.parse(getAccept())). toEntity(getRawResponse()); entity = (E) odataClient.getBinder().getODataEntity(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataPropertyUpdateRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataPropertyUpdateRequestImpl.java index 33ec73afa..038feeb26 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataPropertyUpdateRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataPropertyUpdateRequestImpl.java @@ -28,15 +28,15 @@ import org.apache.http.client.methods.HttpEntityEnclosingRequestBase; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.cud.ODataPropertyUpdateRequest; import org.apache.olingo.client.api.communication.response.ODataPropertyUpdateResponse; +import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.core.communication.request.AbstractODataBasicRequest; import org.apache.olingo.client.core.communication.response.AbstractODataResponse; import org.apache.olingo.client.core.uri.URIUtils; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientProperty; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.client.api.serialization.ODataSerializerException; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -67,7 +67,7 @@ public class ODataPropertyUpdateRequestImpl extends AbstractODataBasicRequest resource = odataClient.getDeserializer(ODataFormat.fromString(getAccept())). + final ResWrap resource = odataClient.getDeserializer(ContentType.parse(getAccept())). toProperty(getRawResponse()); resProperty = odataClient.getBinder().getODataProperty(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataReferenceAddingRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataReferenceAddingRequestImpl.java index 933f22307..640b5cf73 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataReferenceAddingRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/cud/ODataReferenceAddingRequestImpl.java @@ -34,7 +34,7 @@ import org.apache.olingo.client.core.communication.request.AbstractODataBasicReq import org.apache.olingo.client.core.communication.response.AbstractODataResponse; import org.apache.olingo.client.core.uri.URIUtils; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -54,7 +54,7 @@ public class ODataReferenceAddingRequestImpl extends AbstractODataBasicRequest } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultPubFormat(); } - private String getActualFormat(final ODataFormat format) { - return ((ClientProperty.class.isAssignableFrom(reference) && format == ODataFormat.ATOM) - ? ODataFormat.XML : format).getContentType().toContentTypeString(); + private String getActualFormat(final ContentType contentType) { + return ((ClientProperty.class.isAssignableFrom(reference) + && contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC, ContentType.APPLICATION_ATOM_XML)) + ? ContentType.APPLICATION_XML : contentType).toContentTypeString(); } @Override - public void setFormat(final ODataFormat format) { - final String _format = getActualFormat(format); - setAccept(_format); - setContentType(_format); + public void setFormat(final ContentType contentType) { + final String _contentType = getActualFormat(contentType); + setAccept(_contentType); + setContentType(_contentType); } - protected abstract ODataFormat getPOSTParameterFormat(); + protected abstract ContentType getPOSTParameterFormat(); @Override protected InputStream getPayload() { @@ -197,13 +198,13 @@ public abstract class AbstractODataInvokeRequest final InputStream responseStream = this.payload == null ? res.getEntity().getContent() : this.payload; if (ClientEntitySet.class.isAssignableFrom(reference)) { invokeResult = reference.cast(odataClient.getReader().readEntitySet(responseStream, - ODataFormat.fromString(getContentType()))); + ContentType.parse(getContentType()))); } else if (ClientEntity.class.isAssignableFrom(reference)) { invokeResult = reference.cast(odataClient.getReader().readEntity(responseStream, - ODataFormat.fromString(getContentType()))); + ContentType.parse(getContentType()))); } else if (ClientProperty.class.isAssignableFrom(reference)) { invokeResult = reference.cast(odataClient.getReader().readProperty(responseStream, - ODataFormat.fromString(getContentType()))); + ContentType.parse(getContentType()))); } } } catch (IOException e) { diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/invoke/ODataInvokeRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/invoke/ODataInvokeRequestImpl.java index 5e8736e9b..6d6cc01e5 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/invoke/ODataInvokeRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/invoke/ODataInvokeRequestImpl.java @@ -22,12 +22,12 @@ import java.net.URI; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.domain.ClientInvokeResult; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; public class ODataInvokeRequestImpl extends AbstractODataInvokeRequest { - private ODataFormat format; + private ContentType contentType; public ODataInvokeRequestImpl(final ODataClient odataClient, final Class reference, final HttpMethod method, final URI uri) { @@ -36,13 +36,13 @@ public class ODataInvokeRequestImpl extends Abstra } @Override - public void setFormat(final ODataFormat format) { - super.setFormat(format); - this.format = format; + public void setFormat(final ContentType contentType) { + super.setFormat(contentType); + this.contentType = contentType; } @Override - protected ODataFormat getPOSTParameterFormat() { - return format == null ? getDefaultFormat() : format; + protected ContentType getPOSTParameterFormat() { + return contentType == null ? getDefaultFormat() : contentType; } } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/AbstractMetadataRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/AbstractMetadataRequestImpl.java index 3cdd34963..201a662c5 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/AbstractMetadataRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/AbstractMetadataRequestImpl.java @@ -23,7 +23,6 @@ import java.net.URI; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.ODataRequest; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; public abstract class AbstractMetadataRequestImpl extends AbstractODataRetrieveRequest { @@ -34,8 +33,8 @@ public abstract class AbstractMetadataRequestImpl extends AbstractODataRetrie } @Override - public ODataFormat getDefaultFormat() { - return ODataFormat.XML; + public ContentType getDefaultFormat() { + return ContentType.APPLICATION_XML; } @Override diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataDeltaRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataDeltaRequestImpl.java index 5eb4d845b..1cd69706f 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataDeltaRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataDeltaRequestImpl.java @@ -26,12 +26,12 @@ import org.apache.http.client.HttpClient; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataDeltaRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; +import org.apache.olingo.client.api.domain.ClientDelta; import org.apache.olingo.client.api.http.HttpClientException; import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.commons.api.data.Delta; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientDelta; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; public class ODataDeltaRequestImpl extends AbstractODataRetrieveRequest implements ODataDeltaRequest { @@ -41,7 +41,7 @@ public class ODataDeltaRequestImpl extends AbstractODataRetrieveRequest resource = odataClient.getDeserializer(ODataFormat.fromString(getContentType())). + final ResWrap resource = odataClient.getDeserializer(ContentType.parse(getContentType())). toDelta(res.getEntity().getContent()); delta = odataClient.getBinder().getODataDelta(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntityRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntityRequestImpl.java index d5a224f73..dec56b0c4 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntityRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntityRequestImpl.java @@ -25,11 +25,11 @@ import org.apache.http.client.HttpClient; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataEntityRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; +import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientEntity; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.commons.api.format.ODataFormat; /** * This class implements an OData retrieve query request returning a single entity. @@ -48,7 +48,7 @@ public class ODataEntityRequestImpl } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultPubFormat(); } @@ -75,7 +75,7 @@ public class ODataEntityRequestImpl public E getBody() { if (entity == null) { try { - final ResWrap resource = odataClient.getDeserializer(ODataFormat.fromString(getContentType())). + final ResWrap resource = odataClient.getDeserializer(ContentType.parse(getContentType())). toEntity(getRawResponse()); entity = (E) odataClient.getBinder().getODataEntity(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetIteratorRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetIteratorRequestImpl.java index dcb31e9c5..db390a0df 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetIteratorRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetIteratorRequestImpl.java @@ -25,10 +25,10 @@ import org.apache.http.client.HttpClient; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataEntitySetIteratorRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; -import org.apache.olingo.client.api.domain.ClientEntitySetIterator; import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntitySet; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.client.api.domain.ClientEntitySetIterator; +import org.apache.olingo.commons.api.format.ContentType; /** * This class implements an OData EntitySet query request. @@ -50,7 +50,7 @@ public class ODataEntitySetIteratorRequestImpl getBody() { if (entitySetIterator == null) { entitySetIterator = new ClientEntitySetIterator( - odataClient, getRawResponse(), ODataFormat.fromString(getContentType())); + odataClient, getRawResponse(), ContentType.parse(getContentType())); } return entitySetIterator; } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetRequestImpl.java index 7e0164b44..a49dd32aa 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataEntitySetRequestImpl.java @@ -25,11 +25,11 @@ import org.apache.http.client.HttpClient; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataEntitySetRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; +import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientEntitySet; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.commons.api.format.ODataFormat; /** * This class implements an OData EntitySet query request. @@ -52,7 +52,7 @@ public class ODataEntitySetRequestImpl } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultPubFormat(); } @@ -79,7 +79,7 @@ public class ODataEntitySetRequestImpl if (entitySet == null) { try { final ResWrap resource = - odataClient.getDeserializer(ODataFormat.fromString(getContentType())). + odataClient.getDeserializer(ContentType.parse(getContentType())). toEntitySet(getRawResponse()); entitySet = (ES) odataClient.getBinder().getODataEntitySet(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataMediaRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataMediaRequestImpl.java index 7c7c34c1f..3f32f1b2c 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataMediaRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataMediaRequestImpl.java @@ -28,7 +28,7 @@ import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataMediaRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.http.HttpClientException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; /** * This class implements an OData media query request. @@ -44,12 +44,12 @@ public class ODataMediaRequestImpl extends AbstractODataRetrieveRequest } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultFormat(); } @@ -75,7 +75,7 @@ public class ODataPropertyRequestImpl public T getBody() { if (property == null) { try { - final ResWrap resource = odataClient.getDeserializer(ODataFormat.fromString(getContentType())) + final ResWrap resource = odataClient.getDeserializer(ContentType.parse(getContentType())) .toProperty(res.getEntity().getContent()); property = (T) odataClient.getBinder().getODataProperty(resource); diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataRawRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataRawRequestImpl.java index c29e7ee69..79c3e149e 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataRawRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataRawRequestImpl.java @@ -32,7 +32,7 @@ import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.client.core.communication.request.AbstractODataRequest; import org.apache.olingo.client.core.communication.response.AbstractODataResponse; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.api.http.HttpMethod; /** @@ -51,7 +51,7 @@ public class ODataRawRequestImpl extends AbstractODataRequest implements ODataRa } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultPubFormat(); } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataServiceDocumentRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataServiceDocumentRequestImpl.java index b4888f488..d0b6b1faf 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataServiceDocumentRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataServiceDocumentRequestImpl.java @@ -26,10 +26,10 @@ import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataServiceDocumentRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.data.ServiceDocument; -import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.client.api.domain.ClientServiceDocument; +import org.apache.olingo.commons.api.data.ResWrap; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.commons.api.format.ODataFormat; /** * This class implements an OData service document request. @@ -48,7 +48,7 @@ public class ODataServiceDocumentRequestImpl extends AbstractODataRetrieveReques } @Override - public ODataFormat getDefaultFormat() { + public ContentType getDefaultFormat() { return odataClient.getConfiguration().getDefaultFormat(); } @@ -76,7 +76,7 @@ public class ODataServiceDocumentRequestImpl extends AbstractODataRetrieveReques if (serviceDocument == null) { try { final ResWrap resource = odataClient. - getDeserializer(ODataFormat.fromString(getContentType())).toServiceDocument(getRawResponse()); + getDeserializer(ContentType.parse(getContentType())).toServiceDocument(getRawResponse()); serviceDocument = odataClient.getBinder().getODataServiceDocument(resource.getPayload()); } catch (final ODataDeserializerException e) { diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataValueRequestImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataValueRequestImpl.java index 9bbce7c7f..e2161d4bf 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataValueRequestImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/communication/request/retrieve/ODataValueRequestImpl.java @@ -26,10 +26,10 @@ import org.apache.http.client.HttpClient; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.communication.request.retrieve.ODataValueRequest; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; -import org.apache.olingo.client.api.http.HttpClientException; import org.apache.olingo.client.api.domain.ClientPrimitiveValue; +import org.apache.olingo.client.api.http.HttpClientException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; /** * This class implements an OData entity property value query request. @@ -48,7 +48,7 @@ public class ODataValueRequestImpl extends AbstractODataRetrieveRequest implements ODataStreamedEntityRequest { - private ODataFormat format; + private ContentType contentType; /** * Constructor. @@ -50,17 +50,17 @@ public abstract class AbstractODataStreamedEntityRequest toServiceDocument(final InputStream input) throws ODataDeserializerException { - return format == ODataFormat.XML ? + return contentType.isCompatible(ContentType.APPLICATION_XML) ? new XMLServiceDocumentDeserializer(false).toServiceDocument(input) : new JSONServiceDocumentDeserializer(false).toServiceDocument(input); } @@ -127,7 +127,7 @@ public class ClientODataDeserializerImpl implements ClientODataDeserializer { @Override public ResWrap toDelta(final InputStream input) throws ODataDeserializerException { try { - return format == ODataFormat.ATOM ? + return contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC, ContentType.APPLICATION_ATOM_XML) ? new AtomDeserializer().delta(input) : new JsonDeltaDeserializer(false).toDelta(input); } catch (XMLStreamException e) { diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySerializer.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySerializer.java index 9f2056dde..75c7feb4b 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySerializer.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySerializer.java @@ -29,7 +29,7 @@ import org.apache.olingo.commons.api.data.Operation; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmTypeInfo; import com.fasterxml.jackson.core.JsonGenerator; @@ -39,12 +39,8 @@ import com.fasterxml.jackson.core.JsonGenerator; */ public class JsonEntitySerializer extends JsonSerializer { - public JsonEntitySerializer(final boolean serverMode) { - super(serverMode); - } - - public JsonEntitySerializer(final boolean serverMode, final ODataFormat format) { - super(serverMode, format); + public JsonEntitySerializer(final boolean serverMode, final ContentType contentType) { + super(serverMode, contentType); } protected void doSerialize(final Entity entity, final JsonGenerator jgen) @@ -73,12 +69,12 @@ public class JsonEntitySerializer extends JsonSerializer { } } - if (StringUtils.isNotBlank(entity.getType()) && format != ODataFormat.JSON_NO_METADATA) { + if (StringUtils.isNotBlank(entity.getType()) && !isODataMetadataNone(contentType)) { jgen.writeStringField(Constants.JSON_TYPE, new EdmTypeInfo.Builder().setTypeExpression(entity.getType()).build().external()); } - if (entity.getId() != null && format != ODataFormat.JSON_NO_METADATA) { + if (entity.getId() != null && !isODataMetadataNone(contentType)) { jgen.writeStringField(Constants.JSON_ID, entity.getId().toASCIIString()); } @@ -100,7 +96,7 @@ public class JsonEntitySerializer extends JsonSerializer { } } - if (format != ODataFormat.JSON_NO_METADATA) { + if (!isODataMetadataNone(contentType)) { links(entity, jgen); } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySetSerializer.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySetSerializer.java index 6bcf82227..edb92d212 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySetSerializer.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonEntitySetSerializer.java @@ -27,13 +27,14 @@ import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; +import org.apache.olingo.commons.api.format.ContentType; import com.fasterxml.jackson.core.JsonGenerator; public class JsonEntitySetSerializer extends JsonSerializer { - public JsonEntitySetSerializer(final boolean serverMode) { - super(serverMode); + public JsonEntitySetSerializer(final boolean serverMode, final ContentType contentType) { + super(serverMode, contentType); } protected void doSerialize(final EntityCollection entitySet, final JsonGenerator jgen) @@ -81,7 +82,7 @@ public class JsonEntitySetSerializer extends JsonSerializer { } jgen.writeArrayFieldStart(Constants.VALUE); - final JsonEntitySerializer entitySerializer = new JsonEntitySerializer(serverMode); + final JsonEntitySerializer entitySerializer = new JsonEntitySerializer(serverMode, contentType); for (Entity entity : entitySet.getEntities()) { entitySerializer.doSerialize(entity, jgen); } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonPropertySerializer.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonPropertySerializer.java index 11c6821ce..9911d4983 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonPropertySerializer.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonPropertySerializer.java @@ -27,6 +27,7 @@ import org.apache.olingo.commons.api.data.Annotation; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmTypeInfo; import com.fasterxml.jackson.core.JsonGenerator; @@ -36,8 +37,8 @@ import com.fasterxml.jackson.core.JsonGenerator; */ public class JsonPropertySerializer extends JsonSerializer { - public JsonPropertySerializer(final boolean serverMode) { - super(serverMode); + public JsonPropertySerializer(final boolean serverMode, final ContentType contentType) { + super(serverMode, contentType); } protected void doSerialize(final Property property, final JsonGenerator jgen) diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonSerializer.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonSerializer.java old mode 100644 new mode 100755 index 484bbfab5..d095793a6 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonSerializer.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/JsonSerializer.java @@ -45,7 +45,7 @@ import org.apache.olingo.commons.api.data.ValueType; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.geo.Geospatial; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmTypeInfo; import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; @@ -64,16 +64,13 @@ public class JsonSerializer implements ODataSerializer { private final JsonGeoValueSerializer geoSerializer = new JsonGeoValueSerializer(); protected boolean serverMode; + protected final boolean isIEEE754Compatible; + protected ContentType contentType; - protected ODataFormat format; - - public JsonSerializer(final boolean serverMode) { - this(serverMode, ODataFormat.JSON_FULL_METADATA); - } - - public JsonSerializer(final boolean serverMode, final ODataFormat format) { + public JsonSerializer(final boolean serverMode, final ContentType contentType) { this.serverMode = serverMode; - this.format = format; + this.contentType = contentType; + this.isIEEE754Compatible = isIEEE754Compatible(); } @Override @@ -81,11 +78,11 @@ public class JsonSerializer implements ODataSerializer { try { final JsonGenerator json = new JsonFactory().createGenerator(writer); if (obj instanceof EntityCollection) { - new JsonEntitySetSerializer(serverMode).doSerialize((EntityCollection) obj, json); + new JsonEntitySetSerializer(serverMode, contentType).doSerialize((EntityCollection) obj, json); } else if (obj instanceof Entity) { - new JsonEntitySerializer(serverMode, format).doSerialize((Entity) obj, json); + new JsonEntitySerializer(serverMode, contentType).doSerialize((Entity) obj, json); } else if (obj instanceof Property) { - new JsonPropertySerializer(serverMode).doSerialize((Property) obj, json); + new JsonPropertySerializer(serverMode, contentType).doSerialize((Property) obj, json); } else if (obj instanceof Link) { link((Link) obj, json); } @@ -113,11 +110,12 @@ public class JsonSerializer implements ODataSerializer { try { final JsonGenerator json = new JsonFactory().createGenerator(writer); if (obj instanceof EntityCollection) { - new JsonEntitySetSerializer(serverMode).doContainerSerialize((ResWrap) container, json); + new JsonEntitySetSerializer(serverMode, contentType).doContainerSerialize( + (ResWrap) container, json); } else if (obj instanceof Entity) { - new JsonEntitySerializer(serverMode).doContainerSerialize((ResWrap) container, json); + new JsonEntitySerializer(serverMode, contentType).doContainerSerialize((ResWrap) container, json); } else if (obj instanceof Property) { - new JsonPropertySerializer(serverMode).doContainerSerialize((ResWrap) container, json); + new JsonPropertySerializer(serverMode, contentType).doContainerSerialize((ResWrap) container, json); } else if (obj instanceof Link) { link((Link) obj, json); } else if (obj instanceof URI) { @@ -175,10 +173,10 @@ public class JsonSerializer implements ODataSerializer { if (link.getInlineEntity() != null) { jgen.writeFieldName(link.getTitle()); - new JsonEntitySerializer(serverMode).doSerialize(link.getInlineEntity(), jgen); + new JsonEntitySerializer(serverMode, contentType).doSerialize(link.getInlineEntity(), jgen); } else if (link.getInlineEntitySet() != null) { jgen.writeArrayFieldStart(link.getTitle()); - final JsonEntitySerializer entitySerializer = new JsonEntitySerializer(serverMode); + final JsonEntitySerializer entitySerializer = new JsonEntitySerializer(serverMode, contentType); for (Entity subEntry : link.getInlineEntitySet().getEntities()) { entitySerializer.doSerialize(subEntry, jgen); } @@ -233,10 +231,10 @@ public class JsonSerializer implements ODataSerializer { if (link.getInlineEntity() != null) { jgen.writeFieldName(link.getTitle()); - new JsonEntitySerializer(serverMode).doSerialize(link.getInlineEntity(), jgen); + new JsonEntitySerializer(serverMode, contentType).doSerialize(link.getInlineEntity(), jgen); } else if (link.getInlineEntitySet() != null) { jgen.writeArrayFieldStart(link.getTitle()); - JsonEntitySerializer entitySerializer = new JsonEntitySerializer(serverMode); + JsonEntitySerializer entitySerializer = new JsonEntitySerializer(serverMode, contentType); for (Entity subEntry : link.getInlineEntitySet().getEntities()) { entitySerializer.doSerialize(subEntry, jgen); } @@ -294,12 +292,15 @@ public class JsonSerializer implements ODataSerializer { } else if (isBoolean) { jgen.writeBoolean((Boolean) value); } else { - final String serialized = kind == null + String serialized = kind == null ? value.toString() // TODO: add facets : EdmPrimitiveTypeFactory.getInstance(kind). valueToString(value, null, null, Constants.DEFAULT_PRECISION, Constants.DEFAULT_SCALE, null); - if (isNumber) { + + if(isIEEE754Compatible && (kind == EdmPrimitiveTypeKind.Int64 || kind == EdmPrimitiveTypeKind.Decimal)) { + jgen.writeString(serialized); + } else if(isNumber) { jgen.writeNumber(serialized); } else { jgen.writeString(serialized); @@ -312,7 +313,7 @@ public class JsonSerializer implements ODataSerializer { throws IOException, EdmPrimitiveTypeException { jgen.writeStartObject(); - if (typeInfo != null && format != ODataFormat.JSON_NO_METADATA) { + if (typeInfo != null && !isODataMetadataNone(contentType)) { jgen.writeStringField(Constants.JSON_TYPE, typeInfo.external()); } @@ -359,7 +360,7 @@ public class JsonSerializer implements ODataSerializer { valuable.isPrimitive()) || valuable.isNull()) { type = EdmPrimitiveTypeKind.String.getFullQualifiedName().toString(); } - if (StringUtils.isNotBlank(type) && format != ODataFormat.JSON_NO_METADATA) { + if (StringUtils.isNotBlank(type) && !isODataMetadataNone(contentType)) { jgen.writeFieldName( name + StringUtils.prependIfMissing(Constants.JSON_TYPE, "@")); jgen.writeString(new EdmTypeInfo.Builder().setTypeExpression(type).build().external()); @@ -373,4 +374,14 @@ public class JsonSerializer implements ODataSerializer { jgen.writeFieldName(name); value(jgen, valuable.getType(), valuable); } + + private boolean isIEEE754Compatible() { + final String parameter = contentType.getParameters().get(ContentType.PARAMETER_IEEE754_COMPATIBLE); + return parameter == null ? false : "true".equals(parameter.toLowerCase()); + } + + protected boolean isODataMetadataNone(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_JSON) + && ContentType.VALUE_ODATA_METADATA_NONE.equals(contentType.getParameter(ContentType.PARAMETER_ODATA_METADATA)); + } } \ No newline at end of file diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataBinderImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataBinderImpl.java index e953cae2a..926f74c3e 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataBinderImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataBinderImpl.java @@ -69,6 +69,10 @@ import org.apache.olingo.client.api.domain.ClientProperty; import org.apache.olingo.client.api.domain.ClientServiceDocument; import org.apache.olingo.client.api.domain.ClientValuable; import org.apache.olingo.client.api.domain.ClientValue; +import org.apache.olingo.client.core.domain.ClientAnnotationImpl; +import org.apache.olingo.client.core.domain.ClientDeletedEntityImpl; +import org.apache.olingo.client.core.domain.ClientDeltaLinkImpl; +import org.apache.olingo.client.core.domain.ClientPropertyImpl; import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.EdmBindingTarget; import org.apache.olingo.commons.api.edm.EdmComplexType; @@ -87,13 +91,9 @@ import org.apache.olingo.commons.api.edm.EdmTerm; import org.apache.olingo.commons.api.edm.EdmType; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.edm.geo.Geospatial; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.apache.olingo.client.core.domain.ClientAnnotationImpl; -import org.apache.olingo.client.core.domain.ClientDeletedEntityImpl; -import org.apache.olingo.client.core.domain.ClientDeltaLinkImpl; -import org.apache.olingo.client.core.domain.ClientPropertyImpl; -import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmTypeInfo; +import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -391,7 +391,7 @@ public class ODataBinderImpl implements ODataBinder { if (LOG.isDebugEnabled()) { final StringWriter writer = new StringWriter(); try { - client.getSerializer(ODataFormat.JSON).write(writer, resource.getPayload()); + client.getSerializer(ContentType.JSON).write(writer, resource.getPayload()); } catch (final ODataSerializerException e) { LOG.debug("EntitySet -> ODataEntitySet:\n{}", writer.toString()); } @@ -588,7 +588,7 @@ public class ODataBinderImpl implements ODataBinder { if (LOG.isDebugEnabled()) { final StringWriter writer = new StringWriter(); try { - client.getSerializer(ODataFormat.JSON).write(writer, resource.getPayload()); + client.getSerializer(ContentType.JSON).write(writer, resource.getPayload()); } catch (final ODataSerializerException e) { LOG.debug("EntityResource -> ODataEntity:\n{}", writer.toString()); } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataReaderImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataReaderImpl.java index 6153cdb67..aba93579a 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataReaderImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataReaderImpl.java @@ -25,25 +25,25 @@ import java.util.Map; import org.apache.commons.io.IOUtils; import org.apache.olingo.client.api.ODataClient; import org.apache.olingo.client.api.data.ServiceDocument; +import org.apache.olingo.client.api.domain.ClientEntity; +import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientEntitySetIterator; +import org.apache.olingo.client.api.domain.ClientProperty; +import org.apache.olingo.client.api.domain.ClientServiceDocument; +import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.client.api.edm.xml.XMLMetadata; import org.apache.olingo.client.api.serialization.ODataDeserializerException; import org.apache.olingo.client.api.serialization.ODataReader; import org.apache.olingo.client.core.edm.ClientCsdlEdmProvider; +import org.apache.olingo.commons.api.ODataError; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientEntity; -import org.apache.olingo.client.api.domain.ClientEntitySet; -import org.apache.olingo.commons.api.ODataError; -import org.apache.olingo.client.api.domain.ClientProperty; -import org.apache.olingo.client.api.domain.ClientServiceDocument; -import org.apache.olingo.client.api.domain.ClientValue; import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.provider.CsdlSchema; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmProviderImpl; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -63,7 +63,7 @@ public class ODataReaderImpl implements ODataReader { @Override public Edm readMetadata(final InputStream input) { - return readMetadata(client.getDeserializer(ODataFormat.XML).toMetadata(input).getSchemaByNsOrAlias()); + return readMetadata(client.getDeserializer(ContentType.APPLICATION_XML).toMetadata(input).getSchemaByNsOrAlias()); } @Override @@ -73,16 +73,16 @@ public class ODataReaderImpl implements ODataReader { } @Override - public ClientServiceDocument readServiceDocument(final InputStream input, final ODataFormat format) + public ClientServiceDocument readServiceDocument(final InputStream input, final ContentType contentType) throws ODataDeserializerException { return client.getBinder().getODataServiceDocument( - client.getDeserializer(format).toServiceDocument(input).getPayload()); + client.getDeserializer(contentType).toServiceDocument(input).getPayload()); } @Override - public ODataError readError(final InputStream inputStream, final ODataFormat format) + public ODataError readError(final InputStream inputStream, final ContentType contentType) throws ODataDeserializerException { - return client.getDeserializer(format).toError(inputStream); + return client.getDeserializer(contentType).toError(inputStream); } @Override @@ -96,22 +96,22 @@ public class ODataReaderImpl implements ODataReader { (URI) null, null, reference.cast(new ClientEntitySetIterator( - client, src, ODataFormat.fromString(format)))); + client, src, ContentType.parse(format)))); } else if (ClientEntitySet.class.isAssignableFrom(reference)) { - final ResWrap resource = client.getDeserializer(ODataFormat.fromString(format)) + final ResWrap resource = client.getDeserializer(ContentType.parse(format)) .toEntitySet(src); res = new ResWrap( resource.getContextURL(), resource.getMetadataETag(), reference.cast(client.getBinder().getODataEntitySet(resource))); } else if (ClientEntity.class.isAssignableFrom(reference)) { - final ResWrap container = client.getDeserializer(ODataFormat.fromString(format)).toEntity(src); + final ResWrap container = client.getDeserializer(ContentType.parse(format)).toEntity(src); res = new ResWrap( container.getContextURL(), container.getMetadataETag(), reference.cast(client.getBinder().getODataEntity(container))); } else if (ClientProperty.class.isAssignableFrom(reference)) { - final ResWrap container = client.getDeserializer(ODataFormat.fromString(format)).toProperty(src); + final ResWrap container = client.getDeserializer(ContentType.parse(format)).toProperty(src); res = new ResWrap( container.getContextURL(), container.getMetadataETag(), @@ -121,7 +121,7 @@ public class ODataReaderImpl implements ODataReader { (URI) null, null, reference.cast(client.getObjectFactory().newPrimitiveValueBuilder(). - setType(ODataFormat.fromString(format) == ODataFormat.TEXT_PLAIN + setType(ContentType.parse(format).equals(ContentType.TEXT_PLAIN) ? EdmPrimitiveTypeKind.String : EdmPrimitiveTypeKind.Stream). setValue(IOUtils.toString(src)) // TODO: set correct value .build())); @@ -132,7 +132,7 @@ public class ODataReaderImpl implements ODataReader { reference.cast(readMetadata(src))); } else if (ClientServiceDocument.class.isAssignableFrom(reference)) { final ResWrap resource = - client.getDeserializer(ODataFormat.fromString(format)).toServiceDocument(src); + client.getDeserializer(ContentType.parse(format)).toServiceDocument(src); res = new ResWrap( resource.getContextURL(), resource.getMetadataETag(), @@ -141,7 +141,7 @@ public class ODataReaderImpl implements ODataReader { res = new ResWrap( (URI) null, null, - reference.cast(readError(src, ODataFormat.fromString(format)))); + reference.cast(readError(src, ContentType.parse(format)))); } else { throw new IllegalArgumentException("Invalid reference type " + reference); } @@ -158,20 +158,20 @@ public class ODataReaderImpl implements ODataReader { } @Override - public ClientEntitySet readEntitySet(final InputStream input, final ODataFormat format) + public ClientEntitySet readEntitySet(final InputStream input, final ContentType contentType) throws ODataDeserializerException { - return client.getBinder().getODataEntitySet(client.getDeserializer(format).toEntitySet(input)); + return client.getBinder().getODataEntitySet(client.getDeserializer(contentType).toEntitySet(input)); } @Override - public ClientEntity readEntity(final InputStream input, final ODataFormat format) + public ClientEntity readEntity(final InputStream input, final ContentType contentType) throws ODataDeserializerException { - return client.getBinder().getODataEntity(client.getDeserializer(format).toEntity(input)); + return client.getBinder().getODataEntity(client.getDeserializer(contentType).toEntity(input)); } @Override - public ClientProperty readProperty(final InputStream input, final ODataFormat format) + public ClientProperty readProperty(final InputStream input, final ContentType contentType) throws ODataDeserializerException { - return client.getBinder().getODataProperty(client.getDeserializer(format).toProperty(input)); + return client.getBinder().getODataProperty(client.getDeserializer(contentType).toProperty(input)); } } diff --git a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataWriterImpl.java b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataWriterImpl.java index 584c4203b..88a433f94 100644 --- a/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataWriterImpl.java +++ b/lib/client-core/src/main/java/org/apache/olingo/client/core/serialization/ODataWriterImpl.java @@ -29,14 +29,14 @@ import java.util.Collections; import org.apache.commons.io.IOUtils; import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.api.serialization.ODataSerializerException; -import org.apache.olingo.client.api.serialization.ODataWriter; -import org.apache.olingo.commons.api.Constants; -import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientLink; import org.apache.olingo.client.api.domain.ClientProperty; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.client.api.serialization.ODataWriter; +import org.apache.olingo.commons.api.Constants; +import org.apache.olingo.commons.api.data.ResWrap; +import org.apache.olingo.commons.api.format.ContentType; +import org.apache.olingo.client.api.serialization.ODataSerializerException; public class ODataWriterImpl implements ODataWriter { @@ -47,7 +47,7 @@ public class ODataWriterImpl implements ODataWriter { } @Override - public InputStream writeEntities(final Collection entities, final ODataFormat format) + public InputStream writeEntities(final Collection entities, final ContentType contentType) throws ODataSerializerException { ByteArrayOutputStream output = new ByteArrayOutputStream(); OutputStreamWriter writer; @@ -58,7 +58,7 @@ public class ODataWriterImpl implements ODataWriter { } try { for (ClientEntity entity : entities) { - client.getSerializer(format).write(writer, client.getBinder().getEntity(entity)); + client.getSerializer(contentType).write(writer, client.getBinder().getEntity(entity)); } return new ByteArrayInputStream(output.toByteArray()); @@ -68,13 +68,13 @@ public class ODataWriterImpl implements ODataWriter { } @Override - public InputStream writeEntity(final ClientEntity entity, final ODataFormat format) + public InputStream writeEntity(final ClientEntity entity, final ContentType contentType) throws ODataSerializerException { - return writeEntities(Collections.singleton(entity), format); + return writeEntities(Collections.singleton(entity), contentType); } @Override - public InputStream writeProperty(final ClientProperty property, final ODataFormat format) + public InputStream writeProperty(final ClientProperty property, final ContentType contentType) throws ODataSerializerException { final ByteArrayOutputStream output = new ByteArrayOutputStream(); OutputStreamWriter writer; @@ -84,7 +84,7 @@ public class ODataWriterImpl implements ODataWriter { writer = null; } try { - client.getSerializer(format).write(writer, client.getBinder().getProperty(property)); + client.getSerializer(contentType).write(writer, client.getBinder().getProperty(property)); return new ByteArrayInputStream(output.toByteArray()); } finally { @@ -93,7 +93,7 @@ public class ODataWriterImpl implements ODataWriter { } @Override - public InputStream writeLink(final ClientLink link, final ODataFormat format) throws ODataSerializerException { + public InputStream writeLink(final ClientLink link, final ContentType contentType) throws ODataSerializerException { final ByteArrayOutputStream output = new ByteArrayOutputStream(); OutputStreamWriter writer; try { @@ -102,7 +102,7 @@ public class ODataWriterImpl implements ODataWriter { writer = null; } try { - client.getSerializer(format).write(writer, client.getBinder().getLink(link)); + client.getSerializer(contentType).write(writer, client.getBinder().getLink(link)); return new ByteArrayInputStream(output.toByteArray()); } finally { @@ -111,7 +111,7 @@ public class ODataWriterImpl implements ODataWriter { } @Override - public InputStream writeReference(ResWrap reference, ODataFormat format) throws ODataSerializerException { + public InputStream writeReference(ResWrap reference, ContentType contenType) throws ODataSerializerException { final ByteArrayOutputStream output = new ByteArrayOutputStream(); OutputStreamWriter writer; @@ -122,7 +122,7 @@ public class ODataWriterImpl implements ODataWriter { } try { - client.getSerializer(format).write(writer, reference); + client.getSerializer(contenType).write(writer, reference); return new ByteArrayInputStream(output.toByteArray()); } finally { diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/AbstractTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/AbstractTest.java index c0a346a5a..beeda7e02 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/AbstractTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/AbstractTest.java @@ -19,7 +19,7 @@ package org.apache.olingo.client.core; import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.custommonkey.xmlunit.XMLUnit; import org.junit.BeforeClass; @@ -43,7 +43,8 @@ public abstract class AbstractTest { v4Client = ODataClientFactory.getClient(); } - protected String getSuffix(final ODataFormat format) { - return format == ODataFormat.ATOM || format == ODataFormat.XML ? "xml" : "json"; + protected String getSuffix(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC, ContentType.APPLICATION_ATOM_XML, + ContentType.APPLICATION_XML) ? "xml": "json"; } } diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/AtomTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/AtomTest.java index 3d445d81a..4618d3be5 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/AtomTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/AtomTest.java @@ -20,11 +20,8 @@ package org.apache.olingo.client.core.v4; import static org.junit.Assert.assertTrue; -import org.apache.commons.io.IOUtils; -import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.core.AtomLinksQualifier; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.custommonkey.xmlunit.Diff; +import java.io.ByteArrayInputStream; +import java.io.StringWriter; import javax.xml.transform.Source; import javax.xml.transform.Transformer; @@ -32,8 +29,11 @@ import javax.xml.transform.TransformerFactory; import javax.xml.transform.stream.StreamResult; import javax.xml.transform.stream.StreamSource; -import java.io.ByteArrayInputStream; -import java.io.StringWriter; +import org.apache.commons.io.IOUtils; +import org.apache.olingo.client.api.ODataClient; +import org.apache.olingo.client.core.AtomLinksQualifier; +import org.apache.olingo.commons.api.format.ContentType; +import org.custommonkey.xmlunit.Diff; public class AtomTest extends JSONTest { @@ -43,13 +43,13 @@ public class AtomTest extends JSONTest { } @Override - protected ODataFormat getODataPubFormat() { - return ODataFormat.ATOM; + protected ContentType getODataPubFormat() { + return ContentType.APPLICATION_ATOM_XML; } @Override - protected ODataFormat getODataFormat() { - return ODataFormat.XML; + protected ContentType getODataFormat() { + return ContentType.APPLICATION_XML; } private String cleanup(final String input) throws Exception { diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntitySetTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntitySetTest.java index d3746e1c4..50af30fc0 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntitySetTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntitySetTest.java @@ -18,23 +18,23 @@ */ package org.apache.olingo.client.core.v4; -import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.core.AbstractTest; -import org.apache.olingo.commons.api.data.EntityCollection; -import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientEntity; -import org.apache.olingo.client.api.domain.ClientEntitySet; -import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.junit.Test; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertNull; import java.io.IOException; import java.io.InputStream; import java.net.URI; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertNull; +import org.apache.olingo.client.api.ODataClient; +import org.apache.olingo.client.api.domain.ClientEntity; +import org.apache.olingo.client.api.domain.ClientEntitySet; +import org.apache.olingo.client.core.AbstractTest; +import org.apache.olingo.commons.api.data.EntityCollection; +import org.apache.olingo.commons.api.data.ResWrap; +import org.apache.olingo.commons.api.format.ContentType; +import org.apache.olingo.client.api.serialization.ODataDeserializerException; +import org.junit.Test; public class EntitySetTest extends AbstractTest { @@ -43,10 +43,10 @@ public class EntitySetTest extends AbstractTest { return v4Client; } - private void read(final ODataFormat format) throws IOException, ODataDeserializerException { - final InputStream input = getClass().getResourceAsStream("Customers." + getSuffix(format)); + private void read(final ContentType contentType) throws IOException, ODataDeserializerException { + final InputStream input = getClass().getResourceAsStream("Customers." + getSuffix(contentType)); final ClientEntitySet entitySet = getClient().getBinder().getODataEntitySet( - getClient().getDeserializer(format).toEntitySet(input)); + getClient().getDeserializer(contentType).toEntitySet(input)); assertNotNull(entitySet); assertEquals(2, entitySet.getEntities().size()); @@ -60,18 +60,18 @@ public class EntitySetTest extends AbstractTest { @Test public void fromAtom() throws Exception { - read(ODataFormat.ATOM); + read(ContentType.APPLICATION_ATOM_XML); } @Test public void fromJSON() throws Exception { - read(ODataFormat.JSON); + read(ContentType.JSON); } - private void ref(final ODataFormat format) throws ODataDeserializerException { - final InputStream input = getClass().getResourceAsStream("collectionOfEntityReferences." + getSuffix(format)); + private void ref(final ContentType contentType) throws ODataDeserializerException { + final InputStream input = getClass().getResourceAsStream("collectionOfEntityReferences." + getSuffix(contentType)); final ClientEntitySet entitySet = getClient().getBinder().getODataEntitySet( - getClient().getDeserializer(format).toEntitySet(input)); + getClient().getDeserializer(contentType).toEntitySet(input)); assertNotNull(entitySet); for (ClientEntity entity : entitySet.getEntities()) { @@ -87,11 +87,11 @@ public class EntitySetTest extends AbstractTest { @Test public void atomRef() throws Exception { - ref(ODataFormat.ATOM); + ref(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonRef() throws Exception { - ref(ODataFormat.JSON); + ref(ContentType.JSON); } } diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntityTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntityTest.java index 7373da6f7..a21cc15ec 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntityTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/EntityTest.java @@ -29,10 +29,6 @@ import java.util.Iterator; import org.apache.olingo.client.api.EdmEnabledODataClient; import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.core.AbstractTest; -import org.apache.olingo.client.core.EdmEnabledODataClientImpl; -import org.apache.olingo.commons.api.data.Entity; -import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.client.api.domain.ClientAnnotation; import org.apache.olingo.client.api.domain.ClientComplexValue; import org.apache.olingo.client.api.domain.ClientEntity; @@ -42,9 +38,13 @@ import org.apache.olingo.client.api.domain.ClientLinkType; 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 org.apache.olingo.client.core.AbstractTest; +import org.apache.olingo.client.core.EdmEnabledODataClientImpl; +import org.apache.olingo.commons.api.data.Entity; +import org.apache.olingo.commons.api.data.ResWrap; import org.apache.olingo.commons.api.edm.Edm; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.primitivetype.EdmDateTimeOffset; import org.apache.olingo.commons.core.edm.primitivetype.EdmDuration; import org.junit.Ignore; @@ -78,10 +78,10 @@ public class EntityTest extends AbstractTest { }; } - private void singleton(final ODataFormat format) throws Exception { - final InputStream input = getClass().getResourceAsStream("VipCustomer." + getSuffix(format)); + private void singleton(final ContentType contentType) throws Exception { + final InputStream input = getClass().getResourceAsStream("VipCustomer." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", entity.getTypeName().toString()); @@ -102,7 +102,7 @@ public class EntityTest extends AbstractTest { } if ("Orders".equals(link.getName())) { checked++; - if (format == ODataFormat.ATOM) { + if(contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC, ContentType.APPLICATION_ATOM_XML)) { assertEquals(ClientLinkType.ENTITY_SET_NAVIGATION, link.getType()); } } @@ -129,18 +129,18 @@ public class EntityTest extends AbstractTest { @Test public void atomSingleton() throws Exception { - singleton(ODataFormat.ATOM); + singleton(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonSingleton() throws Exception { - singleton(ODataFormat.JSON_FULL_METADATA); + singleton(ContentType.JSON_FULL_METADATA); } - private void withEnums(final ODataFormat format) throws Exception { - final InputStream input = getClass().getResourceAsStream("Products_5." + getSuffix(format)); + private void withEnums(final ContentType contentType) throws Exception { + final InputStream input = getClass().getResourceAsStream("Products_5." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); final ClientProperty skinColor = entity.getProperty("SkinColor"); @@ -165,19 +165,19 @@ public class EntityTest extends AbstractTest { @Test public void atomWithEnums() throws Exception { - withEnums(ODataFormat.ATOM); + withEnums(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonWithEnums() throws Exception { - withEnums(ODataFormat.JSON_FULL_METADATA); + withEnums(ContentType.JSON_FULL_METADATA); } - private void withInlineEntitySet(final ODataFormat format) throws Exception { + private void withInlineEntitySet(final ContentType contentType) throws Exception { final InputStream input = getClass().getResourceAsStream( - "Accounts_101_expand_MyPaymentInstruments." + getSuffix(format)); + "Accounts_101_expand_MyPaymentInstruments." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); final ClientLink instruments = entity.getNavigationLink("MyPaymentInstruments"); @@ -200,19 +200,19 @@ public class EntityTest extends AbstractTest { @Test public void atomWithInlineEntitySet() throws Exception { - withInlineEntitySet(ODataFormat.ATOM); + withInlineEntitySet(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonWithInlineEntitySet() throws Exception { - withInlineEntitySet(ODataFormat.JSON_FULL_METADATA); + withInlineEntitySet(ContentType.JSON_FULL_METADATA); } - private void mediaEntity(final ODataFormat format) throws Exception { + private void mediaEntity(final ContentType contentType) throws Exception { final InputStream input = getClass().getResourceAsStream( - "Advertisements_f89dee73-af9f-4cd4-b330-db93c25ff3c7." + getSuffix(format)); + "Advertisements_f89dee73-af9f-4cd4-b330-db93c25ff3c7." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); assertTrue(entity.isMediaEntity()); @@ -227,18 +227,18 @@ public class EntityTest extends AbstractTest { @Test public void atomMediaEntity() throws Exception { - mediaEntity(ODataFormat.ATOM); + mediaEntity(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonMediaEntity() throws Exception { - mediaEntity(ODataFormat.JSON_FULL_METADATA); + mediaEntity(ContentType.JSON_FULL_METADATA); } - private void withStream(final ODataFormat format) throws Exception { - final InputStream input = getClass().getResourceAsStream("PersonDetails_1." + getSuffix(format)); + private void withStream(final ContentType contentType) throws Exception { + final InputStream input = getClass().getResourceAsStream("PersonDetails_1." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); assertFalse(entity.isMediaEntity()); @@ -254,18 +254,18 @@ public class EntityTest extends AbstractTest { @Test public void atomWithStream() throws Exception { - withStream(ODataFormat.ATOM); + withStream(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonWithStream() throws Exception { - withStream(ODataFormat.JSON_FULL_METADATA); + withStream(ContentType.JSON_FULL_METADATA); } - private void ref(final ODataFormat format) throws Exception { - final InputStream input = getClass().getResourceAsStream("entityReference." + getSuffix(format)); + private void ref(final ContentType contentType) throws Exception { + final InputStream input = getClass().getResourceAsStream("entityReference." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); assertNotNull(entity.getId()); @@ -278,18 +278,18 @@ public class EntityTest extends AbstractTest { @Test public void atomRef() throws Exception { - ref(ODataFormat.ATOM); + ref(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonRef() throws Exception { - ref(ODataFormat.JSON); + ref(ContentType.JSON); } - private void complexNavigationProperties(final ODataFormat format) throws Exception { - final InputStream input = getClass().getResourceAsStream("entity.withcomplexnavigation." + getSuffix(format)); + private void complexNavigationProperties(final ContentType contentType) throws Exception { + final InputStream input = getClass().getResourceAsStream("entity.withcomplexnavigation." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); final ClientComplexValue addressValue = entity.getProperty("Address").getComplexValue(); @@ -306,18 +306,18 @@ public class EntityTest extends AbstractTest { @Test public void atomComplexNavigationProperties() throws Exception { - complexNavigationProperties(ODataFormat.ATOM); + complexNavigationProperties(ContentType.APPLICATION_ATOM_XML); } @Test public void jsonComplexNavigationProperties() throws Exception { - complexNavigationProperties(ODataFormat.JSON); + complexNavigationProperties(ContentType.JSON); } - private void annotated(final ODataFormat format) throws EdmPrimitiveTypeException, Exception { - final InputStream input = getClass().getResourceAsStream("annotated." + getSuffix(format)); + private void annotated(final ContentType contentType) throws EdmPrimitiveTypeException, Exception { + final InputStream input = getClass().getResourceAsStream("annotated." + getSuffix(contentType)); final ClientEntity entity = getClient().getBinder().getODataEntity( - getClient().getDeserializer(format).toEntity(input)); + getClient().getDeserializer(contentType).toEntity(input)); assertNotNull(entity); assertFalse(entity.getAnnotations().isEmpty()); @@ -353,18 +353,18 @@ public class EntityTest extends AbstractTest { @Test @Ignore public void atomAnnotated() throws Exception { - annotated(ODataFormat.ATOM); + annotated(ContentType.APPLICATION_ATOM_XML); } @Test @Ignore public void jsonAnnotated() throws Exception { - annotated(ODataFormat.JSON); + annotated(ContentType.JSON); } - private void derived(final ODataClient client, final ODataFormat format) throws Exception { - final InputStream input = getClass().getResourceAsStream("Customer." + getSuffix(format)); - final ClientEntity entity = client.getBinder().getODataEntity(client.getDeserializer(format).toEntity(input)); + private void derived(final ODataClient client, final ContentType contentType) throws Exception { + final InputStream input = getClass().getResourceAsStream("Customer." + getSuffix(contentType)); + final ClientEntity entity = client.getBinder().getODataEntity(client.getDeserializer(contentType).toEntity(input)); assertNotNull(entity); assertEquals("Microsoft.Test.OData.Services.ODataWCFService.Customer", entity.getTypeName().toString()); @@ -375,16 +375,16 @@ public class EntityTest extends AbstractTest { @Test public void derivedFromAtom() throws Exception { - derived(getClient(), ODataFormat.ATOM); + derived(getClient(), ContentType.APPLICATION_ATOM_XML); } @Test public void derivedFromJSON() throws Exception { - derived(getEdmEnabledClient(), ODataFormat.JSON); + derived(getEdmEnabledClient(), ContentType.JSON); } @Test public void derivedFromFullJSON() throws Exception { - derived(getClient(), ODataFormat.JSON_FULL_METADATA); + derived(getClient(), ContentType.JSON_FULL_METADATA); } } diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ErrorTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ErrorTest.java index 93b43dfbf..217f1d142 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ErrorTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ErrorTest.java @@ -18,16 +18,16 @@ */ package org.apache.olingo.client.core.v4; +import static org.junit.Assert.assertEquals; +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.core.AbstractTest; import org.apache.olingo.commons.api.ODataError; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; - public class ErrorTest extends AbstractTest { @Override @@ -35,15 +35,15 @@ public class ErrorTest extends AbstractTest { return v4Client; } - private ODataError error(final String name, final ODataFormat format) throws ODataDeserializerException { - final ODataError error = getClient().getDeserializer(format).toError( - getClass().getResourceAsStream(name + "." + getSuffix(format))); + private ODataError error(final String name, final ContentType contentType) throws ODataDeserializerException { + final ODataError error = getClient().getDeserializer(contentType).toError( + getClass().getResourceAsStream(name + "." + getSuffix(contentType))); assertNotNull(error); return error; } - private void simple(final ODataFormat format) throws ODataDeserializerException { - final ODataError error = error("error", format); + private void simple(final ContentType contentType) throws ODataDeserializerException { + final ODataError error = error("error", contentType); assertEquals("501", error.getCode()); assertEquals("Unsupported functionality", error.getMessage()); assertEquals("query", error.getTarget()); @@ -51,12 +51,12 @@ public class ErrorTest extends AbstractTest { @Test public void jsonSimple() throws Exception { - simple(ODataFormat.JSON); + simple(ContentType.JSON); } @Test public void atomSimple() throws Exception { - simple(ODataFormat.ATOM); + simple(ContentType.APPLICATION_ATOM_XML); } } diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/JSONTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/JSONTest.java index 83c495c59..87edec17d 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/JSONTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/JSONTest.java @@ -31,16 +31,16 @@ import java.util.Map; import org.apache.commons.io.IOUtils; import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.core.AbstractTest; -import org.apache.olingo.commons.api.Constants; -import org.apache.olingo.commons.api.data.Delta; -import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.client.api.domain.ClientCollectionValue; import org.apache.olingo.client.api.domain.ClientComplexValue; import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientValue; +import org.apache.olingo.client.core.AbstractTest; +import org.apache.olingo.commons.api.Constants; +import org.apache.olingo.commons.api.data.Delta; +import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.junit.Test; import com.fasterxml.jackson.databind.JsonNode; @@ -56,12 +56,12 @@ public class JSONTest extends AbstractTest { return v4Client; } - protected ODataFormat getODataPubFormat() { - return ODataFormat.JSON; + protected ContentType getODataPubFormat() { + return ContentType.JSON; } - protected ODataFormat getODataFormat() { - return ODataFormat.JSON; + protected ContentType getODataFormat() { + return ContentType.JSON; } private void cleanup(final ObjectNode node) { @@ -128,12 +128,12 @@ public class JSONTest extends AbstractTest { assertEquals(expected, actualNode); } - protected void entitySet(final String filename, final ODataFormat format) throws Exception { + protected void entitySet(final String filename, final ContentType contentType) throws Exception { final StringWriter writer = new StringWriter(); - getClient().getSerializer(format).write(writer, getClient().getDeserializer(format).toEntitySet( - getClass().getResourceAsStream(filename + "." + getSuffix(format))).getPayload()); + getClient().getSerializer(contentType).write(writer, getClient().getDeserializer(contentType).toEntitySet( + getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload()); - assertSimilar(filename + "." + getSuffix(format), writer.toString()); + assertSimilar(filename + "." + getSuffix(contentType), writer.toString()); } @Test @@ -142,12 +142,12 @@ public class JSONTest extends AbstractTest { entitySet("collectionOfEntityReferences", getODataPubFormat()); } - protected void entity(final String filename, final ODataFormat format) throws Exception { + protected void entity(final String filename, final ContentType contentType) throws Exception { final StringWriter writer = new StringWriter(); - getClient().getSerializer(format).write(writer, getClient().getDeserializer(format).toEntity( - getClass().getResourceAsStream(filename + "." + getSuffix(format))).getPayload()); + getClient().getSerializer(contentType).write(writer, getClient().getDeserializer(contentType).toEntity( + getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload()); - assertSimilar(filename + "." + getSuffix(format), writer.toString()); + assertSimilar(filename + "." + getSuffix(contentType), writer.toString()); } @Test @@ -169,12 +169,12 @@ public class JSONTest extends AbstractTest { entity("annotated", getODataPubFormat()); } - protected void property(final String filename, final ODataFormat format) throws Exception { + protected void property(final String filename, final ContentType contentType) throws Exception { final StringWriter writer = new StringWriter(); - getClient().getSerializer(format).write(writer, getClient().getDeserializer(format). - toProperty(getClass().getResourceAsStream(filename + "." + getSuffix(format))).getPayload()); + getClient().getSerializer(contentType).write(writer, getClient().getDeserializer(contentType). + toProperty(getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload()); - assertSimilar(filename + "." + getSuffix(format), writer.toString()); + assertSimilar(filename + "." + getSuffix(contentType), writer.toString()); } @Test @@ -187,13 +187,13 @@ public class JSONTest extends AbstractTest { @Test public void crossjoin() throws Exception { - assertNotNull(getClient().getDeserializer(ODataFormat.JSON_FULL_METADATA).toEntitySet( + assertNotNull(getClient().getDeserializer(ContentType.JSON_FULL_METADATA).toEntitySet( getClass().getResourceAsStream("crossjoin.json"))); } - protected void delta(final String filename, final ODataFormat format) throws Exception { - final Delta delta = getClient().getDeserializer(format).toDelta( - getClass().getResourceAsStream(filename + "." + getSuffix(format))).getPayload(); + protected void delta(final String filename, final ContentType contentType) throws Exception { + final Delta delta = getClient().getDeserializer(contentType).toDelta( + getClass().getResourceAsStream(filename + "." + getSuffix(contentType))).getPayload(); assertNotNull(delta); assertNotNull(delta.getDeltaLink()); assertEquals(5, delta.getCount(), 0); @@ -248,7 +248,7 @@ public class JSONTest extends AbstractTest { getClient().getObjectFactory().newEnumValue("Microsoft.Exchange.Services.OData.Model.BodyType", "text"))); message.getProperties().add(getClient().getObjectFactory().newComplexProperty("Body", body)); - final String actual = IOUtils.toString(getClient().getWriter().writeEntity(message, ODataFormat.JSON)); + final String actual = IOUtils.toString(getClient().getWriter().writeEntity(message, ContentType.JSON)); final JsonNode expected = OBJECT_MAPPER.readTree(IOUtils.toString(getClass().getResourceAsStream("olingo390.json")). replace(Constants.JSON_NAVIGATION_LINK, Constants.JSON_BIND_LINK_SUFFIX)); diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/MetadataTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/MetadataTest.java index 562a25534..1f603ad93 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/MetadataTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/MetadataTest.java @@ -64,7 +64,7 @@ import org.apache.olingo.commons.api.edm.provider.annotation.ConstantAnnotationE import org.apache.olingo.commons.api.edm.provider.annotation.Path; import org.apache.olingo.commons.api.edm.provider.annotation.TwoParamsOpDynamicAnnotationExpression; import org.apache.olingo.commons.api.edm.provider.annotation.UrlRef; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.primitivetype.EdmDecimal; import org.apache.olingo.commons.core.edm.primitivetype.EdmInt32; import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; @@ -140,7 +140,7 @@ public class MetadataTest extends AbstractTest { @Test public void demo() { - final XMLMetadata metadata = getClient().getDeserializer(ODataFormat.XML). + final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). toMetadata(getClass().getResourceAsStream("demo-metadata.xml")); assertNotNull(metadata); @@ -181,7 +181,7 @@ public class MetadataTest extends AbstractTest { @Test public void multipleSchemas() { - final XMLMetadata metadata = getClient().getDeserializer(ODataFormat.XML). + final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). toMetadata(getClass().getResourceAsStream("northwind-metadata.xml")); assertNotNull(metadata); @@ -201,7 +201,7 @@ public class MetadataTest extends AbstractTest { */ @Test public void fromdoc1() { - final XMLMetadata metadata = getClient().getDeserializer(ODataFormat.XML). + final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). toMetadata(getClass().getResourceAsStream("fromdoc1-metadata.xml")); assertNotNull(metadata); @@ -281,7 +281,7 @@ public class MetadataTest extends AbstractTest { */ @Test public void fromdoc2() { - final XMLMetadata metadata = getClient().getDeserializer(ODataFormat.XML) + final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML) .toMetadata(getClass().getResourceAsStream("fromdoc2-metadata.xml")); assertNotNull(metadata); @@ -343,7 +343,7 @@ public class MetadataTest extends AbstractTest { */ @Test public void fromdoc4() { - final XMLMetadata metadata = getClient().getDeserializer(ODataFormat.XML). + final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). toMetadata(getClass().getResourceAsStream("fromdoc4-metadata.xml")); assertNotNull(metadata); @@ -399,7 +399,7 @@ public class MetadataTest extends AbstractTest { @Test public void metadataWithCapabilities() throws Exception { InputStream input = getClass().getResourceAsStream("Metadata-With-Capabilities.xml"); - final XMLMetadata metadata = getClient().getDeserializer(ODataFormat.XML). + final XMLMetadata metadata = getClient().getDeserializer(ContentType.APPLICATION_XML). toMetadata(input); CsdlSchema schema = metadata.getSchema("Capabilities"); diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/PropertyTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/PropertyTest.java index b0423e748..0ee54717c 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/PropertyTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/PropertyTest.java @@ -18,23 +18,23 @@ */ package org.apache.olingo.client.core.v4; -import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.core.AbstractTest; -import org.apache.olingo.client.api.domain.ClientCollectionValue; -import org.apache.olingo.client.api.domain.ClientComplexValue; -import org.apache.olingo.client.api.domain.ClientProperty; -import org.apache.olingo.client.api.domain.ClientValue; -import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.client.api.serialization.ODataSerializerException; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.junit.Test; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertTrue; import java.io.InputStream; import java.util.Iterator; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertTrue; +import org.apache.olingo.client.api.ODataClient; +import org.apache.olingo.client.api.domain.ClientCollectionValue; +import org.apache.olingo.client.api.domain.ClientComplexValue; +import org.apache.olingo.client.api.domain.ClientProperty; +import org.apache.olingo.client.api.domain.ClientValue; +import org.apache.olingo.client.core.AbstractTest; +import org.apache.olingo.commons.api.format.ContentType; +import org.apache.olingo.client.api.serialization.ODataDeserializerException; +import org.apache.olingo.client.api.serialization.ODataSerializerException; +import org.junit.Test; public class PropertyTest extends AbstractTest { @@ -43,16 +43,16 @@ public class PropertyTest extends AbstractTest { return v4Client; } - private void _enum(final ODataFormat format) throws ODataDeserializerException, ODataSerializerException { - final InputStream input = getClass().getResourceAsStream("Products_5_SkinColor." + getSuffix(format)); - final ClientProperty property = getClient().getReader().readProperty(input, format); + private void _enum(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException { + final InputStream input = getClass().getResourceAsStream("Products_5_SkinColor." + getSuffix(contentType)); + final ClientProperty property = getClient().getReader().readProperty(input, contentType); assertNotNull(property); assertTrue(property.hasEnumValue()); final ClientProperty written = getClient().getReader().readProperty( - getClient().getWriter().writeProperty(property, format), format); + getClient().getWriter().writeProperty(property, contentType), contentType); // This is needed because type information gets lost with serialization - if (format == ODataFormat.XML) { + if (contentType.isCompatible(ContentType.APPLICATION_XML)) { final ClientProperty comparable = getClient().getObjectFactory().newEnumProperty(property.getName(), getClient().getObjectFactory(). newEnumValue(property.getEnumValue().getTypeName(), written.getEnumValue().getValue())); @@ -63,23 +63,23 @@ public class PropertyTest extends AbstractTest { @Test public void xmlEnum() throws Exception { - _enum(ODataFormat.XML); + _enum(ContentType.APPLICATION_XML); } @Test public void jsonEnum() throws Exception { - _enum(ODataFormat.JSON); + _enum(ContentType.JSON); } - private void complex(final ODataFormat format) throws ODataDeserializerException, ODataSerializerException { - final InputStream input = getClass().getResourceAsStream("Employees_3_HomeAddress." + getSuffix(format)); - final ClientProperty property = getClient().getReader().readProperty(input, format); + private void complex(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException { + final InputStream input = getClass().getResourceAsStream("Employees_3_HomeAddress." + getSuffix(contentType)); + final ClientProperty property = getClient().getReader().readProperty(input, contentType); assertNotNull(property); assertTrue(property.hasComplexValue()); assertEquals(3, property.getComplexValue().size()); final ClientProperty written = getClient().getReader().readProperty( - getClient().getWriter().writeProperty(property, format), format); + getClient().getWriter().writeProperty(property, contentType), contentType); // This is needed because type information gets lost with JSON serialization final ClientComplexValue typedValue = getClient().getObjectFactory(). newComplexValue(property.getComplexValue().getTypeName()); @@ -95,25 +95,25 @@ public class PropertyTest extends AbstractTest { @Test public void xmlComplex() throws Exception { - complex(ODataFormat.XML); + complex(ContentType.APPLICATION_XML); } @Test public void jsonComplex() throws Exception { - complex(ODataFormat.JSON); + complex(ContentType.JSON); } - private void collection(final ODataFormat format) throws ODataDeserializerException, ODataSerializerException { - final InputStream input = getClass().getResourceAsStream("Products_5_CoverColors." + getSuffix(format)); - final ClientProperty property = getClient().getReader().readProperty(input, format); + private void collection(final ContentType contentType) throws ODataDeserializerException, ODataSerializerException { + final InputStream input = getClass().getResourceAsStream("Products_5_CoverColors." + getSuffix(contentType)); + final ClientProperty property = getClient().getReader().readProperty(input, contentType); assertNotNull(property); assertTrue(property.hasCollectionValue()); assertEquals(3, property.getCollectionValue().size()); final ClientProperty written = getClient().getReader().readProperty( - getClient().getWriter().writeProperty(property, format), format); + getClient().getWriter().writeProperty(property, contentType), contentType); // This is needed because type information gets lost with JSON serialization - if (format == ODataFormat.XML) { + if(contentType.isCompatible(ContentType.APPLICATION_XML)) { final ClientCollectionValue typedValue = getClient().getObjectFactory(). newCollectionValue(property.getCollectionValue().getTypeName()); for (final Iterator itor = written.getCollectionValue().iterator(); itor.hasNext();) { @@ -129,11 +129,11 @@ public class PropertyTest extends AbstractTest { @Test public void xmlCollection() throws Exception { - collection(ODataFormat.XML); + collection(ContentType.APPLICATION_XML); } @Test public void jsonCollection() throws Exception { - collection(ODataFormat.JSON); + collection(ContentType.JSON); } } diff --git a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ServiceDocumentTest.java b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ServiceDocumentTest.java index b0a769f76..008b16513 100644 --- a/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ServiceDocumentTest.java +++ b/lib/client-core/src/test/java/org/apache/olingo/client/core/v4/ServiceDocumentTest.java @@ -18,21 +18,21 @@ */ package org.apache.olingo.client.core.v4; -import org.apache.olingo.client.api.ODataClient; -import org.apache.olingo.client.api.data.ServiceDocument; -import org.apache.olingo.client.core.AbstractTest; -import org.apache.olingo.commons.api.data.ResWrap; -import org.apache.olingo.client.api.domain.ClientServiceDocument; -import org.apache.olingo.client.api.serialization.ODataDeserializerException; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.junit.Test; - -import java.net.URI; - import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertTrue; +import java.net.URI; + +import org.apache.olingo.client.api.ODataClient; +import org.apache.olingo.client.api.data.ServiceDocument; +import org.apache.olingo.client.api.domain.ClientServiceDocument; +import org.apache.olingo.client.core.AbstractTest; +import org.apache.olingo.commons.api.data.ResWrap; +import org.apache.olingo.commons.api.format.ContentType; +import org.apache.olingo.client.api.serialization.ODataDeserializerException; +import org.junit.Test; + public class ServiceDocumentTest extends AbstractTest { @Override @@ -40,13 +40,13 @@ public class ServiceDocumentTest extends AbstractTest { return v4Client; } - private String getFileExtension(final ODataFormat format) { - return format == ODataFormat.XML ? "xml" : "json"; + private String getFileExtension(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_XML) ? "xml" : "json"; } - private ClientServiceDocument parse(final ODataFormat format) throws ODataDeserializerException { - ResWrap service = getClient().getDeserializer(format).toServiceDocument( - getClass().getResourceAsStream("serviceDocument." + getFileExtension(format))); + private ClientServiceDocument parse(final ContentType contentType) throws ODataDeserializerException { + ResWrap service = getClient().getDeserializer(contentType).toServiceDocument( + getClass().getResourceAsStream("serviceDocument." + getFileExtension(contentType))); assertEquals(URI.create("http://host/service/$metadata"), service.getContextURL()); assertEquals("W/\"MjAxMy0wNS0xM1QxNDo1NFo=\"", service.getMetadataETag()); @@ -56,20 +56,20 @@ public class ServiceDocumentTest extends AbstractTest { assertTrue(serviceDocument.getEntitySetNames().contains("Order Details")); assertEquals(URI.create("http://host/service/TopProducts"), - serviceDocument.getFunctionImportURI("TopProducts")); + serviceDocument.getFunctionImportURI("TopProducts")); assertEquals(URI.create("http://host/HR/"), - serviceDocument.getRelatedServiceDocumentsURIs().iterator().next()); + serviceDocument.getRelatedServiceDocumentsURIs().iterator().next()); return serviceDocument; } @Test public void json() throws Exception { - parse(ODataFormat.JSON); + parse(ContentType.JSON); } @Test public void xml() throws Exception { - parse(ODataFormat.XML); + parse(ContentType.APPLICATION_XML); } } diff --git a/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/AcceptType.java b/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/AcceptType.java index 734e007a5..874944b4d 100644 --- a/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/AcceptType.java +++ b/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/AcceptType.java @@ -122,14 +122,14 @@ public class AcceptType { /** * Creates a list of {@link AcceptType} objects based on given input string (format). - * @param format accept types, comma-separated, as specified for the HTTP header Accept + * @param contentType accept types, comma-separated, as specified for the HTTP header Accept * @return a list of AcceptType objects * @throws IllegalArgumentException if input string is not parseable */ - public static List create(final String format) { + public static List create(final String contentType) { List result = new ArrayList(); - String[] values = format.split(","); + String[] values = contentType.split(","); for (String value : values) { result.add(new AcceptType(value.trim())); } diff --git a/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ContentType.java b/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ContentType.java index aa3032384..bfdebe3f9 100644 --- a/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ContentType.java +++ b/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ContentType.java @@ -49,14 +49,20 @@ public final class ContentType { private static final String APPLICATION = "application"; private static final String TEXT = "text"; private static final String MULTIPART = "multipart"; - + + public static final ContentType APPLICATION_JSON = new ContentType(APPLICATION, "json", null); + public static final ContentType JSON = ContentType.create(ContentType.APPLICATION_JSON, "odata.metadata=minimal"); + public static final ContentType JSON_NO_METADATA = ContentType.create(ContentType.APPLICATION_JSON, + "odata.metadata=none"); + public static final ContentType JSON_FULL_METADATA = ContentType.create(ContentType.APPLICATION_JSON, + "odata.metadata=full"); + public static final ContentType APPLICATION_XML = new ContentType(APPLICATION, "xml", null); public static final ContentType APPLICATION_ATOM_XML = new ContentType(APPLICATION, "atom+xml", null); public static final ContentType APPLICATION_ATOM_XML_ENTRY = create(APPLICATION_ATOM_XML, "type=entry"); public static final ContentType APPLICATION_ATOM_XML_FEED = create(APPLICATION_ATOM_XML, "type=feed"); public static final ContentType APPLICATION_ATOM_SVC = new ContentType(APPLICATION, "atomsvc+xml", null); - public static final ContentType APPLICATION_JSON = new ContentType(APPLICATION, "json", null); public static final ContentType APPLICATION_OCTET_STREAM = new ContentType(APPLICATION, "octet-stream", null); @@ -75,8 +81,14 @@ public final class ContentType { public static final ContentType MULTIPART_MIXED = new ContentType(MULTIPART, "mixed", null); public static final ContentType MULTIPART_FORM_DATA = new ContentType(MULTIPART, "form-data", null); - public static final String PARAMETER_CHARSET_UTF8 = "charset=utf-8"; - + public static final String PARAMETER_CHARSET = "charset"; + public static final String PARAMETER_IEEE754_COMPATIBLE = "IEEE754Compatible"; + public static final String PARAMETER_ODATA_METADATA = "odata.metadata"; + + public static final String VALUE_ODATA_METADATA_NONE = "none"; + public static final String VALUE_ODATA_METADATA_MINIMAL = "minimal"; + public static final String VALUE_ODATA_METADATA_FULL = "full"; + private final String type; private final String subtype; private final Map parameters; @@ -132,12 +144,12 @@ public final class ContentType { /** * Creates a content type from format and key-value pairs for parameters. * - * @param format for example "application/json" + * @param contentType for example "application/json" * @param parameters for example "a=b", "c=d" * @return a new ContentType object */ - public static ContentType create(final String format, final String... parameters) { - ContentType ct = parse(format); + public static ContentType create(final String contentType, final String... parameters) { + ContentType ct = parse(contentType); for (String p : parameters) { final String[] keyvalue = TypeUtil.parseParameter(p); @@ -243,7 +255,18 @@ public final class ContentType { public Map getParameters() { return Collections.unmodifiableMap(parameters); } - + + /** + * Returns the value of a given parameter. + * If the parameter does not exists the method returns null + * + * @param name The parameter to get + * @return the value of the parameter or null if the parameter is not present + */ + public String getParameter(final String name) { + return parameters.get(name); + } + @Override public int hashCode() { return 1; @@ -300,7 +323,24 @@ public final class ContentType { public boolean isCompatible(final ContentType other) { return type.equalsIgnoreCase(other.type) && subtype.equalsIgnoreCase(other.subtype); } - + + /** + *

{@link ContentType}s are compatible + * if type and subtype have the same value.

+ *

The set parameters are always ignored + * (for compare with parameters see {@link #equals(Object)}).

+ * @return true if both instances are compatible (see definition above), otherwise false. + */ + public boolean isCompatible(final ContentType...otherTypes) { + for(final ContentType otherType : otherTypes) { + if(isCompatible(otherType)) { + return true; + } + } + + return false; + } + /** * Checks whether both strings are equal ignoring the case of the strings. * @@ -326,7 +366,7 @@ public final class ContentType { for (String key : parameters.keySet()) { sb.append(TypeUtil.PARAMETER_SEPARATOR).append(key) - .append(TypeUtil.PARAMETER_KEY_VALUE_SEPARATOR).append(parameters.get(key)); + .append(TypeUtil.PARAMETER_KEY_VALUE_SEPARATOR).append(parameters.get(key)); } return sb.toString(); } diff --git a/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ODataFormat.java b/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ODataFormat.java deleted file mode 100644 index 211494243..000000000 --- a/lib/commons-api/src/main/java/org/apache/olingo/commons/api/format/ODataFormat.java +++ /dev/null @@ -1,126 +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.commons.api.format; - -/** - * Available formats to be used in various contexts. - */ -public enum ODataFormat { - - /** JSON format with no metadata. */ - JSON_NO_METADATA(ContentType.create(ContentType.APPLICATION_JSON, "odata.metadata=none")), - /** JSON format with minimal metadata (default). */ - JSON(ContentType.create(ContentType.APPLICATION_JSON, "odata.metadata=minimal")), - /** JSON format with full metadata. */ - JSON_FULL_METADATA(ContentType.create(ContentType.APPLICATION_JSON, "odata.metadata=full")), - - /** XML format. */ - XML(ContentType.APPLICATION_XML), - /** Atom format. */ - ATOM(ContentType.APPLICATION_ATOM_XML), - - // media formats - APPLICATION_XML(ContentType.APPLICATION_XML), - APPLICATION_ATOM_XML(ContentType.APPLICATION_ATOM_XML), - APPLICATION_XHTML_XML(ContentType.APPLICATION_XHTML_XML), - APPLICATION_SVG_XML(ContentType.APPLICATION_SVG_XML), - APPLICATION_JSON(ContentType.APPLICATION_JSON), - APPLICATION_FORM_URLENCODED(ContentType.APPLICATION_FORM_URLENCODED), - MULTIPART_FORM_DATA(ContentType.MULTIPART_FORM_DATA), - APPLICATION_OCTET_STREAM(ContentType.APPLICATION_OCTET_STREAM), - TEXT_PLAIN(ContentType.TEXT_PLAIN), - TEXT_XML(ContentType.TEXT_XML), - TEXT_HTML(ContentType.TEXT_HTML); - - private final ContentType contentType; - - ODataFormat(final ContentType contentType) { - this.contentType = contentType; - } - - /** - * Gets format as {@link ContentType}. - * @return format as ContentType. - */ - public ContentType getContentType() { - return contentType; - } - - @Override - public String toString() { - if (contentType == null) { - throw new UnsupportedOperationException(); - } else { - return contentType.toContentTypeString(); - } - } - - /** - * Gets OData format from a content type. - * - * @param contentType content type - * @return OData format. - */ - public static ODataFormat fromContentType(final ContentType contentType) { - if (contentType == null) { - return null; - } - - if (contentType.isCompatible(ContentType.APPLICATION_ATOM_XML) - || contentType.isCompatible(ContentType.APPLICATION_ATOM_SVC)) { - return ATOM; - } else if (contentType.isCompatible(ContentType.APPLICATION_XML)) { - return XML; - } else if (contentType.isCompatible(ContentType.APPLICATION_JSON)) { - String jsonVariant = contentType.getParameters().get("odata.metadata"); - if (jsonVariant != null) { - if ("none".equals(jsonVariant)) { - return JSON_NO_METADATA; - } else if ("minimal".equals(jsonVariant)) { - return ODataFormat.JSON; - } else if ("full".equals(jsonVariant)) { - return ODataFormat.JSON_FULL_METADATA; - } - } - return JSON; - } else if (contentType.isCompatible(ContentType.APPLICATION_OCTET_STREAM)) { - return APPLICATION_OCTET_STREAM; - } else if (contentType.isCompatible(ContentType.TEXT_PLAIN)) { - return TEXT_PLAIN; - } else if (contentType.isCompatible(ContentType.APPLICATION_XHTML_XML)) { - return APPLICATION_XHTML_XML; - } else if (contentType.isCompatible(ContentType.APPLICATION_SVG_XML)) { - return APPLICATION_SVG_XML; - } else if (contentType.isCompatible(ContentType.APPLICATION_FORM_URLENCODED)) { - return APPLICATION_FORM_URLENCODED; - } else if (contentType.isCompatible(ContentType.MULTIPART_FORM_DATA)) { - return MULTIPART_FORM_DATA; - } else if (contentType.isCompatible(ContentType.TEXT_XML)) { - return TEXT_XML; - } else if (contentType.isCompatible(ContentType.TEXT_HTML)) { - return TEXT_HTML; - } - - throw new IllegalArgumentException("Unsupported content Type: " + contentType); - } - - public static ODataFormat fromString(final String contentType) { - return contentType == null ? null : fromContentType(ContentType.parse(contentType)); - } -} diff --git a/lib/commons-api/src/test/java/org/apache/olingo/commons/api/format/AcceptTypeTest.java b/lib/commons-api/src/test/java/org/apache/olingo/commons/api/format/AcceptTypeTest.java index a6248f39c..47cfc3f0f 100644 --- a/lib/commons-api/src/test/java/org/apache/olingo/commons/api/format/AcceptTypeTest.java +++ b/lib/commons-api/src/test/java/org/apache/olingo/commons/api/format/AcceptTypeTest.java @@ -18,15 +18,13 @@ */ package org.apache.olingo.commons.api.format; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertTrue; +import static org.junit.Assert.*; import java.util.List; import org.junit.Test; + public class AcceptTypeTest { @Test diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/OData.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/OData.java index e9dc225f8..120d6b2f6 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/OData.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/OData.java @@ -25,7 +25,7 @@ import org.apache.olingo.commons.api.ODataRuntimeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.provider.CsdlEdmProvider; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.deserializer.DeserializerException; import org.apache.olingo.server.api.deserializer.FixedFormatDeserializer; import org.apache.olingo.server.api.deserializer.ODataDeserializer; @@ -68,9 +68,9 @@ public abstract class OData { * Creates a new serializer object for rendering content in the specified format. * Serializers are used in Processor implementations. * - * @param format any format supported by Olingo (XML, JSON ...) + * @param contentType any format supported by Olingo (XML, JSON ...) */ - public abstract ODataSerializer createSerializer(ODataFormat format) throws SerializerException; + public abstract ODataSerializer createSerializer(ContentType contentType) throws SerializerException; /** * Creates a new serializer object for rendering content in a fixed format, e.g., for binary output. @@ -121,9 +121,9 @@ public abstract class OData { * Creates a new deserializer object for reading content in the specified format. * Deserializer are used in Processor implementations. * - * @param format any format supported by Olingo (XML, JSON ...) + * @param contentType any content type supported by Olingo (XML, JSON ...) */ - public abstract ODataDeserializer createDeserializer(ODataFormat format) throws DeserializerException; + public abstract ODataDeserializer createDeserializer(ContentType contentType) throws DeserializerException; /** * Creates a primitive-type instance. diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/processor/DefaultProcessor.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/processor/DefaultProcessor.java index c2097648a..c8481c56a 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/processor/DefaultProcessor.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/processor/DefaultProcessor.java @@ -21,7 +21,6 @@ package org.apache.olingo.server.api.processor; import java.io.ByteArrayInputStream; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.server.api.OData; @@ -72,7 +71,7 @@ public class DefaultProcessor implements MetadataProcessor, ServiceDocumentProce if (isNotModified) { response.setStatusCode(HttpStatusCode.NOT_MODIFIED.getStatusCode()); } else { - ODataSerializer serializer = odata.createSerializer(ODataFormat.fromContentType(requestedContentType)); + ODataSerializer serializer = odata.createSerializer(requestedContentType); response.setContent(serializer.serviceDocument(serviceMetadata, null).getContent()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); response.setHeader(HttpHeader.CONTENT_TYPE, requestedContentType.toContentTypeString()); @@ -97,7 +96,7 @@ public class DefaultProcessor implements MetadataProcessor, ServiceDocumentProce if (isNotModified) { response.setStatusCode(HttpStatusCode.NOT_MODIFIED.getStatusCode()); } else { - ODataSerializer serializer = odata.createSerializer(ODataFormat.fromContentType(requestedContentType)); + ODataSerializer serializer = odata.createSerializer(requestedContentType); response.setContent(serializer.metadataDocument(serviceMetadata).getContent()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); response.setHeader(HttpHeader.CONTENT_TYPE, requestedContentType.toContentTypeString()); @@ -109,7 +108,7 @@ public class DefaultProcessor implements MetadataProcessor, ServiceDocumentProce final ODataServerError serverError, final ContentType requestedContentType) { try { - ODataSerializer serializer = odata.createSerializer(ODataFormat.fromContentType(requestedContentType)); + ODataSerializer serializer = odata.createSerializer(requestedContentType); response.setContent(serializer.error(serverError).getContent()); response.setStatusCode(serverError.getStatusCode()); response.setHeader(HttpHeader.CONTENT_TYPE, requestedContentType.toContentTypeString()); diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ComplexSerializerOptions.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ComplexSerializerOptions.java index b89dac85a..99c69260a 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ComplexSerializerOptions.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ComplexSerializerOptions.java @@ -28,7 +28,7 @@ public class ComplexSerializerOptions { private ContextURL contextURL; private ExpandOption expand; private SelectOption select; - + /** Gets the {@link ContextURL}. */ public ContextURL getContextURL() { return contextURL; @@ -43,7 +43,7 @@ public class ComplexSerializerOptions { public SelectOption getSelect() { return select; } - + private ComplexSerializerOptions() {} /** Initializes the options builder. */ @@ -77,7 +77,7 @@ public class ComplexSerializerOptions { options.select = select; return this; } - + /** Builds the OData serializer options. */ public ComplexSerializerOptions build() { return options; diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntityCollectionSerializerOptions.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntityCollectionSerializerOptions.java index bbfe1bf38..d81530f03 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntityCollectionSerializerOptions.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntityCollectionSerializerOptions.java @@ -31,7 +31,7 @@ public class EntityCollectionSerializerOptions { private ExpandOption expand; private SelectOption select; private boolean onlyReferences; - + /** Gets the {@link ContextURL}. */ public ContextURL getContextURL() { return contextURL; @@ -100,7 +100,7 @@ public class EntityCollectionSerializerOptions { options.onlyReferences = ref; return this; } - + /** Builds the OData serializer options. */ public EntityCollectionSerializerOptions build() { return options; diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntitySerializerOptions.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntitySerializerOptions.java index 563b058a5..db73c431c 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntitySerializerOptions.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/EntitySerializerOptions.java @@ -28,7 +28,7 @@ public class EntitySerializerOptions { private ExpandOption expand; private SelectOption select; private boolean onlyReferences; - + /** Gets the {@link ContextURL}. */ public ContextURL getContextURL() { return contextURL; @@ -88,7 +88,7 @@ public class EntitySerializerOptions { options.onlyReferences = ref; return this; } - + /** Builds the OData serializer options. */ public EntitySerializerOptions build() { return options; diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ODataSerializer.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ODataSerializer.java index 3727064fe..21066bb5e 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ODataSerializer.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ODataSerializer.java @@ -18,7 +18,6 @@ */ package org.apache.olingo.server.api.serializer; -import org.apache.olingo.commons.api.data.ContextURL; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.Property; @@ -119,18 +118,18 @@ public interface ODataSerializer { * @param metadata metadata for the service * @param edmEntitySet {@link EdmEntitySet} * @param entity data of the entity - * @param contextURL {@link ContextURL} + * @param options {@link ReferenceSerializerOptions} */ - SerializerResult reference(ServiceMetadata metadata, EdmEntitySet edmEntitySet, Entity entity, - ContextURL contextURL) throws SerializerException; - + SerializerResult reference(ServiceMetadata metadata, EdmEntitySet edmEntitySet, Entity entity, + ReferenceSerializerOptions options) throws SerializerException; + /** * Writes entity-collection references into an InputStream. * @param metadata metadata for the service * @param edmEntitySet {@link EdmEntitySet} * @param entityCollection data of the entity collection - * @param contextURL {@link ContextURL} + * @param ReferenceCollectionSerializerOptions {@link ReferenceCollectionSerializerOptions} */ - SerializerResult referenceCollection(ServiceMetadata metadata, EdmEntitySet edmEntitySet, - EntityCollection entityCollection, ContextURL contextURL) throws SerializerException; + SerializerResult referenceCollection(ServiceMetadata metadata, EdmEntitySet edmEntitySet, + EntityCollection entityCollection, ReferenceCollectionSerializerOptions options) throws SerializerException; } diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/PrimitiveSerializerOptions.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/PrimitiveSerializerOptions.java index bd345993e..aa88b66ac 100644 --- a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/PrimitiveSerializerOptions.java +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/PrimitiveSerializerOptions.java @@ -30,7 +30,7 @@ public class PrimitiveSerializerOptions { private Integer precision; private Integer scale; private Boolean isUnicode; - + /** Gets the {@link ContextURL}. */ public ContextURL getContextURL() { return contextURL; @@ -60,7 +60,7 @@ public class PrimitiveSerializerOptions { public Boolean isUnicode() { return isUnicode; } - + private PrimitiveSerializerOptions() {} /** Initializes the options builder. */ @@ -112,7 +112,7 @@ public class PrimitiveSerializerOptions { options.isUnicode = isUnicode; return this; } - + /** Sets all facets from an EDM property. */ public Builder facetsFrom(final EdmProperty property) { options.isNullable = property.isNullable(); diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ReferenceCollectionSerializerOptions.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ReferenceCollectionSerializerOptions.java new file mode 100644 index 000000000..b889595fa --- /dev/null +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ReferenceCollectionSerializerOptions.java @@ -0,0 +1,71 @@ +/* + * 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.server.api.serializer; + +import org.apache.olingo.commons.api.data.ContextURL; +import org.apache.olingo.server.api.uri.queryoption.CountOption; + +/** Options for the OData serializer. */ +public class ReferenceCollectionSerializerOptions { + private ContextURL contextURL; + private CountOption count; + + /** Gets the {@link ContextURL}. */ + public ContextURL getContextURL() { + return contextURL; + } + + /** Gets the $count system query option. */ + public CountOption getCount() { + return count; + } + + private ReferenceCollectionSerializerOptions() {} + + /** Initializes the options builder. */ + public static Builder with() { + return new Builder(); + } + + /** Builder of OData serializer options. */ + public static final class Builder { + private ReferenceCollectionSerializerOptions options; + + public Builder() { + options = new ReferenceCollectionSerializerOptions(); + } + + /** Sets the {@link ContextURL}. */ + public Builder contextURL(final ContextURL contextURL) { + options.contextURL = contextURL; + return this; + } + + /** Sets the $count system query option. */ + public Builder count(final CountOption count) { + options.count = count; + return this; + } + + /** Builds the OData serializer options. */ + public ReferenceCollectionSerializerOptions build() { + return options; + } + } +} diff --git a/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ReferenceSerializerOptions.java b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ReferenceSerializerOptions.java new file mode 100644 index 000000000..0479ca4f3 --- /dev/null +++ b/lib/server-api/src/main/java/org/apache/olingo/server/api/serializer/ReferenceSerializerOptions.java @@ -0,0 +1,57 @@ +/* + * 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.server.api.serializer; + +import org.apache.olingo.commons.api.data.ContextURL; + +public class ReferenceSerializerOptions { + private ContextURL contextURL; + + /** Gets the {@link ContextURL}. */ + public ContextURL getContextURL() { + return contextURL; + } + + private ReferenceSerializerOptions() {} + + /** Initializes the options builder. */ + public static Builder with() { + return new Builder(); + } + + /** Builder of OData serializer options. */ + public static final class Builder { + private ReferenceSerializerOptions options; + + public Builder() { + options = new ReferenceSerializerOptions(); + } + + /** Sets the {@link ContextURL}. */ + public Builder contextURL(final ContextURL contextURL) { + options.contextURL = contextURL; + return this; + } + + /** Builds the OData serializer options. */ + public ReferenceSerializerOptions build() { + return options; + } + } +} diff --git a/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ErrorHandler.java b/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ErrorHandler.java index 83b1f522b..5f425da07 100644 --- a/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ErrorHandler.java +++ b/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ErrorHandler.java @@ -21,7 +21,6 @@ package org.apache.olingo.server.core; import java.io.ByteArrayInputStream; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.server.api.OData; @@ -96,9 +95,9 @@ public class ErrorHandler { requestedContentType = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(), request, this.customContent, RepresentationType.ERROR); } catch (final ContentNegotiatorException e) { - requestedContentType = ODataFormat.JSON.getContentType(); + requestedContentType = ContentType.JSON; } catch (UriParserException e) { - requestedContentType = ODataFormat.JSON.getContentType(); + requestedContentType = ContentType.JSON; } processError(response, serverError, requestedContentType); } @@ -106,8 +105,7 @@ public class ErrorHandler { void processError(ODataResponse response, ODataServerError serverError, ContentType requestedContentType) { try { - ODataSerializer serializer = this.odata.createSerializer(ODataFormat - .fromContentType(requestedContentType)); + ODataSerializer serializer = this.odata.createSerializer(requestedContentType); response.setContent(serializer.error(serverError).getContent()); response.setStatusCode(serverError.getStatusCode()); response.setHeader(HttpHeader.CONTENT_TYPE, requestedContentType.toContentTypeString()); diff --git a/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ServiceRequest.java b/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ServiceRequest.java index 53db4c8d0..76e8d5f47 100644 --- a/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ServiceRequest.java +++ b/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/ServiceRequest.java @@ -28,7 +28,6 @@ import java.util.StringTokenizer; import org.apache.olingo.commons.api.data.ContextURL; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpMethod; import org.apache.olingo.server.api.OData; @@ -143,16 +142,15 @@ public abstract class ServiceRequest { @SuppressWarnings("unchecked") public T getSerializerOptions(Class serilizerOptions, ContextURL contextUrl, boolean references) throws ContentNegotiatorException { - final ODataFormat format = ODataFormat.fromContentType(getResponseContentType()); - + if (serilizerOptions.isAssignableFrom(EntitySerializerOptions.class)) { return (T) EntitySerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : contextUrl) + .contextURL(isODataMetadataNone(getResponseContentType()) ? null : contextUrl) .expand(uriInfo.getExpandOption()).select(this.uriInfo.getSelectOption()) .setWriteOnlyReferences(references).build(); } else if (serilizerOptions.isAssignableFrom(EntityCollectionSerializerOptions.class)) { return (T) EntityCollectionSerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : contextUrl) + .contextURL(isODataMetadataNone(getResponseContentType()) ? null : contextUrl) .count(uriInfo.getCountOption()).expand(uriInfo.getExpandOption()) .select(uriInfo.getSelectOption()).setWriteOnlyReferences(references).build(); } else if (serilizerOptions.isAssignableFrom(ComplexSerializerOptions.class)) { @@ -191,8 +189,7 @@ public abstract class ServiceRequest { public ODataSerializer getSerializer() throws ContentNegotiatorException, SerializerException { - ODataFormat format = ODataFormat.fromContentType(getResponseContentType()); - return this.odata.createSerializer(format); + return this.odata.createSerializer(getResponseContentType()); } public Map getPreferences(){ @@ -261,4 +258,9 @@ public abstract class ServiceRequest { dispatcher.visit(uriInfo); return (DataRequest)dispatcher.request; } + + private boolean isODataMetadataNone(final ContentType contentType) { + return contentType.isCompatible(ContentType.JSON) + && ContentType.VALUE_ODATA_METADATA_NONE.equals(contentType.getParameter(ContentType.PARAMETER_ODATA_METADATA)); + } } diff --git a/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/requests/DataRequest.java b/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/requests/DataRequest.java index 0d98de501..7f2273cfc 100644 --- a/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/requests/DataRequest.java +++ b/lib/server-core-ext/src/main/java/org/apache/olingo/server/core/requests/DataRequest.java @@ -41,14 +41,13 @@ import org.apache.olingo.commons.api.edm.EdmNavigationPropertyBinding; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; import org.apache.olingo.commons.core.edm.primitivetype.EdmStream; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.ODataApplicationException; -import org.apache.olingo.server.api.ODataResponse; import org.apache.olingo.server.api.ODataLibraryException; +import org.apache.olingo.server.api.ODataResponse; import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.deserializer.DeserializerException; import org.apache.olingo.server.api.deserializer.DeserializerException.MessageKeys; @@ -331,8 +330,7 @@ public class DataRequest extends ServiceRequest { } private Entity getEntityFromClient() throws DeserializerException { - ODataDeserializer deserializer = odata.createDeserializer(ODataFormat - .fromContentType(getRequestContentType())); + ODataDeserializer deserializer = odata.createDeserializer(getRequestContentType()); return deserializer.entity(getODataRequest().getBody(), getEntitySet().getEntityType()).getEntity(); } @@ -459,8 +457,7 @@ public class DataRequest extends ServiceRequest { // /odata-json-format-v4.0-errata02-os-complete.html#_Toc403940643 // The below code reads as property and converts to an URI private List getPayload() throws DeserializerException { - ODataDeserializer deserializer = odata.createDeserializer(ODataFormat - .fromContentType(getRequestContentType())); + ODataDeserializer deserializer = odata.createDeserializer(getRequestContentType()); return deserializer.entityReferences(getODataRequest().getBody()).getEntityReferences(); } @@ -700,8 +697,7 @@ public class DataRequest extends ServiceRequest { private org.apache.olingo.commons.api.data.Property getPropertyValueFromClient( EdmProperty edmProperty) throws DeserializerException { - ODataDeserializer deserializer = odata.createDeserializer(ODataFormat - .fromContentType(getRequestContentType())); + ODataDeserializer deserializer = odata.createDeserializer(getRequestContentType()); return deserializer.property(getODataRequest().getBody(), edmProperty).getProperty(); } diff --git a/lib/server-core-ext/src/test/java/org/apache/olingo/server/example/TripPinDataModel.java b/lib/server-core-ext/src/test/java/org/apache/olingo/server/example/TripPinDataModel.java index 290f38d5c..646e835b1 100644 --- a/lib/server-core-ext/src/test/java/org/apache/olingo/server/example/TripPinDataModel.java +++ b/lib/server-core-ext/src/test/java/org/apache/olingo/server/example/TripPinDataModel.java @@ -45,6 +45,7 @@ import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.edm.EdmType; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.edm.constants.EdmTypeKind; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.ODataApplicationException; import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.deserializer.DeserializerException; @@ -115,7 +116,7 @@ public class TripPinDataModel { private EntityCollection loadEnities(String entitySetName, EdmEntityType type) { try { - ODataJsonDeserializer deserializer = new ODataJsonDeserializer(); + ODataJsonDeserializer deserializer = new ODataJsonDeserializer(ContentType.JSON); EntityCollection set = deserializer.entityCollection(new FileInputStream(new File( "src/test/resources/" + entitySetName.toLowerCase() + ".json")), type).getEntityCollection(); diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/ContentNegotiator.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/ContentNegotiator.java index 351b76913..a262b698c 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/ContentNegotiator.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/ContentNegotiator.java @@ -23,7 +23,6 @@ import java.util.List; import org.apache.olingo.commons.api.format.AcceptType; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.server.api.ODataRequest; import org.apache.olingo.server.api.serializer.CustomContentTypeSupport; @@ -32,6 +31,10 @@ import org.apache.olingo.server.api.uri.queryoption.FormatOption; public class ContentNegotiator { + private static final String ATOM = "atom"; + private static final String JSON = "json"; + private static final String XML = "xml"; + private ContentNegotiator() {} private static List getDefaultSupportedContentTypes(final RepresentationType type) { @@ -48,9 +51,9 @@ public class ContentNegotiator { return Arrays.asList(ContentType.MULTIPART_MIXED); default: return Arrays.asList( - ODataFormat.JSON.getContentType(), - ODataFormat.JSON_NO_METADATA.getContentType(), - ODataFormat.APPLICATION_JSON.getContentType()); + ContentType.JSON, + ContentType.JSON_NO_METADATA, + ContentType.APPLICATION_JSON); } } @@ -78,14 +81,14 @@ public class ContentNegotiator { if (formatOption != null && formatOption.getFormat() != null) { final String formatString = formatOption.getFormat().trim(); - final ODataFormat format = - ODataFormat.JSON.name().equalsIgnoreCase(formatString) ? ODataFormat.JSON : - ODataFormat.XML.name().equalsIgnoreCase(formatString) ? ODataFormat.XML : - ODataFormat.ATOM.name().equalsIgnoreCase(formatString) ? ODataFormat.ATOM : null; + final ContentType contentType = + JSON.equalsIgnoreCase(formatString) ? ContentType.JSON : + XML.equalsIgnoreCase(formatString) ? ContentType.APPLICATION_XML : + ATOM.equalsIgnoreCase(formatString) ? ContentType.APPLICATION_ATOM_XML : null; try { result = getAcceptedType( - AcceptType.fromContentType(format == null ? - ContentType.create(formatOption.getFormat()) : format.getContentType()), + AcceptType.fromContentType(contentType == null ? + ContentType.create(formatOption.getFormat()) : contentType), supportedContentTypes); } catch (final IllegalArgumentException e) { // Exception results in result = null for next check. @@ -128,11 +131,23 @@ public class ContentNegotiator { if (acceptedType.getParameters().containsKey("charset")) { final String value = acceptedType.getParameters().get("charset"); if ("utf8".equalsIgnoreCase(value) || "utf-8".equalsIgnoreCase(value)) { - contentType = ContentType.create(contentType, ContentType.PARAMETER_CHARSET_UTF8); + contentType = ContentType.create(contentType, ContentType.PARAMETER_CHARSET + "=utf-8"); } else { throw new IllegalArgumentException("charset not supported: " + acceptedType); } } + + if(acceptedType.getParameters().containsKey("ieee754compatible")) { + final String value = acceptedType.getParameters().get("ieee754compatible"); + if("true".equalsIgnoreCase(value)) { + contentType = ContentType.create(contentType, ContentType.PARAMETER_IEEE754_COMPATIBLE + "=true"); + } else if("false".equalsIgnoreCase(value)) { + contentType = ContentType.create(contentType, ContentType.PARAMETER_IEEE754_COMPATIBLE + "=false"); + } else { + throw new IllegalArgumentException("Invalid IEEE754Compatible value " + acceptedType); + } + } + if (acceptedType.matches(contentType)) { return contentType; } diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataHandler.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataHandler.java index b9989f037..47bef3d7c 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataHandler.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataHandler.java @@ -23,7 +23,6 @@ import java.util.List; import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpMethod; import org.apache.olingo.server.api.OData; @@ -140,7 +139,7 @@ public class ODataHandler { uriInfo == null ? null : uriInfo.getFormatOption(), request, getCustomContentTypeSupport(), RepresentationType.ERROR); } catch (final ContentNegotiatorException e) { - requestedContentType = ODataFormat.JSON.getContentType(); + requestedContentType = ContentType.JSON; } exceptionProcessor.processError(request, response, serverError, requestedContentType); } diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataImpl.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataImpl.java index 35c1ccf93..c3da9b4bf 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataImpl.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/ODataImpl.java @@ -24,7 +24,7 @@ import java.util.List; import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.provider.CsdlEdmProvider; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.ODataHttpHandler; @@ -52,20 +52,17 @@ import org.apache.olingo.server.core.uri.UriHelperImpl; public class ODataImpl extends OData { @Override - public ODataSerializer createSerializer(final ODataFormat format) throws SerializerException { + public ODataSerializer createSerializer(final ContentType contentType) throws SerializerException { ODataSerializer serializer; - switch (format) { - case JSON: - case JSON_NO_METADATA: - case JSON_FULL_METADATA: - serializer = new ODataJsonSerializer(format); - break; - case XML: + + // odata.metadata=none, odata.metadata=minimal, odata.metadata=full + if(contentType.isCompatible(ContentType.APPLICATION_JSON)) { + serializer = new ODataJsonSerializer(contentType); + } else if(contentType.isCompatible(ContentType.APPLICATION_XML)) { serializer = new ODataXmlSerializerImpl(); - break; - default: - throw new SerializerException("Unsupported format: " + format, - SerializerException.MessageKeys.UNSUPPORTED_FORMAT, format.toString()); + } else { + throw new SerializerException("Unsupported format: " + contentType.toContentTypeString(), + SerializerException.MessageKeys.UNSUPPORTED_FORMAT, contentType.toContentTypeString()); } return serializer; @@ -104,20 +101,19 @@ public class ODataImpl extends OData { } @Override - public ODataDeserializer createDeserializer(final ODataFormat format) throws DeserializerException { + public ODataDeserializer createDeserializer(final ContentType contentType) throws DeserializerException { ODataDeserializer deserializer; - switch (format) { - case JSON: - case JSON_NO_METADATA: - case JSON_FULL_METADATA: - deserializer = new ODataJsonDeserializer(); - break; - case XML: + + // odata.metadata=none, odata.metadata=minimal, odata.metadata=full + if(contentType.isCompatible(ContentType.JSON)) { + deserializer = new ODataJsonDeserializer(contentType); + //} else if(contentType.isCompatible(ContentType.APPLICATION_XML)) { // We do not support XML deserialization right now so this must lead to an error. - default: - throw new DeserializerException("Unsupported format: " + format, - DeserializerException.MessageKeys.UNSUPPORTED_FORMAT, format.toString()); + } else { + throw new DeserializerException("Unsupported format: " + contentType.toContentTypeString(), + DeserializerException.MessageKeys.UNSUPPORTED_FORMAT, contentType.toContentTypeString()); } + return deserializer; } diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializer.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializer.java index a03206be2..c67efbc0a 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializer.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializer.java @@ -50,7 +50,10 @@ import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.edm.EdmType; import org.apache.olingo.commons.api.edm.EdmTypeDefinition; +import org.apache.olingo.commons.api.format.ContentType; +import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; import org.apache.olingo.server.api.deserializer.DeserializerException; +import org.apache.olingo.server.api.deserializer.DeserializerException.MessageKeys; import org.apache.olingo.server.api.deserializer.DeserializerResult; import org.apache.olingo.server.api.deserializer.ODataDeserializer; import org.apache.olingo.server.core.deserializer.DeserializerResultImpl; @@ -72,7 +75,14 @@ public class ODataJsonDeserializer implements ODataDeserializer { private static final String ODATA_ANNOTATION_MARKER = "@"; private static final String ODATA_CONTROL_INFORMATION_PREFIX = "@odata."; - + private static final EdmPrimitiveType EDM_INT64 = EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Int64); + private static final EdmPrimitiveType EDM_DECIMAL = EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Decimal); + private final boolean isIEEE754Compatible; + + public ODataJsonDeserializer(final ContentType contentType) { + isIEEE754Compatible = isODataIEEE754Compatible(contentType); + } + @Override public DeserializerResult entityCollection(final InputStream stream, final EdmEntityType edmEntityType) throws DeserializerException { @@ -663,8 +673,17 @@ public class ODataJsonDeserializer implements ODataDeserializer { EdmPrimitiveType edmPrimitiveType = (EdmPrimitiveType) type; checkJsonTypeBasedOnPrimitiveType(name, edmPrimitiveType.getName(), jsonNode); Class javaClass = getJavaClassForPrimitiveType(mapping, edmPrimitiveType); - return edmPrimitiveType.valueOfString(jsonNode.asText(), - isNullable, maxLength, precision, scale, isUnicode, javaClass); + String jsonNodeAsText = jsonNode.asText(); + + if (isIEEE754Compatible && (edmPrimitiveType.equals(EDM_INT64) || edmPrimitiveType.equals(EDM_DECIMAL))) { + if(jsonNodeAsText.length() == 0) { + throw new DeserializerException("IEEE754Compatible values must not be of length 0", + MessageKeys.INVALID_NULL_PROPERTY, name); + } + } + + return edmPrimitiveType.valueOfString(jsonNodeAsText, isNullable, maxLength, precision, scale, isUnicode, + javaClass); } catch (EdmPrimitiveTypeException e) { throw new DeserializerException( "Invalid value: " + jsonNode.asText() + " for property: " + name, e, @@ -731,20 +750,33 @@ public class ODataJsonDeserializer implements ODataDeserializer { + " property: " + propertyName, DeserializerException.MessageKeys.INVALID_VALUE_FOR_PROPERTY, propertyName); } break; - // Numbers + // Numbers (must be numbers) case Int16: case Int32: - case Int64: case Byte: case SByte: case Single: case Double: - case Decimal: if (!jsonNode.isNumber()) { throw new DeserializerException("Invalid json type: " + jsonNode.getNodeType() + " for edm " + primKind + " property: " + propertyName, DeserializerException.MessageKeys.INVALID_VALUE_FOR_PROPERTY, propertyName); } break; + case Int64: + case Decimal: + // Numbers (eighter numers or string) + if(isIEEE754Compatible) { + if (!jsonNode.isTextual()) { + throw new DeserializerException("Invalid json type: " + jsonNode.getNodeType() + " for edm " + primKind + + " property: " + propertyName, DeserializerException.MessageKeys.INVALID_VALUE_FOR_PROPERTY, propertyName); + } + } else { + if (!jsonNode.isNumber()) { + throw new DeserializerException("Invalid json type: " + jsonNode.getNodeType() + " for edm " + primKind + + " property: " + propertyName, DeserializerException.MessageKeys.INVALID_VALUE_FOR_PROPERTY, propertyName); + } + } + break; // Strings case String: case Binary: @@ -848,4 +880,10 @@ public class ODataJsonDeserializer implements ODataDeserializer { DeserializerException.MessageKeys.UNKNOWN_CONTENT); } } + + private boolean isODataIEEE754Compatible(final ContentType contentType) { + return contentType.getParameters().containsKey(ContentType.PARAMETER_IEEE754_COMPATIBLE) + && Boolean.TRUE.toString().toLowerCase().equals( + contentType.getParameter(ContentType.PARAMETER_IEEE754_COMPATIBLE).toLowerCase()); + } } diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializer.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializer.java index 168adfa41..f50fcadf7 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializer.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializer.java @@ -41,7 +41,7 @@ import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.edm.EdmStructuredType; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.primitivetype.EdmPrimitiveTypeFactory; import org.apache.olingo.server.api.ODataServerError; import org.apache.olingo.server.api.ServiceMetadata; @@ -50,6 +50,8 @@ import org.apache.olingo.server.api.serializer.EntityCollectionSerializerOptions import org.apache.olingo.server.api.serializer.EntitySerializerOptions; import org.apache.olingo.server.api.serializer.ODataSerializer; import org.apache.olingo.server.api.serializer.PrimitiveSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceCollectionSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceSerializerOptions; import org.apache.olingo.server.api.serializer.SerializerException; import org.apache.olingo.server.api.serializer.SerializerResult; import org.apache.olingo.server.api.uri.UriHelper; @@ -58,6 +60,7 @@ import org.apache.olingo.server.api.uri.queryoption.ExpandOption; import org.apache.olingo.server.api.uri.queryoption.SelectOption; import org.apache.olingo.server.core.serializer.SerializerResultImpl; import org.apache.olingo.server.core.serializer.utils.CircleStreamBuffer; +import org.apache.olingo.server.core.serializer.utils.ContentTypeHelper; import org.apache.olingo.server.core.serializer.utils.ContextURLBuilder; import org.apache.olingo.server.core.serializer.utils.ExpandSelectHelper; import org.apache.olingo.server.core.uri.UriHelperImpl; @@ -72,10 +75,12 @@ public class ODataJsonSerializer implements ODataSerializer { private static final Logger log = LoggerFactory.getLogger(ODataJsonSerializer.class); - private final ODataFormat format; - - public ODataJsonSerializer(final ODataFormat format) { - this.format = format; + private final ContentType contentType; + private final boolean isIEEE754Compatible; + + public ODataJsonSerializer(final ContentType contentType) { + this.isIEEE754Compatible = isODataIEEE754Compatible(contentType); + this.contentType = contentType; } @Override @@ -89,7 +94,7 @@ public class ODataJsonSerializer implements ODataSerializer { gen = new JsonFactory().createGenerator(buffer.getOutputStream()) .setPrettyPrinter(new DefaultPrettyPrinter()); - new ServiceDocumentJsonSerializer(metadata, serviceRoot, format).writeServiceDocument(gen); + new ServiceDocumentJsonSerializer(metadata, serviceRoot, contentType).writeServiceDocument(gen); gen.close(); @@ -180,7 +185,8 @@ public class ODataJsonSerializer implements ODataSerializer { writeEntity(metadata, entityType, entity, contextURL, options == null ? null : options.getExpand(), options == null ? null : options.getSelect(), - options == null ? false : options.onlyReferences(), json); + options == null ? false : options.onlyReferences(), + json); json.close(); } catch (final IOException e) { throw new SerializerException("An I/O exception occurred.", e, @@ -190,7 +196,7 @@ public class ODataJsonSerializer implements ODataSerializer { } private ContextURL checkContextURL(final ContextURL contextURL) throws SerializerException { - if (format == ODataFormat.JSON_NO_METADATA) { + if(ContentTypeHelper.isODataMetadataNone(contentType)) { return null; } else if (contextURL == null) { throw new SerializerException("ContextURL null!", SerializerException.MessageKeys.NO_CONTEXT_URL); @@ -199,7 +205,7 @@ public class ODataJsonSerializer implements ODataSerializer { } private void writeMetadataETag(final ServiceMetadata metadata, JsonGenerator json) throws IOException { - if (format != ODataFormat.JSON_NO_METADATA + if (!ContentTypeHelper.isODataMetadataNone(contentType) && metadata != null && metadata.getServiceMetadataETagSupport() != null && metadata.getServiceMetadataETagSupport().getMetadataETag() != null) { @@ -227,10 +233,10 @@ public class ODataJsonSerializer implements ODataSerializer { protected void writeEntity(final ServiceMetadata metadata, final EdmEntityType entityType, final Entity entity, final ContextURL contextURL, final ExpandOption expand, - final SelectOption select, final boolean onlyReference, final JsonGenerator json) - throws IOException, SerializerException { + final SelectOption select, final boolean onlyReference, final JsonGenerator json) + throws IOException, SerializerException { json.writeStartObject(); - if (format != ODataFormat.JSON_NO_METADATA) { + if(!ContentTypeHelper.isODataMetadataNone(contentType)) { if (contextURL != null) { // top-level entity json.writeStringField(Constants.JSON_CONTEXT, ContextURLBuilder.create(contextURL).toASCIIString()); writeMetadataETag(metadata, json); @@ -315,7 +321,8 @@ public class ODataJsonSerializer implements ODataSerializer { } protected void writeProperties(final EdmStructuredType type, final List properties, - final SelectOption select, final JsonGenerator json) throws IOException, SerializerException { + final SelectOption select, final JsonGenerator json) + throws IOException, SerializerException { final boolean all = ExpandSelectHelper.isAll(select); final Set selected = all ? null : ExpandSelectHelper.getSelectedPropertyNames(select.getSelectItems()); @@ -349,19 +356,15 @@ public class ODataJsonSerializer implements ODataSerializer { } writeExpandedNavigationProperty(metadata, property, navigationLink, innerOptions == null ? null : innerOptions.getExpandOption(), - innerOptions == null ? null : innerOptions.getSelectOption(), - innerOptions == null ? false: innerOptions.isRef(), - json); + innerOptions == null ? null : innerOptions.getSelectOption(), json); } } } } - protected void writeExpandedNavigationProperty(final ServiceMetadata metadata, - final EdmNavigationProperty property, final Link navigationLink, - final ExpandOption innerExpand, final SelectOption innerSelect, boolean onlyReference, - final JsonGenerator json) - throws IOException, SerializerException { + protected void writeExpandedNavigationProperty(final ServiceMetadata metadata, final EdmNavigationProperty property, + final Link navigationLink, final ExpandOption innerExpand, final SelectOption innerSelect, + final JsonGenerator json) throws IOException, SerializerException { json.writeFieldName(property.getName()); if (property.isCollection()) { if (navigationLink == null || navigationLink.getInlineEntitySet() == null) { @@ -369,20 +372,21 @@ public class ODataJsonSerializer implements ODataSerializer { json.writeEndArray(); } else { writeEntitySet(metadata, property.getType(), navigationLink.getInlineEntitySet(), innerExpand, - innerSelect, onlyReference, json); + innerSelect, false, json); } } else { if (navigationLink == null || navigationLink.getInlineEntity() == null) { json.writeNull(); } else { writeEntity(metadata, property.getType(), navigationLink.getInlineEntity(), null, - innerExpand, innerSelect, onlyReference, json); + innerExpand, innerSelect, false, json); } } } protected void writeProperty(final EdmProperty edmProperty, final Property property, - final Set> selectedPaths, final JsonGenerator json) throws IOException, SerializerException { + final Set> selectedPaths, final JsonGenerator json) + throws IOException, SerializerException { json.writeFieldName(edmProperty.getName()); if (property == null || property.isNull()) { if (edmProperty.isNullable() == Boolean.FALSE) { @@ -397,31 +401,27 @@ public class ODataJsonSerializer implements ODataSerializer { } private void writePropertyValue(final EdmProperty edmProperty, - final Property property, final Set> selectedPaths, - final JsonGenerator json) throws IOException, SerializerException { + final Property property, final Set> selectedPaths, final JsonGenerator json) + throws IOException, SerializerException { try { if (edmProperty.isPrimitive()) { if (edmProperty.isCollection()) { writePrimitiveCollection((EdmPrimitiveType) edmProperty.getType(), property, edmProperty.isNullable(), edmProperty.getMaxLength(), - edmProperty.getPrecision(), edmProperty.getScale(), edmProperty.isUnicode(), - json); + edmProperty.getPrecision(), edmProperty.getScale(), edmProperty.isUnicode(), json); } else { writePrimitive((EdmPrimitiveType) edmProperty.getType(), property, edmProperty.isNullable(), edmProperty.getMaxLength(), - edmProperty.getPrecision(), edmProperty.getScale(), edmProperty.isUnicode(), - json); + edmProperty.getPrecision(), edmProperty.getScale(), edmProperty.isUnicode(), json); } } else if (edmProperty.isCollection()) { writeComplexCollection((EdmComplexType) edmProperty.getType(), property, selectedPaths, json); } else if (property.isComplex()) { - writeComplexValue((EdmComplexType) edmProperty.getType(), property.asComplex().getValue(), - selectedPaths, json); + writeComplexValue((EdmComplexType) edmProperty.getType(), property.asComplex().getValue(), selectedPaths, json); } else if (property.isEnum()) { writePrimitive((EdmPrimitiveType) edmProperty.getType(), property, edmProperty.isNullable(), edmProperty.getMaxLength(), - edmProperty.getPrecision(), edmProperty.getScale(), edmProperty.isUnicode(), - json); + edmProperty.getPrecision(), edmProperty.getScale(), edmProperty.isUnicode(), json); } else { throw new SerializerException("Property type not yet supported!", SerializerException.MessageKeys.UNSUPPORTED_PROPERTY_TYPE, edmProperty.getName()); @@ -435,8 +435,8 @@ public class ODataJsonSerializer implements ODataSerializer { private void writePrimitiveCollection(final EdmPrimitiveType type, final Property property, final Boolean isNullable, final Integer maxLength, final Integer precision, final Integer scale, - final Boolean isUnicode, - final JsonGenerator json) throws IOException, EdmPrimitiveTypeException, SerializerException { + final Boolean isUnicode, final JsonGenerator json) + throws IOException, EdmPrimitiveTypeException, SerializerException { json.writeStartArray(); for (Object value : property.asCollection()) { switch (property.getValueType()) { @@ -495,14 +495,17 @@ public class ODataJsonSerializer implements ODataSerializer { protected void writePrimitiveValue(final EdmPrimitiveType type, final Object primitiveValue, final Boolean isNullable, final Integer maxLength, final Integer precision, final Integer scale, - final Boolean isUnicode, - final JsonGenerator json) throws EdmPrimitiveTypeException, IOException { + final Boolean isUnicode, final JsonGenerator json) throws EdmPrimitiveTypeException, IOException { final String value = type.valueToString(primitiveValue, isNullable, maxLength, precision, scale, isUnicode); if (value == null) { json.writeNull(); } else if(type == EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Boolean)) { json.writeBoolean(Boolean.parseBoolean(value)); + } else if(isIEEE754Compatible && + ( type == EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Int64) + || type == EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Decimal))) { + json.writeString(value.toString()); } else if (type == EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Byte) || type == EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Decimal) || type == EdmPrimitiveTypeFactory.getInstance(EdmPrimitiveTypeKind.Double) @@ -559,8 +562,7 @@ public class ODataJsonSerializer implements ODataSerializer { json.writeFieldName(Constants.VALUE); writePrimitive(type, property, options.isNullable(), options.getMaxLength(), options.getPrecision(), options.getScale(), - options.isUnicode(), - json); + options.isUnicode(), json); } json.writeEndObject(); json.close(); @@ -622,8 +624,7 @@ public class ODataJsonSerializer implements ODataSerializer { json.writeFieldName(Constants.VALUE); writePrimitiveCollection(type, property, options.isNullable(), options.getMaxLength(), options.getPrecision(), options.getScale(), - options.isUnicode(), - json); + options.isUnicode(), json); json.writeEndObject(); json.close(); } catch (final IOException e) { @@ -666,8 +667,8 @@ public class ODataJsonSerializer implements ODataSerializer { @Override public SerializerResult reference(final ServiceMetadata metadata, final EdmEntitySet edmEntitySet, - final Entity entity, final ContextURL contextURL) throws SerializerException { - + final Entity entity, final ReferenceSerializerOptions options) throws SerializerException { + final ContextURL contextURL = checkContextURL(options == null ? null : options.getContextURL()); final CircleStreamBuffer buffer = new CircleStreamBuffer(); final UriHelper uriHelper = new UriHelperImpl(); @@ -685,8 +686,9 @@ public class ODataJsonSerializer implements ODataSerializer { @Override public SerializerResult referenceCollection(final ServiceMetadata metadata, final EdmEntitySet edmEntitySet, - final EntityCollection entityCollection, final ContextURL contextURL) throws SerializerException { - + final EntityCollection entityCollection, final ReferenceCollectionSerializerOptions options) + throws SerializerException { + final ContextURL contextURL = checkContextURL(options == null ? null : options.getContextURL()); final CircleStreamBuffer buffer = new CircleStreamBuffer(); final UriHelper uriHelper = new UriHelperImpl(); @@ -694,12 +696,12 @@ public class ODataJsonSerializer implements ODataSerializer { final JsonGenerator json = new JsonFactory().createGenerator(buffer.getOutputStream()); json.writeStartObject(); - if(entityCollection.getCount() != null) { + json.writeStringField(Constants.JSON_CONTEXT, ContextURLBuilder.create(contextURL).toASCIIString()); + writeMetadataETag(metadata, json); + if(options != null && options.getCount() != null) { writeCount(entityCollection, json); } - json.writeStringField(Constants.JSON_CONTEXT, ContextURLBuilder.create(contextURL).toASCIIString()); - writeMetadataETag(metadata, json); writeReferenceCollection(edmEntitySet, entityCollection, uriHelper,json); if(entityCollection.getNext() != null) { @@ -718,7 +720,7 @@ public class ODataJsonSerializer implements ODataSerializer { protected void writeReferenceCollection(final EdmEntitySet edmEntitySet, final EntityCollection entityCollection, final UriHelper uriHelper, final JsonGenerator json) throws IOException, SerializerException { json.writeArrayFieldStart(Constants.VALUE); - + for(final Entity entity : entityCollection.getEntities()) { writeReference(null, edmEntitySet, entity, null, uriHelper, json); } @@ -739,11 +741,21 @@ public class ODataJsonSerializer implements ODataSerializer { json.writeEndObject(); } - private void writeCount(final EntityCollection entitySet, JsonGenerator json) throws IOException { - json.writeNumberField(Constants.JSON_COUNT, entitySet.getCount()); + private void writeCount(final EntityCollection entitySet, final JsonGenerator json) throws IOException { + if(isIEEE754Compatible) { + json.writeStringField(Constants.JSON_COUNT, entitySet.getCount().toString()); + } else { + json.writeNumberField(Constants.JSON_COUNT, entitySet.getCount()); + } } private void writeNextLink(final EntityCollection entitySet, JsonGenerator json) throws IOException { json.writeStringField(Constants.JSON_NEXT_LINK, entitySet.getNext().toASCIIString()); } + + private boolean isODataIEEE754Compatible(final ContentType contentType) { + return contentType.getParameters().containsKey(ContentType.PARAMETER_IEEE754_COMPATIBLE) + && Boolean.TRUE.toString().toLowerCase().equals( + contentType.getParameter(ContentType.PARAMETER_IEEE754_COMPATIBLE).toLowerCase()); + } } diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentJsonSerializer.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentJsonSerializer.java index 65b467370..5b341849c 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentJsonSerializer.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentJsonSerializer.java @@ -26,8 +26,9 @@ import org.apache.olingo.commons.api.edm.EdmEntityContainer; import org.apache.olingo.commons.api.edm.EdmEntitySet; import org.apache.olingo.commons.api.edm.EdmFunctionImport; import org.apache.olingo.commons.api.edm.EdmSingleton; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.ServiceMetadata; +import org.apache.olingo.server.core.serializer.utils.ContentTypeHelper; import com.fasterxml.jackson.core.JsonGenerator; @@ -40,13 +41,13 @@ public class ServiceDocumentJsonSerializer { private final ServiceMetadata metadata; private final String serviceRoot; - private final ODataFormat format; + private final ContentType contentType; public ServiceDocumentJsonSerializer(final ServiceMetadata metadata, final String serviceRoot, - final ODataFormat format) { + final ContentType contentType) { this.metadata = metadata; this.serviceRoot = serviceRoot; - this.format = format; + this.contentType = contentType; } public void writeServiceDocument(final JsonGenerator gen) throws IOException { @@ -58,7 +59,7 @@ public class ServiceDocumentJsonSerializer { + Constants.METADATA; gen.writeObjectField(Constants.JSON_CONTEXT, metadataUri); - if (format != ODataFormat.JSON_NO_METADATA + if (!ContentTypeHelper.isODataMetadataNone(contentType) && metadata != null && metadata.getServiceMetadataETagSupport() != null && metadata.getServiceMetadataETagSupport().getMetadataETag() != null) { diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/utils/ContentTypeHelper.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/utils/ContentTypeHelper.java new file mode 100644 index 000000000..1e8066652 --- /dev/null +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/utils/ContentTypeHelper.java @@ -0,0 +1,28 @@ +/* + * 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.server.core.serializer.utils; + +import org.apache.olingo.commons.api.format.ContentType; + +public class ContentTypeHelper { + public static boolean isODataMetadataNone(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_JSON) + && ContentType.VALUE_ODATA_METADATA_NONE.equals(contentType.getParameter(ContentType.PARAMETER_ODATA_METADATA)); + } +} diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/xml/ODataXmlSerializerImpl.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/xml/ODataXmlSerializerImpl.java index e6b04a6b4..1e7349bef 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/xml/ODataXmlSerializerImpl.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/serializer/xml/ODataXmlSerializerImpl.java @@ -22,7 +22,6 @@ import javax.xml.stream.XMLOutputFactory; import javax.xml.stream.XMLStreamException; import javax.xml.stream.XMLStreamWriter; -import org.apache.olingo.commons.api.data.ContextURL; import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.Property; @@ -37,6 +36,8 @@ import org.apache.olingo.server.api.serializer.EntityCollectionSerializerOptions import org.apache.olingo.server.api.serializer.EntitySerializerOptions; import org.apache.olingo.server.api.serializer.ODataSerializer; import org.apache.olingo.server.api.serializer.PrimitiveSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceCollectionSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceSerializerOptions; import org.apache.olingo.server.api.serializer.SerializerException; import org.apache.olingo.server.api.serializer.SerializerResult; import org.apache.olingo.server.core.serializer.SerializerResultImpl; @@ -139,14 +140,15 @@ public class ODataXmlSerializerImpl implements ODataSerializer { @Override public SerializerResult reference(final ServiceMetadata metadata, final EdmEntitySet edmEntotySet, - final Entity entity, final ContextURL contextURL) throws SerializerException { + final Entity entity, final ReferenceSerializerOptions options) throws SerializerException { throw new SerializerException("Serialization not implemented for XML format.", SerializerException.MessageKeys.NOT_IMPLEMENTED); } @Override public SerializerResult referenceCollection(final ServiceMetadata metadata, final EdmEntitySet edmEntitySet, - final EntityCollection entityCollection, final ContextURL contextURL) throws SerializerException { + final EntityCollection entityCollection, final ReferenceCollectionSerializerOptions optionsL) + throws SerializerException { throw new SerializerException("Serialization not implemented for XML format.", SerializerException.MessageKeys.NOT_IMPLEMENTED); } diff --git a/lib/server-core/src/main/java/org/apache/olingo/server/core/uri/parser/Parser.java b/lib/server-core/src/main/java/org/apache/olingo/server/core/uri/parser/Parser.java index 6391212e0..f764c53d8 100644 --- a/lib/server-core/src/main/java/org/apache/olingo/server/core/uri/parser/Parser.java +++ b/lib/server-core/src/main/java/org/apache/olingo/server/core/uri/parser/Parser.java @@ -32,7 +32,6 @@ import org.antlr.v4.runtime.atn.PredictionMode; import org.antlr.v4.runtime.misc.ParseCancellationException; import org.apache.olingo.commons.api.ODataRuntimeException; import org.apache.olingo.commons.api.edm.Edm; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.server.api.uri.UriInfo; import org.apache.olingo.server.api.uri.UriInfoKind; import org.apache.olingo.server.api.uri.UriResource; @@ -68,6 +67,9 @@ import org.apache.olingo.server.core.uri.queryoption.SkipTokenOptionImpl; import org.apache.olingo.server.core.uri.queryoption.TopOptionImpl; public class Parser { + private static final String ATOM = "atom"; + private static final String JSON = "json"; + private static final String XML = "xml"; int logLevel = 0; private enum ParserEntryRules { @@ -177,9 +179,9 @@ public class Parser { FormatOptionImpl formatOption = new FormatOptionImpl(); formatOption.setName(option.name); formatOption.setText(option.value); - if (option.value.equalsIgnoreCase(ODataFormat.JSON.name()) - || option.value.equalsIgnoreCase(ODataFormat.XML.name()) - || option.value.equalsIgnoreCase(ODataFormat.ATOM.name()) + if (option.value.equalsIgnoreCase(JSON) + || option.value.equalsIgnoreCase(XML) + || option.value.equalsIgnoreCase(ATOM) || isFormatSyntaxValid(option.value)) { formatOption.setFormat(option.value); } else { diff --git a/lib/server-core/src/test/java/org/apache/olingo/server/core/ContentNegotiatorTest.java b/lib/server-core/src/test/java/org/apache/olingo/server/core/ContentNegotiatorTest.java index f84ef9538..07e06ca69 100644 --- a/lib/server-core/src/test/java/org/apache/olingo/server/core/ContentNegotiatorTest.java +++ b/lib/server-core/src/test/java/org/apache/olingo/server/core/ContentNegotiatorTest.java @@ -31,7 +31,6 @@ import java.util.Arrays; import java.util.List; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.server.api.ODataRequest; @@ -46,32 +45,39 @@ public class ContentNegotiatorTest { static final private String ACCEPT_CASE_MIN_UTF8 = "application/json;charset=UTF-8;odata.metadata=minimal"; static final private String ACCEPT_CASE_FULL = "application/json;odata.metadata=full"; static final private String ACCEPT_CASE_NONE = "application/json;odata.metadata=none"; + static final private String ACCEPT_CASE_MIN_UTF8_IEEE754 + = "application/json;charset=UTF-8;odata.metadata=minimal;IEEE754Compatible=true"; + static final private String ACCEPT_CASE_MIN_IEEE754 + = "application/json;odata.metadata=minimal;IEEE754Compatible=true"; static final private String ACCEPT_CASE_JSONQ = "application/json;q=0.2"; static final private String ACCEPT_CASE_XML = HttpContentType.APPLICATION_XML; static final private String ACCEPT_CASE_WILDCARD1 = HttpContentType.WILDCARD; static final private String ACCEPT_CASE_WILDCARD2 = "application/*"; - + //@formatter:off (Eclipse formatter) //CHECKSTYLE:OFF (Maven checkstyle) String[][] casesServiceDocument = { - /* expected $format accept modified content types */ - { ACCEPT_CASE_MIN, null, null, null }, - { ACCEPT_CASE_MIN, "json", null, null }, - { ACCEPT_CASE_MIN, "json", ACCEPT_CASE_JSONQ, null }, - { ACCEPT_CASE_NONE, ACCEPT_CASE_NONE, null, null }, - { "a/a", "a/a", null, "a/a" }, - { ACCEPT_CASE_MIN, null, ACCEPT_CASE_JSONQ, null }, - { ACCEPT_CASE_MIN, null, ACCEPT_CASE_WILDCARD1, null }, - { ACCEPT_CASE_MIN, null, ACCEPT_CASE_WILDCARD2, null }, - { ACCEPT_CASE_MIN, null, null, ACCEPT_CASE_MIN }, - { "a/a", "a/a", null, "a/a,b/b" }, - { "a/a;x=y", "a/a", ACCEPT_CASE_WILDCARD1, "a/a;x=y" }, - { "a/a;v=w;x=y", null, "a/a;x=y", "a/a;b=c,a/a;v=w;x=y" }, - { "a/a;v=w;x=y", "a/a;x=y", null, "a/a;b=c,a/a;v=w;x=y" }, - { ACCEPT_CASE_MIN, "json", ACCEPT_CASE_MIN, null }, - { ACCEPT_CASE_FULL, null, ACCEPT_CASE_FULL, ACCEPT_CASE_FULL }, - { ACCEPT_CASE_MIN_UTF8, null, ACCEPT_CASE_MIN_UTF8, null } + /* expected $format accept modified content types */ + { ACCEPT_CASE_MIN, null, null, null }, + { ACCEPT_CASE_MIN, "json", null, null }, + { ACCEPT_CASE_MIN, "json", ACCEPT_CASE_JSONQ, null }, + { ACCEPT_CASE_NONE, ACCEPT_CASE_NONE, null, null }, + { "a/a", "a/a", null, "a/a" }, + { ACCEPT_CASE_MIN, null, ACCEPT_CASE_JSONQ, null }, + { ACCEPT_CASE_MIN, null, ACCEPT_CASE_WILDCARD1, null }, + { ACCEPT_CASE_MIN, null, ACCEPT_CASE_WILDCARD2, null }, + { ACCEPT_CASE_MIN, null, null, ACCEPT_CASE_MIN }, + { "a/a", "a/a", null, "a/a,b/b" }, + { "a/a;x=y", "a/a", ACCEPT_CASE_WILDCARD1, "a/a;x=y" }, + { "a/a;v=w;x=y", null, "a/a;x=y", "a/a;b=c,a/a;v=w;x=y" }, + { "a/a;v=w;x=y", "a/a;x=y", null, "a/a;b=c,a/a;v=w;x=y" }, + { ACCEPT_CASE_MIN, "json", ACCEPT_CASE_MIN, null }, + { ACCEPT_CASE_FULL, null, ACCEPT_CASE_FULL, ACCEPT_CASE_FULL }, + { ACCEPT_CASE_MIN_UTF8, null, ACCEPT_CASE_MIN_UTF8, null }, + { ACCEPT_CASE_MIN_IEEE754, null, ACCEPT_CASE_MIN_IEEE754, null }, + { ACCEPT_CASE_MIN_UTF8_IEEE754, null, ACCEPT_CASE_MIN_UTF8_IEEE754, null }, + { ACCEPT_CASE_MIN_IEEE754, ACCEPT_CASE_MIN_IEEE754, ACCEPT_CASE_MIN , null }, }; String[][] casesMetadata = { @@ -147,7 +153,7 @@ public class ContentNegotiatorTest { @Test public void checkSupport() throws Exception { - ContentNegotiator.checkSupport(ODataFormat.JSON.getContentType(), null, + ContentNegotiator.checkSupport(ContentType.JSON, null, RepresentationType.ENTITY); ContentNegotiator.checkSupport(ContentType.TEXT_PLAIN, null, RepresentationType.VALUE); try { diff --git a/lib/server-core/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerBasicTest.java b/lib/server-core/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerBasicTest.java index 053dd074d..d29fdf84d 100644 --- a/lib/server-core/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerBasicTest.java +++ b/lib/server-core/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerBasicTest.java @@ -26,25 +26,25 @@ import java.io.InputStream; import java.net.URI; import java.util.List; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.deserializer.DeserializerException; import org.apache.olingo.server.api.deserializer.ODataDeserializer; import org.junit.Test; public class ODataJsonDeserializerBasicTest { - + @Test public void checkSupportedJsonFormats() throws Exception { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); assertNotNull(deserializer); deserializer = null; - deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON_NO_METADATA); + deserializer = OData.newInstance().createDeserializer(ContentType.JSON_NO_METADATA); assertNotNull(deserializer); deserializer = null; - deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON_FULL_METADATA); + deserializer = OData.newInstance().createDeserializer(ContentType.JSON_FULL_METADATA); assertNotNull(deserializer); deserializer = null; } @@ -58,7 +58,7 @@ public class ODataJsonDeserializerBasicTest { " { \"@odata.id\": \"Orders(10759)\" }\n" + " ]\n" + "}"; - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); List values = deserializer.entityReferences(new ByteArrayInputStream(payload.getBytes())) .getEntityReferences(); assertEquals(2, values.size()); @@ -72,7 +72,7 @@ public class ODataJsonDeserializerBasicTest { " \"@odata.context\": \"http://host/service/$metadata#$ref\",\n" + " \"@odata.id\": \"Orders(10643)\"\n" + "}"; - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); List values = deserializer.entityReferences(new ByteArrayInputStream(payload .getBytes())).getEntityReferences(); assertEquals(1, values.size()); @@ -87,7 +87,7 @@ public class ODataJsonDeserializerBasicTest { + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); final List entityReferences = deserializer.entityReferences(stream).getEntityReferences(); assertEquals(1, entityReferences.size()); @@ -105,7 +105,7 @@ public class ODataJsonDeserializerBasicTest { "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); final List entityReferences = deserializer.entityReferences(stream).getEntityReferences(); assertEquals(2, entityReferences.size()); @@ -124,7 +124,7 @@ public class ODataJsonDeserializerBasicTest { "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); final List entityReferences = deserializer.entityReferences(stream).getEntityReferences(); assertEquals(1, entityReferences.size()); @@ -142,7 +142,7 @@ public class ODataJsonDeserializerBasicTest { "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); final List entityReferences = deserializer.entityReferences(stream).getEntityReferences(); assertEquals(1, entityReferences.size()); @@ -158,7 +158,7 @@ public class ODataJsonDeserializerBasicTest { "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); final List entityReferences = deserializer.entityReferences(stream).getEntityReferences(); assertEquals(0, entityReferences.size()); @@ -173,7 +173,7 @@ public class ODataJsonDeserializerBasicTest { String entityString = "{ }"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); final List entityReferences = deserializer.entityReferences(stream).getEntityReferences(); assertEquals(0, entityReferences.size()); @@ -187,7 +187,7 @@ public class ODataJsonDeserializerBasicTest { "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(ContentType.JSON); deserializer.entityReferences(stream); } } diff --git a/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java b/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java index 08aed1383..1994e0c66 100644 --- a/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java +++ b/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java @@ -32,7 +32,7 @@ import org.apache.olingo.commons.api.data.ComplexValue; import org.apache.olingo.commons.api.data.ContextURL; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.data.ValueType; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.serializer.ComplexSerializerOptions; import org.junit.Test; @@ -44,7 +44,7 @@ public class ODataJsonSerializerTest { col.add(getValues(2)); final Property complexCollection = new Property(null, "ComplexCol", ValueType.COLLECTION_COMPLEX, col); - final ODataJsonSerializer serializer = new ODataJsonSerializer(ODataFormat.APPLICATION_JSON); + final ODataJsonSerializer serializer = new ODataJsonSerializer(ContentType.APPLICATION_JSON); final ComplexSerializerOptions options = ComplexSerializerOptions.with() .contextURL(ContextURL.with().selectList("ComplexCollection").build()).build(); final InputStream in = serializer.complexCollection(null, ComplexTypeHelper.createType(), diff --git a/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ServerErrorSerializerTest.java b/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ServerErrorSerializerTest.java index c9efe0776..324207689 100644 --- a/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ServerErrorSerializerTest.java +++ b/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/json/ServerErrorSerializerTest.java @@ -27,9 +27,9 @@ import java.util.List; import org.apache.commons.io.IOUtils; import org.apache.olingo.commons.api.ODataErrorDetail; -import org.apache.olingo.commons.api.format.ODataFormat; -import org.apache.olingo.server.api.ODataServerError; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.OData; +import org.apache.olingo.server.api.ODataServerError; import org.apache.olingo.server.api.serializer.ODataSerializer; import org.apache.olingo.server.api.serializer.SerializerException; import org.junit.Before; @@ -45,7 +45,7 @@ public class ServerErrorSerializerTest { @Before public void before() throws Exception { - ser = OData.newInstance().createSerializer(ODataFormat.JSON); + ser = OData.newInstance().createSerializer(ContentType.JSON); } @Test diff --git a/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentXmlSerializerTest.java b/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentXmlSerializerTest.java index d78b50e95..4423308cd 100644 --- a/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentXmlSerializerTest.java +++ b/lib/server-core/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentXmlSerializerTest.java @@ -57,7 +57,7 @@ import org.apache.olingo.commons.api.edm.provider.CsdlPropertyRef; import org.apache.olingo.commons.api.edm.provider.CsdlReturnType; import org.apache.olingo.commons.api.edm.provider.CsdlSchema; import org.apache.olingo.commons.api.edm.provider.CsdlSingleton; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.commons.core.edm.EdmComplexTypeImpl; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.ServiceMetadata; @@ -76,7 +76,7 @@ public class MetadataDocumentXmlSerializerTest { @BeforeClass public static void init() throws SerializerException { - serializer = OData.newInstance().createSerializer(ODataFormat.XML); + serializer = OData.newInstance().createSerializer(ContentType.APPLICATION_XML); } @Test diff --git a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalActionProcessor.java b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalActionProcessor.java index d7fc00f15..663a7ebee 100644 --- a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalActionProcessor.java +++ b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalActionProcessor.java @@ -31,7 +31,6 @@ import org.apache.olingo.commons.api.edm.EdmEntitySet; import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.server.api.ODataApplicationException; @@ -81,8 +80,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor .getAction(); DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); EntityCollection collection = dataProvider.processActionEntityCollection(action.getName(), deserializerResult.getActionParameters()); @@ -99,11 +97,10 @@ public class TechnicalActionProcessor extends TechnicalProcessor if (returnPreference == null || returnPreference == Return.REPRESENTATION) { final EdmEntitySet edmEntitySet = getEdmEntitySet(uriInfo.asUriInfoResource()); final EdmEntityType type = (EdmEntityType) action.getReturnType().getType(); - final ODataFormat format = ODataFormat.fromContentType(responseFormat); final EntityCollectionSerializerOptions options = EntityCollectionSerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : getContextUrl(edmEntitySet, type, false)) + .contextURL(isODataMetadataNone(responseFormat) ? null : getContextUrl(edmEntitySet, type, false)) .build(); - response.setContent(odata.createSerializer(format) + response.setContent(odata.createSerializer(responseFormat) .entityCollection(serviceMetadata, type, collection, options).getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); @@ -127,8 +124,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final EdmEntityType type = (EdmEntityType) action.getReturnType().getType(); final DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); final EntityActionResult entityResult = dataProvider.processActionEntity(action.getName(), deserializerResult.getActionParameters()); @@ -143,13 +139,12 @@ public class TechnicalActionProcessor extends TechnicalProcessor } else { final Return returnPreference = odata.createPreferences(request.getHeaders(HttpHeader.PREFER)).getReturn(); if (returnPreference == null || returnPreference == Return.REPRESENTATION) { - final ODataFormat format = ODataFormat.fromContentType(responseFormat); - response.setContent(odata.createSerializer(format).entity( + response.setContent(odata.createSerializer(responseFormat).entity( serviceMetadata, type, entityResult.getEntity(), EntitySerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : getContextUrl(edmEntitySet, type, true)) + .contextURL(isODataMetadataNone(responseFormat) ? null : getContextUrl(edmEntitySet, type, true)) .build()) .getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); @@ -165,7 +160,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor if (entityResult.isCreated()) { response.setHeader(HttpHeader.LOCATION, request.getRawBaseUri() + '/' - + odata.createUriHelper().buildCanonicalURL(edmEntitySet, entityResult.getEntity())); + + odata.createUriHelper().buildCanonicalURL(edmEntitySet, entityResult.getEntity())); } if (entityResult.getEntity().getETag() != null) { response.setHeader(HttpHeader.ETAG, entityResult.getEntity().getETag()); @@ -181,8 +176,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0)) .getAction(); DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); Property property = dataProvider.processActionPrimitiveCollection(action.getName(), deserializerResult.getActionParameters()); @@ -203,8 +197,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final ContextURL contextURL = ContextURL.with().type(type).asCollection().build(); final PrimitiveSerializerOptions options = PrimitiveSerializerOptions.with().contextURL(contextURL).build(); final SerializerResult result = - odata.createSerializer(ODataFormat.fromContentType(responseFormat)) - .primitiveCollection(serviceMetadata, type, property, options); + odata.createSerializer(responseFormat).primitiveCollection(serviceMetadata, type, property, options); response.setContent(result.getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); @@ -225,8 +218,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0)) .getAction(); DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); Property property = dataProvider.processActionPrimitive(action.getName(), deserializerResult.getActionParameters()); EdmPrimitiveType type = (EdmPrimitiveType) action.getReturnType().getType(); @@ -243,7 +235,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor if (returnPreference == null || returnPreference == Return.REPRESENTATION) { final ContextURL contextURL = ContextURL.with().type(type).build(); final PrimitiveSerializerOptions options = PrimitiveSerializerOptions.with().contextURL(contextURL).build(); - final SerializerResult result = odata.createSerializer(ODataFormat.fromContentType(responseFormat)) + final SerializerResult result = odata.createSerializer(responseFormat) .primitive(serviceMetadata, type, property, options); response.setContent(result.getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); @@ -266,8 +258,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0)) .getAction(); DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); Property property = dataProvider.processActionComplexCollection(action.getName(), deserializerResult.getActionParameters()); @@ -281,15 +272,13 @@ public class TechnicalActionProcessor extends TechnicalProcessor throw new ODataApplicationException("The action could not be executed.", HttpStatusCode.INTERNAL_SERVER_ERROR.getStatusCode(), Locale.ROOT); } - final Return returnPreference = odata.createPreferences(request.getHeaders(HttpHeader.PREFER)).getReturn(); if (returnPreference == null || returnPreference == Return.REPRESENTATION) { final EdmComplexType type = (EdmComplexType) action.getReturnType().getType(); final ContextURL contextURL = ContextURL.with().type(type).asCollection().build(); final ComplexSerializerOptions options = ComplexSerializerOptions.with().contextURL(contextURL).build(); final SerializerResult result = - odata.createSerializer(ODataFormat.fromContentType(responseFormat)).complexCollection(serviceMetadata, type, - property, options); + odata.createSerializer(responseFormat).complexCollection(serviceMetadata, type, property, options); response.setContent(result.getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); @@ -310,8 +299,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final EdmAction action = ((UriResourceAction) uriInfo.asUriInfoResource().getUriResourceParts().get(0)) .getAction(); DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); Property property = dataProvider.processActionComplex(action.getName(), deserializerResult.getActionParameters()); EdmComplexType type = (EdmComplexType) action.getReturnType().getType(); @@ -329,8 +317,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final ContextURL contextURL = ContextURL.with().type(type).build(); final ComplexSerializerOptions options = ComplexSerializerOptions.with().contextURL(contextURL).build(); final SerializerResult result = - odata.createSerializer(ODataFormat.fromContentType(responseFormat)).complex(serviceMetadata, type, property, - options); + odata.createSerializer(responseFormat).complex(serviceMetadata, type, property, options); response.setContent(result.getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); @@ -352,8 +339,7 @@ public class TechnicalActionProcessor extends TechnicalProcessor final EdmAction action = resource.getAction(); if (action.getParameterNames().size() - (action.isBound() ? 1 : 0) > 0) { checkRequestFormat(requestFormat); - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .actionParameters(request.getBody(), action); + odata.createDeserializer(requestFormat).actionParameters(request.getBody(), action); } response.setStatusCode(HttpStatusCode.NO_CONTENT.getStatusCode()); } diff --git a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalEntityProcessor.java b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalEntityProcessor.java index 807c81522..9844d71ae 100644 --- a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalEntityProcessor.java +++ b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalEntityProcessor.java @@ -28,7 +28,6 @@ import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.edm.EdmEntitySet; import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpMethod; @@ -50,6 +49,8 @@ import org.apache.olingo.server.api.processor.ReferenceCollectionProcessor; import org.apache.olingo.server.api.processor.ReferenceProcessor; import org.apache.olingo.server.api.serializer.EntityCollectionSerializerOptions; import org.apache.olingo.server.api.serializer.EntitySerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceCollectionSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceSerializerOptions; import org.apache.olingo.server.api.serializer.SerializerResult; import org.apache.olingo.server.api.uri.UriInfo; import org.apache.olingo.server.api.uri.UriResourceEntitySet; @@ -153,9 +154,8 @@ public class TechnicalEntityProcessor extends TechnicalProcessor dataProvider.setMedia(entity, odata.createFixedFormatDeserializer().binary(request.getBody()), requestFormat.toContentTypeString()); } else { - final DeserializerResult deserializerResult = - odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) - .entity(request.getBody(), edmEntityType); + final DeserializerResult deserializerResult = + odata.createDeserializer(requestFormat).entity(request.getBody(), edmEntityType); new RequestValidator(dataProvider, request.getRawBaseUri()) .validate(edmEntitySet, deserializerResult.getEntity()); @@ -166,8 +166,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor final Return returnPreference = odata.createPreferences(request.getHeaders(HttpHeader.PREFER)).getReturn(); if (returnPreference == null || returnPreference == Return.REPRESENTATION) { - final ODataFormat format = ODataFormat.fromContentType(responseFormat); - response.setContent(serializeEntity(entity, edmEntitySet, edmEntityType, format, expand, null) + response.setContent(serializeEntity(entity, edmEntitySet, edmEntityType, responseFormat, expand, null) .getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); response.setStatusCode(HttpStatusCode.CREATED.getStatusCode()); @@ -209,7 +208,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor request.getHeaders(HttpHeader.IF_MATCH), request.getHeaders(HttpHeader.IF_NONE_MATCH)); checkRequestFormat(requestFormat); - final ODataDeserializer deserializer = odata.createDeserializer(ODataFormat.fromContentType(requestFormat)); + final ODataDeserializer deserializer = odata.createDeserializer(requestFormat); final Entity changedEntity = deserializer.entity(request.getBody(), edmEntitySet.getEntityType()).getEntity(); new RequestValidator(dataProvider, @@ -223,8 +222,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor final Return returnPreference = odata.createPreferences(request.getHeaders(HttpHeader.PREFER)).getReturn(); if (returnPreference == null || returnPreference == Return.REPRESENTATION) { response.setStatusCode(HttpStatusCode.OK.getStatusCode()); - final ODataFormat format = ODataFormat.fromContentType(responseFormat); - response.setContent(serializeEntity(entity, edmEntitySet, edmEntityType, format, null, null) + response.setContent(serializeEntity(entity, edmEntitySet, edmEntityType, responseFormat, null, null) .getContent()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); } else { @@ -256,8 +254,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor final Return returnPreference = odata.createPreferences(request.getHeaders(HttpHeader.PREFER)).getReturn(); if (returnPreference == null || returnPreference == Return.REPRESENTATION) { - final ODataFormat format = ODataFormat.fromContentType(responseFormat); - response.setContent(serializeEntity(entity, edmEntitySet, edmEntityType, format, null, null) + response.setContent(serializeEntity(entity, edmEntitySet, edmEntityType, responseFormat, null, null) .getContent()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); @@ -309,7 +306,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor public void createReference(final ODataRequest request, final ODataResponse response, final UriInfo uriInfo, final ContentType requestFormat) throws ODataApplicationException, ODataLibraryException { - final ODataDeserializer deserializer = odata.createDeserializer(ODataFormat.fromContentType(requestFormat)); + final ODataDeserializer deserializer = odata.createDeserializer(requestFormat); final DeserializerResult references = deserializer.entityReferences(request.getBody()); if (references.getEntityReferences().size() != 1) { @@ -329,7 +326,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor public void updateReference(final ODataRequest request, ODataResponse response, final UriInfo uriInfo, final ContentType requestFormat) throws ODataApplicationException, ODataLibraryException { - final ODataDeserializer deserializer = odata.createDeserializer(ODataFormat.fromContentType(requestFormat)); + final ODataDeserializer deserializer = odata.createDeserializer(requestFormat); final DeserializerResult references = deserializer.entityReferences(request.getBody()); if (references.getEntityReferences().size() != 1) { @@ -378,7 +375,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor } private void readEntity(final ODataRequest request, final ODataResponse response, final UriInfo uriInfo, - final ContentType requestedContentType, final boolean isReference) + final ContentType requestedFormat, final boolean isReference) throws ODataApplicationException, ODataLibraryException { final EdmEntitySet edmEntitySet = getEdmEntitySet(uriInfo); final EdmEntityType edmEntityType = edmEntitySet == null ? @@ -396,7 +393,6 @@ public class TechnicalEntityProcessor extends TechnicalProcessor return; } - final ODataFormat format = ODataFormat.fromContentType(requestedContentType); final ExpandOption expand = uriInfo.getExpandOption(); final SelectOption select = uriInfo.getSelectOption(); @@ -405,15 +401,15 @@ public class TechnicalEntityProcessor extends TechnicalProcessor expandHandler.applyExpandQueryOptions(entitySerialization, edmEntitySet, expand); final SerializerResult serializerResult = isReference ? - serializeReference(entity, edmEntitySet, format) : - serializeEntity(entitySerialization, edmEntitySet, edmEntityType, format, expand, select); + serializeReference(entity, edmEntitySet, requestedFormat) : + serializeEntity(entitySerialization, edmEntitySet, edmEntityType, requestedFormat, expand, select); if (entity.getETag() != null) { response.setHeader(HttpHeader.ETAG, entity.getETag()); } response.setContent(serializerResult.getContent()); response.setStatusCode(HttpStatusCode.OK.getStatusCode()); - response.setHeader(HttpHeader.CONTENT_TYPE, requestedContentType.toContentTypeString()); + response.setHeader(HttpHeader.CONTENT_TYPE, requestedFormat.toContentTypeString()); } private void readEntityCollection(final ODataRequest request, final ODataResponse response, @@ -451,7 +447,6 @@ public class TechnicalEntityProcessor extends TechnicalProcessor pageSize); // Apply expand system query option - final ODataFormat format = ODataFormat.fromContentType(requestedContentType); final ExpandOption expand = uriInfo.getExpandOption(); final SelectOption select = uriInfo.getSelectOption(); @@ -466,9 +461,9 @@ public class TechnicalEntityProcessor extends TechnicalProcessor final CountOption countOption = uriInfo.getCountOption(); // Serialize - final SerializerResult serializerResult = isReference ? - serializeReferenceCollection(entitySetSerialization, edmEntitySet, format) : - serializeEntityCollection(entitySetSerialization, edmEntitySet, edmEntityType, format, + final SerializerResult serializerResult = (isReference) ? + serializeReferenceCollection(entitySetSerialization, edmEntitySet, requestedContentType, countOption) : + serializeEntityCollection(entitySetSerialization, edmEntitySet, edmEntityType, requestedContentType, expand, select, countOption); response.setContent(serializerResult.getContent()); @@ -481,44 +476,49 @@ public class TechnicalEntityProcessor extends TechnicalProcessor } private SerializerResult serializeEntityCollection(final EntityCollection entityCollection, - final EdmEntitySet edmEntitySet, final EdmEntityType edmEntityType, final ODataFormat format, + final EdmEntitySet edmEntitySet, final EdmEntityType edmEntityType, final ContentType requestedFormat, final ExpandOption expand, final SelectOption select, final CountOption countOption) throws ODataLibraryException { - return odata.createSerializer(format).entityCollection( + + return odata.createSerializer(requestedFormat).entityCollection( serviceMetadata, edmEntityType, entityCollection, EntityCollectionSerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : + .contextURL(isODataMetadataNone(requestedFormat) ? null : getContextUrl(edmEntitySet, edmEntityType, false, expand, select)) .count(countOption) .expand(expand).select(select) .build()); } - private SerializerResult serializeReferenceCollection(final EntityCollection entityCollection, - final EdmEntitySet edmEntitySet, final ODataFormat format) throws ODataLibraryException { - return odata.createSerializer(format) - .referenceCollection(serviceMetadata, edmEntitySet, entityCollection, - ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()); + private SerializerResult serializeReferenceCollection(final EntityCollection entityCollection, + final EdmEntitySet edmEntitySet, final ContentType requestedFormat, final CountOption countOption) + throws ODataLibraryException { + + return odata.createSerializer(requestedFormat) + .referenceCollection(serviceMetadata, edmEntitySet, entityCollection,ReferenceCollectionSerializerOptions.with() + .contextURL(ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()) + .count(countOption).build()); } private SerializerResult serializeReference(final Entity entity, final EdmEntitySet edmEntitySet, - final ODataFormat format) throws ODataLibraryException { - return odata.createSerializer(format) - .reference(serviceMetadata, edmEntitySet, entity, - ContextURL.with().suffix(Suffix.REFERENCE).build()); + final ContentType requestedFormat) throws ODataLibraryException { + return odata.createSerializer(requestedFormat) + .reference(serviceMetadata, edmEntitySet, entity, ReferenceSerializerOptions.with() + .contextURL(ContextURL.with().suffix(Suffix.REFERENCE).build()).build()); + } private SerializerResult serializeEntity(final Entity entity, - final EdmEntitySet edmEntitySet, final EdmEntityType edmEntityType, final ODataFormat format, + final EdmEntitySet edmEntitySet, final EdmEntityType edmEntityType, final ContentType requestedFormat, final ExpandOption expand, final SelectOption select) throws ODataLibraryException { - return odata.createSerializer(format).entity( + return odata.createSerializer(requestedFormat).entity( serviceMetadata, edmEntityType, entity, EntitySerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : + .contextURL(isODataMetadataNone(requestedFormat) ? null : getContextUrl(edmEntitySet, edmEntityType, true, expand, select)) .expand(expand).select(select) .build()); diff --git a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalPrimitiveComplexProcessor.java b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalPrimitiveComplexProcessor.java index 4d1e83468..cf4b38e18 100644 --- a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalPrimitiveComplexProcessor.java +++ b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalPrimitiveComplexProcessor.java @@ -38,7 +38,6 @@ import org.apache.olingo.commons.api.edm.EdmStructuredType; import org.apache.olingo.commons.api.edm.EdmType; import org.apache.olingo.commons.api.edm.constants.EdmTypeKind; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpMethod; import org.apache.olingo.commons.api.http.HttpStatusCode; @@ -255,9 +254,8 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor } else { final ExpandOption expand = uriInfo.getExpandOption(); final SelectOption select = uriInfo.getSelectOption(); - final ODataFormat format = ODataFormat.fromContentType(contentType); final SerializerResult result = serializeProperty(entity, edmEntitySet, path, property, edmProperty, - type, returnType, representationType, format, expand, select); + type, returnType, representationType, contentType, expand, select); response.setContent(result.getContent()); } } @@ -297,7 +295,7 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor deserializer.primitiveValue(request.getBody(), edmProperty); dataProvider.updatePropertyValue(property, value); } else { - final Property changedProperty = odata.createDeserializer(ODataFormat.fromContentType(requestFormat)) + final Property changedProperty = odata.createDeserializer(requestFormat) .property(request.getBody(), edmProperty).getProperty(); if (changedProperty.isNull() && !edmProperty.isNullable()) { throw new ODataApplicationException("Not nullable.", HttpStatusCode.BAD_REQUEST.getStatusCode(), Locale.ROOT); @@ -314,9 +312,8 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor response.setContent( serializePrimitiveValue(property, edmProperty, (EdmPrimitiveType) edmProperty.getType(), null)); } else { - final ODataFormat format = ODataFormat.fromContentType(responseFormat); final SerializerResult result = serializeProperty(entity, edmEntitySet, path, property, edmProperty, - edmProperty.getType(), null, representationType, format, null, null); + edmProperty.getType(), null, representationType, responseFormat, null, null); response.setContent(result.getContent()); } response.setHeader(HttpHeader.CONTENT_TYPE, responseFormat.toContentTypeString()); @@ -406,10 +403,10 @@ public class TechnicalPrimitiveComplexProcessor extends TechnicalProcessor private SerializerResult serializeProperty(final Entity entity, final EdmEntitySet edmEntitySet, final List path, final Property property, final EdmProperty edmProperty, final EdmType type, final EdmReturnType returnType, - final RepresentationType representationType, final ODataFormat format, + final RepresentationType representationType, final ContentType responseFormat, final ExpandOption expand, final SelectOption select) throws ODataLibraryException { - ODataSerializer serializer = odata.createSerializer(format); - final ContextURL contextURL = format == ODataFormat.JSON_NO_METADATA ? null : + ODataSerializer serializer = odata.createSerializer(responseFormat); + final ContextURL contextURL = isODataMetadataNone(responseFormat) ? null : getContextUrl(edmEntitySet, entity, path, type, representationType, expand, select); SerializerResult result = null; switch (representationType) { diff --git a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalProcessor.java b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalProcessor.java index f3012d985..64327f327 100644 --- a/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalProcessor.java +++ b/lib/server-tecsvc/src/main/java/org/apache/olingo/server/tecsvc/processor/TechnicalProcessor.java @@ -255,4 +255,9 @@ public abstract class TechnicalProcessor implements Processor { HttpStatusCode.BAD_REQUEST.getStatusCode(), Locale.ROOT); } } + + protected boolean isODataMetadataNone(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_JSON) + && ContentType.VALUE_ODATA_METADATA_NONE.equals(contentType.getParameter(ContentType.PARAMETER_ODATA_METADATA)); + } } diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/ODataHandlerTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/ODataHandlerTest.java index ec5a33d95..a3f75eb87 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/ODataHandlerTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/ODataHandlerTest.java @@ -39,7 +39,6 @@ import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion; import org.apache.olingo.commons.api.edm.provider.CsdlAbstractEdmProvider; import org.apache.olingo.commons.api.edm.provider.CsdlEntitySet; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpMethod; @@ -714,7 +713,7 @@ public class ODataHandlerTest { if (headerName != HttpHeader.CONTENT_TYPE) { request.addHeader(HttpHeader.CONTENT_TYPE, Collections.singletonList( - ODataFormat.JSON.getContentType().toContentTypeString())); + ContentType.JSON.toContentTypeString())); } final OData odata = OData.newInstance(); diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/AbstractODataDeserializerTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/AbstractODataDeserializerTest.java index 89b73185c..c0e188ad0 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/AbstractODataDeserializerTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/AbstractODataDeserializerTest.java @@ -23,12 +23,16 @@ import java.io.InputStream; import java.util.Collections; import org.apache.olingo.commons.api.edm.Edm; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.edmx.EdmxReference; import org.apache.olingo.server.tecsvc.provider.EdmTechProvider; public class AbstractODataDeserializerTest { - + protected static final ContentType CONTENT_TYPE_JSON = ContentType.JSON; + protected static final ContentType CONTENT_TYPE_JSON_IEEE754Compatible = + ContentType.parse("application/json;odata.format=minimal;IEEE754Compatible=true"); + protected static final Edm edm = OData.newInstance().createServiceMetadata( new EdmTechProvider(), Collections. emptyList()).getEdm(); diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerDeepInsertTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerDeepInsertTest.java index 010ec06d0..7bae02251 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerDeepInsertTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerDeepInsertTest.java @@ -30,18 +30,16 @@ import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.Link; import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.deserializer.DeserializerException; import org.junit.Test; public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTest { - @Test public void esAllPrimExpandedToOne() throws Exception { EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("EntityESAllPrimExpandedNavPropertyETTwoPrimOne.json"); - Entity entity = OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType).getEntity(); + Entity entity = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType).getEntity(); Link navigationLink = entity.getNavigationLink("NavPropertyETTwoPrimOne"); assertNotNull(navigationLink); @@ -55,14 +53,14 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe public void esAllPrimExpandedToOneWithODataAnnotations() throws Exception { EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("EntityESAllPrimExpandedNavPropertyETTwoPrimOneWithODataAnnotations.json"); - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } @Test public void esAllPrimExpandedToMany() throws Exception { EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("EntityESAllPrimExpandedNavPropertyETTwoPrimMany.json"); - Entity entity = OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType).getEntity(); + Entity entity = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType).getEntity(); Link navigationLink = entity.getNavigationLink("NavPropertyETTwoPrimMany"); assertNotNull(navigationLink); @@ -78,7 +76,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe public void esAllPrimExpandedToManyWithODataAnnotations() throws Exception { EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("EntityESAllPrimExpandedNavPropertyETTwoPrimManyWithODataAnnotations.json"); - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } @Test(expected = DeserializerException.class) @@ -86,7 +84,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("EntityESAllPrimExpandedNavPropertyETTwoPrimOneWithCustomAnnotations.json"); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); throw e; @@ -98,7 +96,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("EntityESAllPrimExpandedNavPropertyETTwoPrimManyWithCustomAnnotations.json"); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); throw e; @@ -114,7 +112,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_NULL_PROPERTY, e.getMessageKey()); throw e; @@ -129,7 +127,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETTwoPrim")); - final Entity entity = OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType) + final Entity entity = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType) .getEntity(); assertEquals(1, entity.getNavigationLinks().size()); @@ -149,7 +147,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_VALUE_FOR_NAVIGATION_PROPERTY, e.getMessageKey()); throw e; @@ -165,7 +163,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_NULL_PROPERTY, e.getMessageKey()); throw e; @@ -181,7 +179,7 @@ public class ODataDeserializerDeepInsertTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entity(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entity(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_VALUE_FOR_NAVIGATION_PROPERTY, e.getMessageKey()); throw e; diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerEntityCollectionTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerEntityCollectionTest.java index c2294dda3..375fafb16 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerEntityCollectionTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataDeserializerEntityCollectionTest.java @@ -32,7 +32,6 @@ import org.apache.olingo.commons.api.data.EntityCollection; import org.apache.olingo.commons.api.data.Property; import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.deserializer.DeserializerException; import org.junit.Test; @@ -44,7 +43,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("ESAllPrim.json"); EntityCollection entitySet = - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType) + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType) .getEntityCollection(); assertNotNull(entitySet); @@ -79,7 +78,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETCompCollComp")); InputStream stream = getFileAsStream("ESCompCollComp.json"); EntityCollection entitySet = - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType) + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType) .getEntityCollection(); assertNotNull(entitySet); @@ -92,7 +91,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial public void esAllPrimODataAnnotationsAreIgnored() throws Exception { EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("ESAllPrimWithODataAnnotations.json"); - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } @Test @@ -101,7 +100,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); EntityCollection entityCollection = - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType) + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType) .getEntityCollection(); assertNotNull(entityCollection.getEntities()); assertTrue(entityCollection.getEntities().isEmpty()); @@ -112,7 +111,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("ESAllPrimWithCustomAnnotations.json"); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); throw e; @@ -124,7 +123,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); InputStream stream = getFileAsStream("ESAllPrimWithDoubleKey.json"); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.DUPLICATE_JSON_PROPERTY, e.getMessageKey()); throw e; @@ -137,7 +136,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.VALUE_TAG_MUST_BE_AN_ARRAY, e.getMessageKey()); throw e; @@ -150,7 +149,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.VALUE_TAG_MUST_BE_AN_ARRAY, e.getMessageKey()); throw e; @@ -163,7 +162,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.VALUE_TAG_MUST_BE_AN_ARRAY, e.getMessageKey()); throw e; @@ -176,7 +175,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.VALUE_ARRAY_NOT_PRESENT, e.getMessageKey()); throw e; @@ -189,7 +188,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_ENTITY, e.getMessageKey()); throw e; @@ -202,7 +201,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_ENTITY, e.getMessageKey()); throw e; @@ -215,7 +214,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.JSON_SYNTAX_EXCEPTION, e.getMessageKey()); throw e; @@ -230,7 +229,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.UNKNOWN_CONTENT, e.getMessageKey()); throw e; @@ -245,7 +244,7 @@ public class ODataDeserializerEntityCollectionTest extends AbstractODataDeserial InputStream stream = new ByteArrayInputStream(entityCollectionString.getBytes()); EdmEntityType edmEntityType = edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim")); try { - OData.newInstance().createDeserializer(ODataFormat.JSON).entityCollection(stream, edmEntityType); + OData.newInstance().createDeserializer(CONTENT_TYPE_JSON).entityCollection(stream, edmEntityType); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); throw e; diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerActionParametersTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerActionParametersTest.java index 00918dbc7..b3568f573 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerActionParametersTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerActionParametersTest.java @@ -28,7 +28,6 @@ import java.util.Map; import org.apache.olingo.commons.api.data.Parameter; import org.apache.olingo.commons.api.edm.FullQualifiedName; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.deserializer.DeserializerException; import org.junit.Test; @@ -112,14 +111,14 @@ public class ODataJsonDeserializerActionParametersTest extends AbstractODataDese } private Map deserialize(final String input, final String actionName) throws DeserializerException { - return OData.newInstance().createDeserializer(ODataFormat.JSON) + return OData.newInstance().createDeserializer(CONTENT_TYPE_JSON) .actionParameters(new ByteArrayInputStream(input.getBytes()), edm.getUnboundAction(new FullQualifiedName("Namespace1_Alias", actionName))).getActionParameters(); } private Map deserialize(final String input, final String actionName, final String typeName) throws DeserializerException { - return OData.newInstance().createDeserializer(ODataFormat.JSON) + return OData.newInstance().createDeserializer(CONTENT_TYPE_JSON) .actionParameters(new ByteArrayInputStream(input.getBytes()), edm.getBoundAction(new FullQualifiedName("Namespace1_Alias", actionName), new FullQualifiedName("Namespace1_Alias", typeName), false)).getActionParameters(); diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerEntityTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerEntityTest.java index 0956c91ce..468446126 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerEntityTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/deserializer/json/ODataJsonDeserializerEntityTest.java @@ -45,7 +45,6 @@ import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.edm.provider.CsdlMapping; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.core.edm.primitivetype.EdmDate; import org.apache.olingo.commons.core.edm.primitivetype.EdmDateTimeOffset; import org.apache.olingo.server.api.OData; @@ -61,7 +60,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe public void emptyEntity() throws Exception { String entityString = "{}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -91,7 +90,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + "\"PropertyTimeOfDay\":\"03:26:05\"}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -138,7 +137,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + "\"PropertyTimeOfDay\":\"03:26:05\"}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -159,7 +158,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertyString\":\"First Resource - positive values\"" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -189,7 +188,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + "\"PropertyTimeOfDay\":\"03:26:05\"}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -224,7 +223,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertySByte\":127," + "\"PropertyTimeOfDay\":\"01:00:01\"}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETCompAllPrim"))) .getEntity(); @@ -266,7 +265,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"CollPropertyTimeOfDay\":[\"04:14:13\",\"23:59:59\",\"01:12:33\"]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETCollAllPrim"))) .getEntity(); @@ -304,7 +303,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "{\"PropertyInt16\":789,\"PropertyString\":\"TEST 3\"}]}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))) .getEntity(); @@ -337,7 +336,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "{\"PropertyInt16\":789}]}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))) .getEntity(); @@ -386,7 +385,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + "\"PropertyTimeOfDay\":\"03:26:05\"}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -404,7 +403,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyString\":\"First Resource - positive values\"" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } @@ -423,7 +422,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "{\"PropertyInt16\":789,\"PropertyString\":\"TEST 3\"}]}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } @@ -444,7 +443,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyString\":\"First Resource - positive values\"" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -463,7 +462,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimMany@odata.bind\":[\"ESTwoPrim(2)\",\"ESTwoPrim(3)\"]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -497,7 +496,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimMany@odata.bind\":[]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))) .getEntity(); @@ -509,7 +508,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe @Test public void eTMixEnumDefCollCompTest() throws Exception { InputStream stream = getFileAsStream("EntityETMixEnumDefCollComp.json"); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm .getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))) @@ -556,7 +555,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"CollPropertyTimeOfDay\":[\"04:14:13\",\"23:59:59\",\"01:12:33\"]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity e = deserializer.entity(stream, edm.getEntityType( new FullQualifiedName("Namespace1_Alias", "ETCollAllPrim"))).getEntity(); @@ -571,7 +570,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyComp\":null" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))).getEntity(); @@ -585,7 +584,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "null," + "{\"PropertyInt16\":789,\"PropertyString\":\"TEST 3\"}]}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType( new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))).getEntity(); @@ -602,7 +601,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyComp\":{\"PropertyString\":\"TEST A\",\"PropertyInt16\":null}" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, edm.getEntityType( new FullQualifiedName("Namespace1_Alias", "ETCompAllPrim"))).getEntity(); @@ -619,7 +618,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity e = deserializer.entity(stream, edm.getEntityType( new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))).getEntity(); @@ -635,7 +634,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity e = deserializer.entity(stream, edm.getEntityType( new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))).getEntity(); @@ -671,7 +670,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "{\"PropertyDate\":\"2012-12-03\"," + "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\"}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); Entity entity = deserializer.entity(stream, entityType).getEntity(); assertNotNull(entity); @@ -708,7 +707,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe "\"PropertyTimeOfDay\":\"03:26:05\"}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.INVALID_NULL_PROPERTY, e.getMessageKey()); @@ -723,7 +722,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETTwoPrim"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.DUPLICATE_PROPERTY, e.getMessageKey()); @@ -746,7 +745,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.DUPLICATE_PROPERTY, e.getMessageKey()); @@ -773,7 +772,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.DUPLICATE_PROPERTY, e.getMessageKey()); @@ -797,7 +796,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.DUPLICATE_PROPERTY, e.getMessageKey()); @@ -820,7 +819,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); @@ -843,7 +842,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); @@ -865,7 +864,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.NOT_IMPLEMENTED, e.getMessageKey()); @@ -888,7 +887,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.UNKNOWN_CONTENT, e.getMessageKey()); @@ -910,7 +909,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.UNKNOWN_CONTENT, e.getMessageKey()); @@ -932,7 +931,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe InputStream stream = new ByteArrayInputStream(entityString.getBytes()); try { - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { assertEquals(DeserializerException.MessageKeys.UNKNOWN_CONTENT, e.getMessageKey()); @@ -1044,7 +1043,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimOne@odata.bind\":[\"ESTwoPrim(2)\"]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1061,7 +1060,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimMany@odata.bind\":\"ESTwoPrim(2)\"" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1078,7 +1077,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimMany@odata.bind\":[123,456]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1095,7 +1094,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"@odata.bind\":\"ESTwoPrim(2)\"" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1112,7 +1111,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimOne@odata.bind\":null" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1129,7 +1128,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimMany@odata.bind\":null" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1146,7 +1145,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"NavPropertyETTwoPrimMany@odata.bind\":[null]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1160,7 +1159,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe String entityString = "{\"PropertyInt16\":32767,}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1174,7 +1173,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe String entityString = "{\"PropertyInt16\":[]}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1188,7 +1187,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe String entityString = "{\"PropertyInt16\":{}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); } catch (DeserializerException e) { @@ -1204,7 +1203,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "{\"Employee1@company.example\":1234}" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { @@ -1219,7 +1218,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyComp\":\"InvalidString\"" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { @@ -1234,7 +1233,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyComp\":null" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETTwoKeyNav"))); } catch (DeserializerException e) { @@ -1251,7 +1250,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyComp\": {\"PropertyString\":\"StringValue\"}}" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETTwoKeyNav"))); } catch (DeserializerException e) { @@ -1267,7 +1266,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyCompTwoPrim\":{\"PropertyInt16\": null, \"PropertyString\":\"StringValue\"}" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETKeyNav"))); } catch (DeserializerException e) { @@ -1283,7 +1282,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "null," + "\"StringValue_1\",\"TEST 3\"]}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETCollAllPrim"))); } catch (DeserializerException e) { @@ -1298,7 +1297,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"CollPropertyInt16\":[123,\"null\",4711]" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETCollAllPrim"))); } catch (DeserializerException e) { @@ -1313,7 +1312,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "\"PropertyInt16\":32767000000000000000000000000000000000000" + "}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixPrimCollComp"))); } catch (DeserializerException e) { @@ -1331,7 +1330,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType( new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))); @@ -1350,7 +1349,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))); } catch (DeserializerException e) { @@ -1368,7 +1367,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))); } catch (DeserializerException e) { @@ -1386,7 +1385,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))); } catch (DeserializerException e) { @@ -1404,7 +1403,7 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe + "}}"; InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETMixEnumDefCollComp"))); } catch (DeserializerException e) { @@ -1412,10 +1411,118 @@ public class ODataJsonDeserializerEntityTest extends AbstractODataDeserializerTe throw e; } } - + + @Test + public void ieee754Compatible() throws Exception { + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON_IEEE754Compatible); + String entityString = + "{\"PropertyInt16\":32767," + + "\"PropertyString\":\"First Resource - positive values\"," + + "\"PropertyBoolean\":null," + + "\"PropertyByte\":255," + + "\"PropertySByte\":127," + + "\"PropertyInt32\":2147483647," + + "\"PropertyInt64\":\"9223372036854775807\"," + + "\"PropertySingle\":1.79E20," + + "\"PropertyDouble\":-1.79E19," + + "\"PropertyDecimal\":\"34\"," + + "\"PropertyBinary\":\"ASNFZ4mrze8=\"," + + "\"PropertyDate\":null," + + "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\"," + + "\"PropertyDuration\":\"PT6S\"," + + "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + + "\"PropertyTimeOfDay\":\"03:26:05\"}"; + + final InputStream stream = new ByteArrayInputStream(entityString.getBytes()); + final Entity entity = deserializer + .entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))).getEntity(); + + assertEquals(9223372036854775807L, entity.getProperty("PropertyInt64").asPrimitive()); + assertEquals(BigDecimal.valueOf(34), entity.getProperty("PropertyDecimal").asPrimitive()); + } + + @Test + public void ieee754CompatibleNull() throws Exception { + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON_IEEE754Compatible); + String entityString = + "{\"PropertyInt16\":32767," + + "\"PropertyString\":\"First Resource - positive values\"," + + "\"PropertyBoolean\":null," + + "\"PropertyByte\":255," + + "\"PropertySByte\":127," + + "\"PropertyInt32\":2147483647," + + "\"PropertyInt64\":null," + + "\"PropertySingle\":1.79E20," + + "\"PropertyDouble\":-1.79E19," + + "\"PropertyDecimal\":null," + + "\"PropertyBinary\":\"ASNFZ4mrze8=\"," + + "\"PropertyDate\":null," + + "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\"," + + "\"PropertyDuration\":\"PT6S\"," + + "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + + "\"PropertyTimeOfDay\":\"03:26:05\"}"; + + final InputStream stream = new ByteArrayInputStream(entityString.getBytes()); + final Entity entity = deserializer + .entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))).getEntity(); + + assertTrue(entity.getProperty("PropertyInt64").isNull()); + assertTrue(entity.getProperty("PropertyDecimal").isNull()); + } + + @Test(expected=DeserializerException.class) + public void ieee754CompatibleEmptyString() throws Exception { + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON_IEEE754Compatible); + String entityString = + "{\"PropertyInt16\":32767," + + "\"PropertyString\":\"First Resource - positive values\"," + + "\"PropertyBoolean\":null," + + "\"PropertyByte\":255," + + "\"PropertySByte\":127," + + "\"PropertyInt32\":2147483647," + + "\"PropertyInt64\":\"\"," + + "\"PropertySingle\":1.79E20," + + "\"PropertyDouble\":-1.79E19," + + "\"PropertyDecimal\":\" \"," + + "\"PropertyBinary\":\"ASNFZ4mrze8=\"," + + "\"PropertyDate\":null," + + "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\"," + + "\"PropertyDuration\":\"PT6S\"," + + "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + + "\"PropertyTimeOfDay\":\"03:26:05\"}"; + + final InputStream stream = new ByteArrayInputStream(entityString.getBytes()); + deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))).getEntity(); + } + + @Test(expected=DeserializerException.class) + public void ieee754CompatibleNullAsString() throws Exception { + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON_IEEE754Compatible); + String entityString = + "{\"PropertyInt16\":32767," + + "\"PropertyString\":\"First Resource - positive values\"," + + "\"PropertyBoolean\":null," + + "\"PropertyByte\":255," + + "\"PropertySByte\":127," + + "\"PropertyInt32\":2147483647," + + "\"PropertyInt64\":\"null\"," + + "\"PropertySingle\":1.79E20," + + "\"PropertyDouble\":-1.79E19," + + "\"PropertyDecimal\":\"null\"," + + "\"PropertyBinary\":\"ASNFZ4mrze8=\"," + + "\"PropertyDate\":null," + + "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\"," + + "\"PropertyDuration\":\"PT6S\"," + + "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + + "\"PropertyTimeOfDay\":\"03:26:05\"}"; + + final InputStream stream = new ByteArrayInputStream(entityString.getBytes()); + deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))).getEntity(); + } + private void checkPropertyJsonType(final String entityString) throws DeserializerException { InputStream stream = new ByteArrayInputStream(entityString.getBytes()); - ODataDeserializer deserializer = OData.newInstance().createDeserializer(ODataFormat.JSON); + ODataDeserializer deserializer = OData.newInstance().createDeserializer(CONTENT_TYPE_JSON); try { deserializer.entity(stream, edm.getEntityType(new FullQualifiedName("Namespace1_Alias", "ETAllPrim"))); fail("Expected an exception but was not thrown: " + this.getClass().getName()); diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java index c9cfde9f5..15dd99b1c 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ODataJsonSerializerTest.java @@ -36,7 +36,7 @@ import org.apache.olingo.commons.api.edm.EdmEntitySet; import org.apache.olingo.commons.api.edm.EdmEntityType; import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.edm.EdmProperty; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.edmx.EdmxReference; import org.apache.olingo.server.api.serializer.ComplexSerializerOptions; @@ -44,6 +44,8 @@ import org.apache.olingo.server.api.serializer.EntityCollectionSerializerOptions import org.apache.olingo.server.api.serializer.EntitySerializerOptions; import org.apache.olingo.server.api.serializer.ODataSerializer; import org.apache.olingo.server.api.serializer.PrimitiveSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceCollectionSerializerOptions; +import org.apache.olingo.server.api.serializer.ReferenceSerializerOptions; import org.apache.olingo.server.api.serializer.SerializerException; import org.apache.olingo.server.api.serializer.SerializerResult; import org.apache.olingo.server.api.uri.UriHelper; @@ -68,7 +70,9 @@ public class ODataJsonSerializerTest { new EdmTechProvider(), Collections. emptyList(), new MetadataETagSupport("W/\"metadataETag\"")); private static final EdmEntityContainer entityContainer = metadata.getEdm().getEntityContainer(); private final DataProvider data = new DataProvider(); - private final ODataSerializer serializer = new ODataJsonSerializer(ODataFormat.JSON); + private final ODataSerializer serializer = new ODataJsonSerializer(ContentType.JSON); + private final ODataSerializer serializerIEEECompatible = + new ODataJsonSerializer(ContentType.parse("application/json;odata.metadata=minimal;IEEE754Compatible=true")); private final UriHelper helper = new UriHelperImpl(); @Test @@ -302,8 +306,8 @@ public class ODataJsonSerializerTest { public void entityTwoPrimNoMetadata() throws Exception { final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESTwoPrim"); final Entity entity = data.readAll(edmEntitySet).getEntities().get(0); - InputStream result = new ODataJsonSerializer(ODataFormat.JSON_NO_METADATA) - .entity(metadata, edmEntitySet.getEntityType(), entity, null).getContent(); + InputStream result = new ODataJsonSerializer(ContentType.JSON_NO_METADATA) + .entity(metadata, edmEntitySet.getEntityType(), entity, null).getContent(); final String resultString = IOUtils.toString(result); final String expectedResult = "{\"PropertyInt16\":32766,\"PropertyString\":\"Test String1\"}"; Assert.assertEquals(expectedResult, resultString); @@ -313,10 +317,11 @@ public class ODataJsonSerializerTest { public void entitySetTwoPrimNoMetadata() throws Exception { final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESTwoPrim"); final EntityCollection entitySet = data.readAll(edmEntitySet); - InputStream result = new ODataJsonSerializer(ODataFormat.JSON_NO_METADATA) - .entityCollection(metadata, edmEntitySet.getEntityType(), entitySet, - EntityCollectionSerializerOptions.with() - .contextURL(ContextURL.with().entitySet(edmEntitySet).build()).build()).getContent(); + InputStream result = new ODataJsonSerializer(ContentType.JSON_NO_METADATA) + .entityCollection(metadata, edmEntitySet.getEntityType(), entitySet, + EntityCollectionSerializerOptions.with() + .contextURL(ContextURL.with().entitySet(edmEntitySet).build()).build()).getContent(); + final String resultString = IOUtils.toString(result); final String expectedResult = "{\"value\":[" + "{\"PropertyInt16\":32766,\"PropertyString\":\"Test String1\"}," @@ -711,7 +716,7 @@ public class ODataJsonSerializerTest { + "\"PropertyInt16\":111,\"PropertyString\":\"TEST A\"}", resultString); } - + @Test public void complexCollectionProperty() throws Exception { final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESMixPrimCollComp"); @@ -740,7 +745,7 @@ public class ODataJsonSerializerTest { final Entity entity = data.readAll(edmEntitySet).getEntities().get(0); final SerializerResult serializerResult = serializer.reference(metadata, edmEntitySet, entity, - ContextURL.with().suffix(Suffix.REFERENCE).build()); + ReferenceSerializerOptions.with().contextURL(ContextURL.with().suffix(Suffix.REFERENCE).build()).build()); final String resultString = IOUtils.toString(serializerResult.getContent()); Assert.assertEquals("{\"@odata.context\":\"$metadata#$ref\"," @@ -754,11 +759,13 @@ public class ODataJsonSerializerTest { final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); final EntityCollection entityCollection = data.readAll(edmEntitySet); - final SerializerResult serializerResult = serializer.referenceCollection(metadata, - edmEntitySet, - entityCollection, - ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()); - + final SerializerResult serializerResult = serializer.referenceCollection(metadata, + edmEntitySet, + entityCollection, + ReferenceCollectionSerializerOptions.with() + .contextURL(ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()) + .build()); + final String resultString = IOUtils.toString(serializerResult.getContent()); Assert.assertEquals("{\"@odata.context\":\"$metadata#Collection($ref)\"," @@ -774,15 +781,219 @@ public class ODataJsonSerializerTest { final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); final EntityCollection entityCollection = new EntityCollection(); - final SerializerResult serializerResult = serializer.referenceCollection(metadata, - edmEntitySet, - entityCollection, - ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()); - + final SerializerResult serializerResult = serializer.referenceCollection(metadata, + edmEntitySet, entityCollection, + ReferenceCollectionSerializerOptions.with() + .contextURL(ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()) + .build()); + final String resultString = IOUtils.toString(serializerResult.getContent()); Assert.assertEquals("{\"@odata.context\":\"$metadata#Collection($ref)\"," + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + "\"value\":[]}", resultString); } + + @Test + public void entityIEE754Compatible() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); + final Entity entity = data.readAll(edmEntitySet).getEntities().get(0); + InputStream result = serializerIEEECompatible.entity(metadata, edmEntitySet.getEntityType(), entity, + EntitySerializerOptions.with() + .contextURL(ContextURL.with().entitySet(edmEntitySet).suffix(Suffix.ENTITY).build()) + .build()).getContent(); + final String resultString = IOUtils.toString(result); + final String expectedResult = "{" + + "\"@odata.context\":\"$metadata#ESAllPrim/$entity\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"PropertyInt16\":32767," + + "\"PropertyString\":\"First Resource - positive values\"," + + "\"PropertyBoolean\":true," + + "\"PropertyByte\":255," + + "\"PropertySByte\":127," + + "\"PropertyInt32\":2147483647," + + "\"PropertyInt64\":\"" + Long.MAX_VALUE + "\"," + + "\"PropertySingle\":1.79E20," + + "\"PropertyDouble\":-1.79E19," + + "\"PropertyDecimal\":\"34\"," + + "\"PropertyBinary\":\"ASNFZ4mrze8=\"," + + "\"PropertyDate\":\"2012-12-03\"," + + "\"PropertyDateTimeOffset\":\"2012-12-03T07:16:23Z\"," + + "\"PropertyDuration\":\"PT6S\"," + + "\"PropertyGuid\":\"01234567-89ab-cdef-0123-456789abcdef\"," + + "\"PropertyTimeOfDay\":\"03:26:05\"" + + "}"; + Assert.assertEquals(expectedResult, resultString); + } + + @Test + public void entityCollAllPrimIEEE754Compatible() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESCollAllPrim"); + final Entity entity = data.readAll(edmEntitySet).getEntities().get(0); + InputStream result = serializerIEEECompatible.entity(metadata, edmEntitySet.getEntityType(), entity, + EntitySerializerOptions.with() + .contextURL(ContextURL.with().serviceRoot(URI.create("http://host/service/")) + .entitySet(edmEntitySet).suffix(Suffix.ENTITY).build()) + .build()).getContent(); + final String resultString = IOUtils.toString(result); + final String expectedResult = "{" + + "\"@odata.context\":\"http://host/service/$metadata#ESCollAllPrim/$entity\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"PropertyInt16\":1," + + "\"CollPropertyString\":" + + "[\"Employee1@company.example\",\"Employee2@company.example\",\"Employee3@company.example\"]," + + "\"CollPropertyBoolean\":[true,false,true]," + + "\"CollPropertyByte\":[50,200,249]," + + "\"CollPropertySByte\":[-120,120,126]," + + "\"CollPropertyInt16\":[1000,2000,30112]," + + "\"CollPropertyInt32\":[23232323,11223355,10000001]," + + "\"CollPropertyInt64\":[\"929292929292\",\"333333333333\",\"444444444444\"]," + + "\"CollPropertySingle\":[1790.0,26600.0,3210.0]," + + "\"CollPropertyDouble\":[-17900.0,-2.78E7,3210.0]," + + "\"CollPropertyDecimal\":[\"12\",\"-2\",\"1234\"]," + + "\"CollPropertyBinary\":[\"q83v\",\"ASNF\",\"VGeJ\"]," + + "\"CollPropertyDate\":[\"1958-12-03\",\"1999-08-05\",\"2013-06-25\"]," + + "\"CollPropertyDateTimeOffset\":[\"2015-08-12T03:08:34Z\",\"1970-03-28T12:11:10Z\"," + + "\"1948-02-17T09:09:09Z\"]," + + "\"CollPropertyDuration\":[\"PT13S\",\"PT5H28M0S\",\"PT1H0S\"]," + + "\"CollPropertyGuid\":[\"ffffff67-89ab-cdef-0123-456789aaaaaa\",\"eeeeee67-89ab-cdef-0123-456789bbbbbb\"," + + "\"cccccc67-89ab-cdef-0123-456789cccccc\"]," + + "\"CollPropertyTimeOfDay\":[\"04:14:13\",\"23:59:59\",\"01:12:33\"]" + + "}"; + Assert.assertEquals(expectedResult, resultString); + } + + @Test + public void primitiveCollectionPropertyIEEE754CompatibleInt64() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESCollAllPrim"); + final EdmProperty edmProperty = (EdmProperty) edmEntitySet.getEntityType().getProperty("CollPropertyInt64"); + final Property property = data.readAll(edmEntitySet).getEntities().get(0).getProperty(edmProperty.getName()); + + final String resultString = IOUtils.toString(serializerIEEECompatible + .primitiveCollection(metadata, (EdmPrimitiveType) edmProperty.getType(), property, + PrimitiveSerializerOptions.with() + .contextURL(ContextURL.with() + .entitySet(edmEntitySet).keyPath("1").navOrPropertyPath(edmProperty.getName()).build()) + .build()).getContent()); + Assert.assertEquals("{" + + "\"@odata.context\":\"$metadata#ESCollAllPrim(1)/CollPropertyInt64\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"value\":[\"929292929292\",\"333333333333\",\"444444444444\"]}", + resultString); + } + + @Test + public void primitiveCollectionPropertyIEEE754CompatibleDecimal() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESCollAllPrim"); + final EdmProperty edmProperty = (EdmProperty) edmEntitySet.getEntityType().getProperty("CollPropertyDecimal"); + final Property property = data.readAll(edmEntitySet).getEntities().get(0).getProperty(edmProperty.getName()); + + final String resultString = IOUtils.toString(serializerIEEECompatible + .primitiveCollection(metadata, (EdmPrimitiveType) edmProperty.getType(), property, + PrimitiveSerializerOptions.with() + .contextURL(ContextURL.with() + .entitySet(edmEntitySet).keyPath("1").navOrPropertyPath(edmProperty.getName()).build()) + .build()).getContent()); + Assert.assertEquals("{" + + "\"@odata.context\":\"$metadata#ESCollAllPrim(1)/CollPropertyDecimal\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"value\":[\"12\",\"-2\",\"1234\"]}", + resultString); + } + + @Test + public void primitivePropertyIEEE754CompatibleInt64() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); + final EdmProperty edmProperty = (EdmProperty) edmEntitySet.getEntityType().getProperty("PropertyInt64"); + final Property property = data.readAll(edmEntitySet).getEntities().get(0).getProperty(edmProperty.getName()); + final String resultString = IOUtils.toString(serializerIEEECompatible + .primitive(metadata, (EdmPrimitiveType) edmProperty.getType(), property, + PrimitiveSerializerOptions.with() + .contextURL(ContextURL.with() + .entitySet(edmEntitySet).keyPath("32767").navOrPropertyPath(edmProperty.getName()).build()) + .build()).getContent()); + Assert.assertEquals("{" + + "\"@odata.context\":\"$metadata#ESAllPrim(32767)/PropertyInt64\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"value\":\"" + Long.MAX_VALUE + "\"}", + resultString); + } + + @Test + public void primitivePropertyIEEE754CompatibleDecimal() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); + final EdmProperty edmProperty = (EdmProperty) edmEntitySet.getEntityType().getProperty("PropertyDecimal"); + final Property property = data.readAll(edmEntitySet).getEntities().get(0).getProperty(edmProperty.getName()); + final String resultString = IOUtils.toString(serializerIEEECompatible + .primitive(metadata, (EdmPrimitiveType) edmProperty.getType(), property, + PrimitiveSerializerOptions.with() + .contextURL(ContextURL.with() + .entitySet(edmEntitySet).keyPath("32767").navOrPropertyPath(edmProperty.getName()).build()) + .build()).getContent()); + Assert.assertEquals("{" + + "\"@odata.context\":\"$metadata#ESAllPrim(32767)/PropertyDecimal\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"value\":\"34\"}", + resultString); + } + + @Test + public void entitySetAllPrimIEEE754CompatibleCount() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); + EntityCollection entitySet = data.readAll(edmEntitySet); + entitySet.setCount(entitySet.getEntities().size()); + entitySet.setNext(URI.create("/next")); + CountOption countOption = Mockito.mock(CountOption.class); + Mockito.when(countOption.getValue()).thenReturn(true); + InputStream result = serializerIEEECompatible.entityCollection(metadata, edmEntitySet.getEntityType(), entitySet, + EntityCollectionSerializerOptions.with() + .contextURL(ContextURL.with().entitySet(edmEntitySet).build()) + .count(countOption) + .build()).getContent(); + final String resultString = IOUtils.toString(result); + + Assert.assertThat(resultString, CoreMatchers.startsWith("{" + + "\"@odata.context\":\"$metadata#ESAllPrim\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"@odata.count\":\"3\",\"value\":[")); + Assert.assertThat(resultString, CoreMatchers.endsWith("]," + + "\"@odata.nextLink\":\"/next\"}")); + + int count = 0; + int index = -1; + while ((index = resultString.indexOf("PropertyInt16\":", ++index)) > 0) { + count++; + } + Assert.assertEquals(3, count); + } + + @Test + public void entitySetAllPrimReferenceIEEE754CompatibleCount() throws Exception { + final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); + EntityCollection entitySet = data.readAll(edmEntitySet); + entitySet.setCount(entitySet.getEntities().size()); + entitySet.setNext(URI.create("/next")); + CountOption countOption = Mockito.mock(CountOption.class); + Mockito.when(countOption.getValue()).thenReturn(true); + InputStream result = serializerIEEECompatible.referenceCollection(metadata, edmEntitySet, entitySet, + ReferenceCollectionSerializerOptions.with() + .contextURL(ContextURL.with().asCollection().suffix(Suffix.REFERENCE).build()) + .count(countOption) + .build()).getContent(); + final String resultString = IOUtils.toString(result); + + Assert.assertThat(resultString, CoreMatchers.startsWith("{" + + "\"@odata.context\":\"$metadata#Collection($ref)\"," + + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + + "\"@odata.count\":\"3\",\"value\":[")); + Assert.assertThat(resultString, CoreMatchers.endsWith("]," + + "\"@odata.nextLink\":\"/next\"}")); + + int count = 0; + int index = -1; + while ((index = resultString.indexOf("ESAllPrim(", ++index)) > 0) { + count++; + } + Assert.assertEquals(3, count); + } } diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentTest.java index ae9e314c2..bd4a55166 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/json/ServiceDocumentTest.java @@ -26,7 +26,7 @@ import java.io.InputStream; import java.util.Collections; import org.apache.commons.io.IOUtils; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.edmx.EdmxReference; @@ -47,7 +47,7 @@ public class ServiceDocumentTest { OData server = OData.newInstance(); assertNotNull(server); - ODataSerializer serializer = server.createSerializer(ODataFormat.JSON); + ODataSerializer serializer = server.createSerializer(ContentType.JSON); assertNotNull(serializer); InputStream result = serializer.serviceDocument(metadata, serviceRoot).getContent(); diff --git a/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentTest.java b/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentTest.java index a8619b318..ef27e2483 100644 --- a/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentTest.java +++ b/lib/server-test/src/test/java/org/apache/olingo/server/core/serializer/xml/MetadataDocumentTest.java @@ -27,7 +27,7 @@ import java.util.Arrays; import java.util.List; import org.apache.commons.io.IOUtils; -import org.apache.olingo.commons.api.format.ODataFormat; +import org.apache.olingo.commons.api.format.ContentType; import org.apache.olingo.server.api.OData; import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.edmx.EdmxReference; @@ -48,7 +48,7 @@ public class MetadataDocumentTest { new EdmTechProvider(references), references); final String metadata = IOUtils.toString( - odata.createSerializer(ODataFormat.XML).metadataDocument(serviceMetadata).getContent()); + odata.createSerializer(ContentType.APPLICATION_XML).metadataDocument(serviceMetadata).getContent()); assertNotNull(metadata); assertThat(metadata, containsString("" diff --git a/samples/server/src/main/java/org/apache/olingo/server/sample/processor/CarsProcessor.java b/samples/server/src/main/java/org/apache/olingo/server/sample/processor/CarsProcessor.java index caffcd5ab..0b1917fdf 100644 --- a/samples/server/src/main/java/org/apache/olingo/server/sample/processor/CarsProcessor.java +++ b/samples/server/src/main/java/org/apache/olingo/server/sample/processor/CarsProcessor.java @@ -34,7 +34,6 @@ import org.apache.olingo.commons.api.edm.EdmEntitySet; import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.format.ContentType; -import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.http.HttpContentType; import org.apache.olingo.commons.api.http.HttpHeader; import org.apache.olingo.commons.api.http.HttpStatusCode; @@ -102,15 +101,14 @@ public class CarsProcessor implements EntityCollectionProcessor, EntityProcessor // Next we create a serializer based on the requested format. This could also be a custom format but we do not // support them in this example - final ODataFormat format = ODataFormat.fromContentType(requestedContentType); - ODataSerializer serializer = odata.createSerializer(format); + ODataSerializer serializer = odata.createSerializer(requestedContentType); // Now the content is serialized using the serializer. final ExpandOption expand = uriInfo.getExpandOption(); final SelectOption select = uriInfo.getSelectOption(); InputStream serializedContent = serializer.entityCollection(edm, edmEntitySet.getEntityType(), entitySet, EntityCollectionSerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : + .contextURL(isODataMetadataNone(requestedContentType) ? null : getContextUrl(edmEntitySet, false, expand, select, null)) .count(uriInfo.getCountOption()) .expand(expand).select(select) @@ -142,13 +140,12 @@ public class CarsProcessor implements EntityCollectionProcessor, EntityProcessor .getStatusCode(), Locale.ENGLISH); } else { // If an entity was found we proceed by serializing it and sending it to the client. - final ODataFormat format = ODataFormat.fromContentType(requestedContentType); - ODataSerializer serializer = odata.createSerializer(format); + ODataSerializer serializer = odata.createSerializer(requestedContentType); final ExpandOption expand = uriInfo.getExpandOption(); final SelectOption select = uriInfo.getSelectOption(); InputStream serializedContent = serializer.entity(edm, edmEntitySet.getEntityType(), entity, EntitySerializerOptions.with() - .contextURL(format == ODataFormat.JSON_NO_METADATA ? null : + .contextURL(isODataMetadataNone(requestedContentType) ? null : getContextUrl(edmEntitySet, true, expand, select, null)) .expand(expand).select(select) .build()).getContent(); @@ -254,9 +251,8 @@ public class CarsProcessor implements EntityCollectionProcessor, EntityProcessor if (property.getValue() == null) { response.setStatusCode(HttpStatusCode.NO_CONTENT.getStatusCode()); } else { - final ODataFormat format = ODataFormat.fromContentType(contentType); - ODataSerializer serializer = odata.createSerializer(format); - final ContextURL contextURL = format == ODataFormat.JSON_NO_METADATA ? null : + ODataSerializer serializer = odata.createSerializer(contentType); + final ContextURL contextURL = isODataMetadataNone(contentType) ? null : getContextUrl(edmEntitySet, true, null, null, edmProperty.getName()); InputStream serializerContent = complex ? serializer.complex(edm, (EdmComplexType) edmProperty.getType(), property, @@ -368,4 +364,9 @@ public class CarsProcessor implements EntityCollectionProcessor, EntityProcessor throw new ODataApplicationException("Entity update is not supported yet.", HttpStatusCode.NOT_IMPLEMENTED.getStatusCode(), Locale.ENGLISH); } + + public static boolean isODataMetadataNone(final ContentType contentType) { + return contentType.isCompatible(ContentType.APPLICATION_JSON) + && ContentType.VALUE_ODATA_METADATA_NONE.equals(contentType.getParameter(ContentType.PARAMETER_ODATA_METADATA)); + } } \ No newline at end of file