More V3 property tests

This commit is contained in:
Francesco Chicchiriccò 2014-03-29 07:43:10 +01:00
parent 8c58e3ea8d
commit b85c68fde1
8 changed files with 790 additions and 461 deletions

View File

@ -1,401 +0,0 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.olingo.client.core;
import java.io.File;
import java.io.InputStream;
import java.math.BigDecimal;
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import java.util.UUID;
import org.apache.commons.codec.binary.Base64;
import org.apache.olingo.commons.api.Constants;
import org.apache.olingo.commons.api.domain.ODataPrimitiveValue;
import org.apache.olingo.commons.api.domain.ODataProperty;
import org.apache.olingo.commons.api.format.ODataFormat;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.apache.olingo.commons.api.edm.geo.Geospatial;
import org.apache.olingo.commons.api.edm.geo.Geospatial.Dimension;
import org.apache.olingo.commons.api.edm.geo.GeospatialCollection;
import org.apache.olingo.commons.api.edm.geo.LineString;
import org.apache.olingo.commons.api.edm.geo.MultiLineString;
import org.apache.olingo.commons.api.edm.geo.MultiPoint;
import org.apache.olingo.commons.api.edm.geo.MultiPolygon;
import org.apache.olingo.commons.api.edm.geo.Point;
import org.apache.olingo.commons.api.edm.geo.Polygon;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
public abstract class AbstractPrimitiveTest extends AbstractTest {
protected abstract ODataFormat getFormat();
protected ODataServiceVersion getVersion() {
return getClient().getServiceVersion();
}
protected String getFilename(final String entity, final String propertyName) {
return getVersion().name().toLowerCase()
+ File.separatorChar
+ entity.replace('(', '_').replace(")", "")
+ "_" + propertyName.replaceAll("/", "_") + "." + getSuffix(getFormat());
}
protected ODataPrimitiveValue writePrimitiveValue(final ODataPrimitiveValue value) {
final ODataPrimitiveValue newValue = getClient().getPrimitiveValueBuilder().
setType(value.getTypeKind()).
setValue(value.toValue()).build();
final InputStream written = getClient().getWriter().writeProperty(
getClient().getObjectFactory().newPrimitiveProperty(Constants.ELEM_PROPERTY, newValue),
getFormat());
return readPrimitiveValue(written);
}
protected ODataPrimitiveValue readPrimitiveValue(final InputStream input) {
final ODataProperty property = getClient().getBinder().getODataProperty(
getClient().getDeserializer().toProperty(input, getFormat()).getObject());
assertNotNull(property);
assertTrue(property.hasPrimitiveValue());
assertNotNull(property.getPrimitiveValue());
return property.getPrimitiveValue();
}
protected ODataPrimitiveValue readPrimitiveValue(final String entity, final String propertyName) {
final ODataPrimitiveValue value =
readPrimitiveValue(getClass().getResourceAsStream(getFilename(entity, propertyName)));
assertEquals(value.toString(), writePrimitiveValue(value).toString());
return value;
}
protected void int32(final String entity, final String propertyName, final int check)
throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(EdmPrimitiveTypeKind.Int32, opv.getTypeKind());
final Integer value = opv.toCastValue(Integer.class);
assertNotNull(value);
assertTrue(check == value);
}
protected void string(final String entity, final String propertyName, final String check)
throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(EdmPrimitiveTypeKind.String, opv.getTypeKind());
final String value = opv.toCastValue(String.class);
assertNotNull(value);
assertEquals(check, value);
assertEquals(opv, writePrimitiveValue(opv));
}
protected void decimal(final String entity, final String propertyName, final BigDecimal check)
throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(EdmPrimitiveTypeKind.Decimal, opv.getTypeKind());
final BigDecimal value = opv.toCastValue(BigDecimal.class);
assertNotNull(value);
assertTrue(check.equals(value));
}
protected void datetime(final String entity, final String propertyName, final String check)
throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(EdmPrimitiveTypeKind.DateTime, opv.getTypeKind());
final Timestamp value = opv.toCastValue(Timestamp.class);
assertNotNull(value);
assertEquals(check, opv.toString());
}
protected void guid(final String entity, final String propertyName, final String check)
throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(EdmPrimitiveTypeKind.Guid, opv.getTypeKind());
final UUID value = opv.toCastValue(UUID.class);
assertNotNull(value);
assertEquals(check, opv.toString());
}
protected void binary(final String entity, final String propertyName) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(EdmPrimitiveTypeKind.Binary, opv.getTypeKind());
final byte[] value = opv.toCastValue(byte[].class);
assertNotNull(value);
assertTrue(value.length > 0);
assertTrue(Base64.isBase64(opv.toString()));
}
private void checkPoint(final Point point, final Point check) {
assertEquals(check.getX(), point.getX(), 0);
assertEquals(check.getY(), point.getY(), 0);
assertEquals(check.getZ(), point.getZ(), 0);
}
protected void point(
final String entity,
final String propertyName,
final Point expectedValues,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final Point point = opv.toCastValue(Point.class);
assertNotNull(point);
assertEquals(expectedDimension, point.getDimension());
checkPoint(point, expectedValues);
}
private void checkLine(final LineString line, final List<Point> check) {
final List<Point> points = new ArrayList<Point>();
for (Point point : line) {
points.add(point);
}
assertEquals(check.size(), points.size());
for (int i = 0; i < points.size(); i++) {
checkPoint(points.get(i), check.get(i));
}
}
protected void lineString(
final String entity,
final String propertyName,
final List<Point> check,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final LineString lineString = opv.toCastValue(LineString.class);
assertNotNull(lineString);
assertEquals(expectedDimension, lineString.getDimension());
checkLine(lineString, check);
}
protected void multiPoint(
final String entity,
final String propertyName,
final List<Point> check,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final MultiPoint multiPoint = opv.toCastValue(MultiPoint.class);
assertNotNull(multiPoint);
assertEquals(expectedDimension, multiPoint.getDimension());
final List<Point> points = new ArrayList<Point>();
for (Point point : multiPoint) {
points.add(point);
}
assertEquals(check.size(), points.size());
for (int i = 0; i < points.size(); i++) {
checkPoint(points.get(i), check.get(i));
}
}
protected void multiLine(
final String entity,
final String propertyName,
final List<List<Point>> check,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final MultiLineString multiLine = opv.toCastValue(MultiLineString.class);
assertNotNull(multiLine);
assertEquals(expectedDimension, multiLine.getDimension());
final List<LineString> lines = new ArrayList<LineString>();
int i = 0;
for (LineString line : multiLine) {
checkLine(line, check.get(i));
i++;
}
}
private void checkPoligon(
final Polygon polygon,
final List<Point> checkInterior,
final List<Point> checkExterior) {
final List<Point> points = new ArrayList<Point>();
for (Point point : polygon.getInterior()) {
points.add(point);
}
assertEquals(checkInterior.size(), points.size());
for (int i = 0; i < points.size(); i++) {
checkPoint(checkInterior.get(i), points.get(i));
}
points.clear();
for (Point point : polygon.getExterior()) {
points.add(point);
}
assertEquals(checkExterior.size(), points.size());
for (int i = 0; i < points.size(); i++) {
checkPoint(checkExterior.get(i), points.get(i));
}
}
protected void polygon(
final String entity,
final String propertyName,
final List<Point> checkInterior,
final List<Point> checkExterior,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final Polygon polygon = opv.toCastValue(Polygon.class);
assertNotNull(polygon);
assertEquals(expectedDimension, polygon.getDimension());
checkPoligon(polygon, checkInterior, checkExterior);
}
protected void multiPolygon(
final String entity,
final String propertyName,
final List<List<Point>> checkInterior,
final List<List<Point>> checkExterior,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final MultiPolygon multiPolygon = opv.toCastValue(MultiPolygon.class);
assertNotNull(multiPolygon);
assertEquals(expectedDimension, multiPolygon.getDimension());
int i = 0;
for (Polygon polygon : multiPolygon) {
checkPoligon(
polygon,
checkInterior.isEmpty() ? Collections.<Point>emptyList() : checkInterior.get(i),
checkExterior.isEmpty() ? Collections.<Point>emptyList() : checkExterior.get(i));
i++;
}
}
protected void geomCollection(
final String entity,
final String propertyName,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final GeospatialCollection collection = opv.toCastValue(GeospatialCollection.class);
assertNotNull(collection);
assertEquals(expectedDimension, collection.getDimension());
final Iterator<Geospatial> itor = collection.iterator();
int count = 0;
while (itor.hasNext()) {
count++;
final Geospatial geospatial = itor.next();
if (count == 1) {
assertTrue(geospatial instanceof Point);
}
if (count == 2) {
assertTrue(geospatial instanceof LineString);
}
}
assertEquals(2, count);
}
protected void geogCollection(
final String entity,
final String propertyName,
final EdmPrimitiveTypeKind expectedType,
final Dimension expectedDimension) throws EdmPrimitiveTypeException {
final ODataPrimitiveValue opv = readPrimitiveValue(entity, propertyName);
assertEquals(expectedType, opv.getTypeKind());
final GeospatialCollection collection = opv.toCastValue(GeospatialCollection.class);
assertNotNull(collection);
assertEquals(expectedDimension, collection.getDimension());
final Iterator<Geospatial> itor = collection.iterator();
int count = 0;
while (itor.hasNext()) {
count++;
final Geospatial geospatial = itor.next();
if (count == 1) {
assertTrue(geospatial instanceof GeospatialCollection);
}
if (count == 2) {
assertTrue(geospatial instanceof GeospatialCollection);
}
}
assertEquals(2, count);
}
}

View File

@ -16,17 +16,18 @@
* specific language governing permissions and limitations * specific language governing permissions and limitations
* under the License. * under the License.
*/ */
package org.apache.olingo.client.core; package org.apache.olingo.client.core.v3;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.Iterator; import java.util.Iterator;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.olingo.client.api.v3.ODataClient;
import org.apache.olingo.client.core.AbstractTest;
import org.apache.olingo.commons.api.domain.ODataCollectionValue; import org.apache.olingo.commons.api.domain.ODataCollectionValue;
import org.apache.olingo.commons.api.domain.ODataComplexValue; import org.apache.olingo.commons.api.domain.ODataComplexValue;
import org.apache.olingo.commons.api.domain.ODataPrimitiveValue; import org.apache.olingo.commons.api.domain.ODataPrimitiveValue;
@ -35,22 +36,18 @@ import org.apache.olingo.commons.api.domain.ODataValue;
import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.format.ODataFormat;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeException;
import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind; import org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
import org.apache.olingo.commons.api.edm.constants.ODataServiceVersion;
import org.junit.Test; import org.junit.Test;
public abstract class AbstractPropertyTest extends AbstractTest { public class PropertyTest extends AbstractTest {
protected abstract ODataFormat getFormat(); @Override
protected ODataClient getClient() {
protected ODataServiceVersion getVersion() { return v3Client;
return getClient().getServiceVersion();
} }
@Test @Test
public void readPropertyValue() throws IOException { public void readPropertyValue() throws IOException {
final InputStream input = getClass().getResourceAsStream( final InputStream input = getClass().getResourceAsStream("Customer_-10_CustomerId_value.txt");
getVersion().name().toLowerCase() + File.separatorChar
+ "Customer_-10_CustomerId_value.txt");
final ODataPrimitiveValue value = getClient().getPrimitiveValueBuilder(). final ODataPrimitiveValue value = getClient().getPrimitiveValueBuilder().
setType(EdmPrimitiveTypeKind.String). setType(EdmPrimitiveTypeKind.String).
@ -60,19 +57,17 @@ public abstract class AbstractPropertyTest extends AbstractTest {
assertEquals("-10", value.toString()); assertEquals("-10", value.toString());
} }
private ODataProperty primitive() throws IOException, EdmPrimitiveTypeException { private ODataProperty primitive(final ODataFormat format) throws IOException, EdmPrimitiveTypeException {
final InputStream input = getClass().getResourceAsStream( final InputStream input = getClass().getResourceAsStream("Customer_-10_CustomerId." + getSuffix(format));
getVersion().name().toLowerCase() + File.separatorChar final ODataProperty property = getClient().getReader().readProperty(input, format);
+ "Customer_-10_CustomerId." + getSuffix(getFormat()));
final ODataProperty property = getClient().getReader().readProperty(input, getFormat());
assertNotNull(property); assertNotNull(property);
assertTrue(property.hasPrimitiveValue()); assertTrue(property.hasPrimitiveValue());
assertTrue(-10 == property.getPrimitiveValue().toCastValue(Integer.class)); assertTrue(-10 == property.getPrimitiveValue().toCastValue(Integer.class));
ODataProperty comparable; ODataProperty comparable;
final ODataProperty written = getClient().getReader().readProperty( final ODataProperty written = getClient().getReader().readProperty(
getClient().getWriter().writeProperty(property, getFormat()), getFormat()); getClient().getWriter().writeProperty(property, format), format);
if (getFormat() == ODataFormat.XML) { if (format == ODataFormat.XML) {
comparable = written; comparable = written;
} else { } else {
// This is needed because type information gets lost with JSON serialization // This is needed because type information gets lost with JSON serialization
@ -89,23 +84,26 @@ public abstract class AbstractPropertyTest extends AbstractTest {
} }
@Test @Test
public void readPrimitiveProperty() throws IOException, EdmPrimitiveTypeException { public void xmlPrimitive() throws IOException, EdmPrimitiveTypeException {
primitive(); primitive(ODataFormat.XML);
} }
private ODataProperty complex() throws IOException { @Test
final InputStream input = getClass().getResourceAsStream( public void jsonPrimitive() throws IOException, EdmPrimitiveTypeException {
getVersion().name().toLowerCase() + File.separatorChar primitive(ODataFormat.JSON);
+ "Customer_-10_PrimaryContactInfo." + getSuffix(getFormat())); }
final ODataProperty property = getClient().getReader().readProperty(input, getFormat());
private ODataProperty complex(final ODataFormat format) throws IOException {
final InputStream input = getClass().getResourceAsStream("Customer_-10_PrimaryContactInfo." + getSuffix(format));
final ODataProperty property = getClient().getReader().readProperty(input, format);
assertNotNull(property); assertNotNull(property);
assertTrue(property.hasComplexValue()); assertTrue(property.hasComplexValue());
assertEquals(6, property.getComplexValue().size()); assertEquals(6, property.getComplexValue().size());
ODataProperty comparable; ODataProperty comparable;
final ODataProperty written = getClient().getReader().readProperty( final ODataProperty written = getClient().getReader().readProperty(
getClient().getWriter().writeProperty(property, getFormat()), getFormat()); getClient().getWriter().writeProperty(property, format), format);
if (getFormat() == ODataFormat.XML) { if (format == ODataFormat.XML) {
comparable = written; comparable = written;
} else { } else {
// This is needed because type information gets lost with JSON serialization // This is needed because type information gets lost with JSON serialization
@ -123,53 +121,48 @@ public abstract class AbstractPropertyTest extends AbstractTest {
} }
@Test @Test
public void readComplexProperty() throws IOException { public void xmlComplex() throws IOException {
complex(); complex(ODataFormat.XML);
} }
private ODataProperty collection() throws IOException { @Test
final InputStream input = getClass().getResourceAsStream( public void jsonComplex() throws IOException {
getVersion().name().toLowerCase() + File.separatorChar complex(ODataFormat.JSON);
+ "Customer_-10_BackupContactInfo." + getSuffix(getFormat())); }
final ODataProperty property = getClient().getReader().readProperty(input, getFormat());
private ODataProperty collection(final ODataFormat format) throws IOException {
final InputStream input = getClass().getResourceAsStream("Customer_-10_BackupContactInfo." + getSuffix(format));
final ODataProperty property = getClient().getReader().readProperty(input, format);
assertNotNull(property); assertNotNull(property);
assertTrue(property.hasCollectionValue()); assertTrue(property.hasCollectionValue());
assertEquals(9, property.getCollectionValue().size()); assertEquals(9, property.getCollectionValue().size());
ODataProperty comparable; ODataProperty comparable;
final ODataProperty written = getClient().getReader().readProperty( final ODataProperty written = getClient().getReader().readProperty(
getClient().getWriter().writeProperty(property, getFormat()), getFormat()); getClient().getWriter().writeProperty(property, format), format);
if (getFormat() == ODataFormat.XML) { if (format == ODataFormat.XML) {
comparable = written; comparable = written;
} else { } else {
// This is needed because type information gets lost with JSON serialization // This is needed because type information gets lost with JSON serialization
final ODataCollectionValue typedValue = final ODataCollectionValue typedValue = new ODataCollectionValue(property.getCollectionValue().getType());
new ODataCollectionValue(property.getCollectionValue().getType());
for (final Iterator<ODataValue> itor = written.getCollectionValue().iterator(); itor.hasNext();) { for (final Iterator<ODataValue> itor = written.getCollectionValue().iterator(); itor.hasNext();) {
final ODataValue value = itor.next(); final ODataValue value = itor.next();
if (value.isPrimitive()) { typedValue.add(value);
typedValue.add(value);
}
if (value.isComplex()) {
final ODataComplexValue typedComplexValue =
new ODataComplexValue("Microsoft.Test.OData.Services.AstoriaDefaultService.ContactDetails");
for (final Iterator<ODataProperty> valueItor = value.asComplex().iterator(); valueItor.hasNext();) {
final ODataProperty prop = valueItor.next();
typedComplexValue.add(prop);
}
typedValue.add(typedComplexValue);
}
} }
comparable = getClient().getObjectFactory().newCollectionProperty(written.getName(), typedValue); comparable = getClient().getObjectFactory().newCollectionProperty(written.getName(), typedValue);
} }
assertEquals(property, comparable); assertEquals(property, comparable);
return property; return property;
} }
@Test @Test
public void readCollectionProperty() throws IOException { public void xmlCollection() throws IOException {
collection(); collection(ODataFormat.XML);
}
@Test
public void jsonCollection() throws IOException {
collection(ODataFormat.JSON);
} }
} }

View File

@ -19,4 +19,6 @@
under the License. under the License.
--> -->
<d:CustomerId xmlns:d="http://schemas.microsoft.com/ado/2007/08/dataservices" xmlns:m="http://schemas.microsoft.com/ado/2007/08/dataservices/metadata" m:type="Edm.Int32">-10</d:CustomerId> <d:CustomerId xmlns:d="http://schemas.microsoft.com/ado/2007/08/dataservices"
xmlns:m="http://schemas.microsoft.com/ado/2007/08/dataservices/metadata"
m:type="Edm.Int32">-10</d:CustomerId>

View File

@ -66,8 +66,8 @@ class AtomPropertyDeserializer extends AbstractAtomDealer {
foundEndProperty = true; foundEndProperty = true;
} }
} }
return value; return value == null? new PrimitiveValueImpl(StringUtils.EMPTY): value;
} }
private Value fromComplexOrEnum(final XMLEventReader reader, final StartElement start) private Value fromComplexOrEnum(final XMLEventReader reader, final StartElement start)