More V3 property tests
This commit is contained in:
parent
8c58e3ea8d
commit
b85c68fde1
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -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>
|
||||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue