[OLINGO-317] Added collection type handling

This commit is contained in:
Michael Bolz 2014-07-02 09:28:26 +02:00
parent 71bdaed300
commit da8cf726bf
3 changed files with 285 additions and 68 deletions

View File

@ -135,12 +135,11 @@ public class ODataJsonSerializer implements ODataSerializer {
json.writeNull(); json.writeNull();
} }
} else { } else {
if (edmProperty.isPrimitive()) { if (edmProperty.isCollection()) {
handlePrimitive(edmProperty, property, json);
} else if (edmProperty.isCollection()) {
handleCollection(edmProperty, property, json); handleCollection(edmProperty, property, json);
} else { } else if (edmProperty.isPrimitive()) {
if (property.isLinkedComplex()) { handlePrimitive(edmProperty, property, json);
} else if (property.isLinkedComplex()) {
writeComplexValue(edmProperty, property.asLinkedComplex().getValue(), json); writeComplexValue(edmProperty, property.asLinkedComplex().getValue(), json);
} else if(property.isComplex()) { } else if(property.isComplex()) {
writeComplexValue(edmProperty, property.asComplex(), json); writeComplexValue(edmProperty, property.asComplex(), json);
@ -149,7 +148,6 @@ public class ODataJsonSerializer implements ODataSerializer {
} }
} }
} }
}
private void handleCollection(EdmProperty edmProperty, Property property, JsonGenerator json) private void handleCollection(EdmProperty edmProperty, Property property, JsonGenerator json)
throws IOException, EdmPrimitiveTypeException { throws IOException, EdmPrimitiveTypeException {
@ -167,6 +165,9 @@ public class ODataJsonSerializer implements ODataSerializer {
case COLLECTION_LINKED_COMPLEX: case COLLECTION_LINKED_COMPLEX:
writeComplexValue(edmProperty, ((LinkedComplexValue) value).getValue(), json); writeComplexValue(edmProperty, ((LinkedComplexValue) value).getValue(), json);
break; break;
case COLLECTION_COMPLEX:
writeComplexValue(edmProperty, property.asComplex(), json);
break;
default: default:
throw new ODataRuntimeException("Property type not yet supported!"); throw new ODataRuntimeException("Property type not yet supported!");
} }
@ -237,7 +238,8 @@ public class ODataJsonSerializer implements ODataSerializer {
JsonGenerator json = new JsonFactory().createGenerator(buffer.getOutputStream()); JsonGenerator json = new JsonFactory().createGenerator(buffer.getOutputStream());
json.writeStartObject(); json.writeStartObject();
if (contextURL != null) { if (contextURL != null) {
json.writeStringField(Constants.JSON_CONTEXT, contextURL.getURI().toASCIIString()); String context = "$metadata#" + edmEntitySet.getName();
json.writeStringField(Constants.JSON_CONTEXT, context);
} }
if (entitySet.getCount() != null) { if (entitySet.getCount() != null) {
json.writeNumberField("@odata.count", entitySet.getCount()); json.writeNumberField("@odata.count", entitySet.getCount());

View File

@ -43,6 +43,7 @@ public class ODataJsonSerializerTest {
private static final String ETAllPrim = "ETAllPrim"; private static final String ETAllPrim = "ETAllPrim";
private static final String ETCompAllPrim = "ETCompAllPrim"; private static final String ETCompAllPrim = "ETCompAllPrim";
private static final String ETCollAllPrim = "ETCollAllPrim";
private static final String CTAllPrim = "CTAllPrim"; private static final String CTAllPrim = "CTAllPrim";
private static final String CTAllPrim_Type = "com.sap.odata.test1.CTAllPrim"; private static final String CTAllPrim_Type = "com.sap.odata.test1.CTAllPrim";
@ -50,18 +51,31 @@ public class ODataJsonSerializerTest {
String getName(); String getName();
String getTypeName(); String getTypeName();
EdmPrimitiveTypeKind getType(); EdmPrimitiveTypeKind getType();
boolean isCollection();
} }
public static class TecComplexProperty implements TechProperty { public static class TecComplexProperty implements TechProperty {
final String typeName; final String typeName;
final String name; final String name;
final List<EdmProperty> properties; final List<EdmProperty> properties = new ArrayList<EdmProperty>();
boolean collection = false;
public TecComplexProperty(String typeName, String name, List<EdmProperty> propertyNames) { public TecComplexProperty(String typeName, String name) {
this.typeName = typeName; this.typeName = typeName;
this.name = name; this.name = name;
this.properties = new ArrayList<EdmProperty>(propertyNames); }
TechProperty addProperties(List<EdmProperty> properties) {
this.properties.addAll(properties);
return this;
}
TechProperty asCollection() {
this.collection = true;
return this;
}
@Override
public boolean isCollection() {
return collection;
} }
@Override @Override
public String getName() { public String getName() {
@ -96,25 +110,44 @@ public class ODataJsonSerializerTest {
DateTimeOffset("PropertyDateTimeOffset", EdmPrimitiveTypeKind.DateTimeOffset), DateTimeOffset("PropertyDateTimeOffset", EdmPrimitiveTypeKind.DateTimeOffset),
Duration("PropertyDuration", EdmPrimitiveTypeKind.Duration), Duration("PropertyDuration", EdmPrimitiveTypeKind.Duration),
Guid("PropertyGuid", EdmPrimitiveTypeKind.Guid), Guid("PropertyGuid", EdmPrimitiveTypeKind.Guid),
TimeOfDay("PropertyTimeOfDay", EdmPrimitiveTypeKind.TimeOfDay); TimeOfDay("PropertyTimeOfDay", EdmPrimitiveTypeKind.TimeOfDay),
// <NavigationProperty Name="NavPropertyETTwoPrimOne" Type="test1.ETTwoPrim" Nullable="false"/> // <NavigationProperty Name="NavPropertyETTwoPrimOne" Type="test1.ETTwoPrim" Nullable="false"/>
// NavETTwoPrimOne = "NavPropertyETTwoPrimOne", EdmPrimitiveTypeKind.), // NavETTwoPrimOne = "NavPropertyETTwoPrimOne", EdmPrimitiveTypeKind.),
// <NavigationProperty Name="NavPropertyETTwoPrimMany" Type="Collection(test1.ETTwoPrim)" Nullable="false"/> // <NavigationProperty Name="NavPropertyETTwoPrimMany" Type="Collection(test1.ETTwoPrim)" Nullable="false"/>
// NavETTwoPrimMany("NavPropertyETTwoPrimMany", EdmCom.); // NavETTwoPrimMany("NavPropertyETTwoPrimMany", EdmCom.);
Collection_Int16("CollPropertyInt16", EdmPrimitiveTypeKind.Int16, true),
Collection_String("CollPropertyString", EdmPrimitiveTypeKind.String, true),
Collection_Boolean("CollPropertyBoolean", EdmPrimitiveTypeKind.Boolean, true),
Collection_Byte("CollPropertyByte", EdmPrimitiveTypeKind.Byte, true),
Collection_SByte("CollPropertySByte", EdmPrimitiveTypeKind.SByte, true),
Collection_Int32("CollPropertyInt32", EdmPrimitiveTypeKind.Int32, true),
Collection_Int64("CollPropertyInt64", EdmPrimitiveTypeKind.Int64, true),
Collection_Single("CollPropertySingle", EdmPrimitiveTypeKind.Single, true),
Collection_Double("CollPropertyDouble", EdmPrimitiveTypeKind.Double, true),
Collection_Decimal("CollPropertyDecimal", EdmPrimitiveTypeKind.Decimal, true),
Collection_Binary("CollPropertyBinary", EdmPrimitiveTypeKind.Binary, true),
Collection_Date("CollPropertyDate", EdmPrimitiveTypeKind.Date, true),
Collection_DateTimeOffset("CollPropertyDateTimeOffset", EdmPrimitiveTypeKind.DateTimeOffset, true),
Collection_Duration("CollPropertyDuration", EdmPrimitiveTypeKind.Duration, true),
Collection_Guid("CollPropertyGuid", EdmPrimitiveTypeKind.Guid, true),
Collection_TimeOfDay("CollPropertyTimeOfDay", EdmPrimitiveTypeKind.TimeOfDay, true);
final String name; final String name;
final EdmPrimitiveTypeKind type; final EdmPrimitiveTypeKind type;
final boolean isCollection;
TecSimpleProperty(String name, EdmPrimitiveTypeKind type) { TecSimpleProperty(String name, EdmPrimitiveTypeKind type) {
this(name, type, false);
}
TecSimpleProperty(String name, EdmPrimitiveTypeKind type, boolean collection) {
this.name = name; this.name = name;
this.type = type; this.type = type;
this.isCollection = collection;
} }
@Override @Override
public String getTypeName() { public String getTypeName() {
return type.name(); return type.name();
} }
@Override @Override
public EdmPrimitiveTypeKind getType() { public EdmPrimitiveTypeKind getType() {
return type; return type;
@ -123,12 +156,19 @@ public class ODataJsonSerializerTest {
public String getName() { public String getName() {
return name; return name;
} }
@Override
public boolean isCollection() {
return isCollection;
}
} }
private ContextURL contextUrl; private ContextURL contextUrl;
private EdmEntitySet edmESAllPrim; private EdmEntitySet edmESAllPrim;
private EdmEntitySet edmESCompAllPrim;
private EdmEntitySet edmESCollAllPrim;
private EdmEntityType edmETAllPrim; private EdmEntityType edmETAllPrim;
private EdmEntityType edmETCompAllPrim; private EdmEntityType edmETCompAllPrim;
private EdmEntityType edmETCollAllPrim;
private ODataJsonSerializer serializer = new ODataJsonSerializer(); private ODataJsonSerializer serializer = new ODataJsonSerializer();
@ -136,6 +176,7 @@ public class ODataJsonSerializerTest {
public void prepare() throws Exception { public void prepare() throws Exception {
contextUrl = ContextURL.getInstance(new URI("http://localhost:8080/test.svc")); contextUrl = ContextURL.getInstance(new URI("http://localhost:8080/test.svc"));
// entity all primitive
edmETAllPrim = Mockito.mock(EdmEntityType.class); edmETAllPrim = Mockito.mock(EdmEntityType.class);
Mockito.when(edmETAllPrim.getName()).thenReturn(ETAllPrim); Mockito.when(edmETAllPrim.getName()).thenReturn(ETAllPrim);
List<EdmProperty> properties = Arrays.asList( List<EdmProperty> properties = Arrays.asList(
@ -176,7 +217,7 @@ public class ODataJsonSerializerTest {
Mockito.when(edmETCompAllPrim.getName()).thenReturn(ETCompAllPrim); Mockito.when(edmETCompAllPrim.getName()).thenReturn(ETCompAllPrim);
List<EdmProperty> capProperties = Arrays.asList( List<EdmProperty> capProperties = Arrays.asList(
mockProperty(TecSimpleProperty.Int16, false), mockProperty(TecSimpleProperty.Int16, false),
mockProperty(new TecComplexProperty(CTAllPrim_Type, CTAllPrim, properties), false) mockProperty(new TecComplexProperty(CTAllPrim_Type, CTAllPrim).addProperties(properties), false)
); );
List<String> capPropertyNames = new ArrayList<String>(); List<String> capPropertyNames = new ArrayList<String>();
@ -185,6 +226,38 @@ public class ODataJsonSerializerTest {
Mockito.when(edmETCompAllPrim.getProperty(property.getName())).thenReturn(property); Mockito.when(edmETCompAllPrim.getProperty(property.getName())).thenReturn(property);
} }
Mockito.when(edmETCompAllPrim.getPropertyNames()).thenReturn(capPropertyNames); Mockito.when(edmETCompAllPrim.getPropertyNames()).thenReturn(capPropertyNames);
// entity type all primitive collections
//
edmETCollAllPrim = Mockito.mock(EdmEntityType.class);
Mockito.when(edmETCollAllPrim.getName()).thenReturn(ETCollAllPrim);
List<EdmProperty> allCollProperties = Arrays.asList(
mockProperty(TecSimpleProperty.Int16, false),
mockProperty(TecSimpleProperty.Collection_String),
mockProperty(TecSimpleProperty.Collection_Boolean),
mockProperty(TecSimpleProperty.Collection_Byte),
mockProperty(TecSimpleProperty.Collection_SByte),
mockProperty(TecSimpleProperty.Collection_Int32),
mockProperty(TecSimpleProperty.Collection_Int64),
mockProperty(TecSimpleProperty.Collection_Single),
mockProperty(TecSimpleProperty.Collection_Double),
mockProperty(TecSimpleProperty.Collection_Decimal),
mockProperty(TecSimpleProperty.Collection_Binary),
mockProperty(TecSimpleProperty.Collection_Date),
mockProperty(TecSimpleProperty.Collection_DateTimeOffset),
mockProperty(TecSimpleProperty.Collection_Duration),
mockProperty(TecSimpleProperty.Collection_Guid),
mockProperty(TecSimpleProperty.Collection_TimeOfDay)
);
List<String> etCollAllPrimPropertyNames = new ArrayList<String>();
for (EdmProperty property : allCollProperties) {
etCollAllPrimPropertyNames.add(property.getName());
Mockito.when(edmETCollAllPrim.getProperty(property.getName())).thenReturn(property);
}
Mockito.when(edmETCollAllPrim.getPropertyNames()).thenReturn(etCollAllPrimPropertyNames);
// Entity Set all primitive collection
} }
private EdmProperty mockProperty(TechProperty name) { private EdmProperty mockProperty(TechProperty name) {
@ -217,6 +290,7 @@ public class ODataJsonSerializerTest {
Mockito.when(edmElement.getScale()).thenReturn(10); Mockito.when(edmElement.getScale()).thenReturn(10);
Mockito.when(edmElement.getType()).thenReturn(EdmPrimitiveTypeFactory.getInstance(tecProperty.getType())); Mockito.when(edmElement.getType()).thenReturn(EdmPrimitiveTypeFactory.getInstance(tecProperty.getType()));
} }
Mockito.when(edmElement.isCollection()).thenReturn(tecProperty.isCollection());
Mockito.when(edmElement.isNullable()).thenReturn(nullable); Mockito.when(edmElement.isNullable()).thenReturn(nullable);
return edmElement; return edmElement;
} }
@ -225,8 +299,16 @@ public class ODataJsonSerializerTest {
return new PropertyImpl(property.getTypeName(), property.getName(), vType, value); return new PropertyImpl(property.getTypeName(), property.getName(), vType, value);
} }
private PropertyImpl createProperty(String type, TecSimpleProperty property, ValueType vType, Object value) { private PropertyImpl createProperty(String type, TecSimpleProperty property, ValueType vType, Object ... value) {
return new PropertyImpl(type, property.name, vType, value); final Object propValue;
if(value == null || value.length ==0) {
propValue = null;
} else if(property.isCollection()) {
propValue = Arrays.asList(value);
} else {
propValue = value[0];
}
return new PropertyImpl(type, property.name, vType, propValue);
} }
@Test @Test
@ -257,7 +339,6 @@ public class ODataJsonSerializerTest {
Assert.assertEquals(expectedResult, resultString); Assert.assertEquals(expectedResult, resultString);
} }
@Test @Test
public void entitySetETAllPrim() throws Exception { public void entitySetETAllPrim() throws Exception {
EdmEntitySet edmEntitySet = edmESAllPrim; EdmEntitySet edmEntitySet = edmESAllPrim;
@ -287,6 +368,34 @@ public class ODataJsonSerializerTest {
Assert.assertEquals(100, count); Assert.assertEquals(100, count);
} }
@Test
public void entityCollAllPrim() throws Exception {
Entity entity = createETCollAllPrim(4711);
InputStream result = serializer.entity(edmETCollAllPrim, entity, contextUrl);
String resultString = streamToString(result);
String expectedResult = "{" +
"\"@odata.context\":\"http://localhost:8080/test.svc\"," +
"\"PropertyInt16\":4711," +
"\"CollPropertyString\":[\"StringValue_1\",\"StringValue_2\"]," +
"\"CollPropertyBoolean\":[true,false]," +
"\"CollPropertyByte\":[19,42]," +
"\"CollPropertySByte\":[1,2]," +
"\"CollPropertyInt32\":[2147483647,-2147483648]," +
"\"CollPropertyInt64\":[9223372036854775807,-9223372036854775808]," +
"\"CollPropertySingle\":[47.11,11.47]," +
"\"CollPropertyDouble\":[4.711,711.4]," +
"\"CollPropertyDecimal\":[4711.1174,1174.4711]," +
"\"CollPropertyBinary\":[\"BAcBAQ==\",\"dGVzdA==\"]," +
"\"CollPropertyDate\":[\"2014-03-19\",\"2014-07-02\"]," +
"\"CollPropertyDateTimeOffset\":[\"2014-03-19T10:12:00+01:00\",\"2014-07-02T13:30:00+02:00\"]," +
"\"CollPropertyDuration\":[\"P16148383DT8H0S\",\"P16253479DT4H0S\"]," +
"\"CollPropertyGuid\":[\"0000aaaa-00bb-00cc-00dd-000000ffffff\",\"0000ffff-00dd-00cc-00bb-000000aaaaaa\"]," +
"\"CollPropertyTimeOfDay\":[\"10:12:00\",\"13:30:00\"]" +
"}";
Assert.assertEquals(expectedResult, resultString);
}
@Test @Test
public void entityETCompAllPrim() throws Exception { public void entityETCompAllPrim() throws Exception {
Entity complexCtAllPrim = createETAllPrim(); Entity complexCtAllPrim = createETAllPrim();
@ -294,7 +403,7 @@ public class ODataJsonSerializerTest {
Entity entity = new EntityImpl(); Entity entity = new EntityImpl();
entity.addProperty(new PropertyImpl("Edm.Int16", TecSimpleProperty.Int16.name, ValueType.PRIMITIVE, 4711)); entity.addProperty(new PropertyImpl("Edm.Int16", TecSimpleProperty.Int16.name, ValueType.PRIMITIVE, 4711));
entity.addProperty(createProperty( entity.addProperty(createProperty(
new TecComplexProperty(CTAllPrim_Type, CTAllPrim, Collections.<EdmProperty>emptyList()), new TecComplexProperty(CTAllPrim_Type, CTAllPrim),
ValueType.COMPLEX, complexCtAllPrim.getProperties())); ValueType.COMPLEX, complexCtAllPrim.getProperties()));
InputStream result = serializer.entity(edmETCompAllPrim, entity, contextUrl); InputStream result = serializer.entity(edmETCompAllPrim, entity, contextUrl);
@ -323,10 +432,59 @@ public class ODataJsonSerializerTest {
Assert.assertEquals(expectedResult, resultString); Assert.assertEquals(expectedResult, resultString);
} }
private Entity createETAllPrim() { private Entity createETAllPrim() {
return createETAllPrim(4711); return createETAllPrim(4711);
} }
private Entity createETCollAllPrim(int id) {
Entity entity = new EntityImpl();
Calendar date = Calendar.getInstance();
date.set(2014, Calendar.MARCH, 19, 10, 12, 0);
date.set(Calendar.MILLISECOND, 0);
Calendar date2 = Calendar.getInstance();
date2.set(2014, Calendar.JULY, 2, 13, 30, 0);
date2.set(Calendar.MILLISECOND, 0);
//
entity.addProperty(createProperty("Edm.Int16", TecSimpleProperty.Int16, ValueType.PRIMITIVE, id));
//
entity.addProperty(createProperty("Collection(Edm.Int16)", TecSimpleProperty.Collection_Int16,
ValueType.COLLECTION_PRIMITIVE, id));
entity.addProperty(createProperty("Collection(Edm.String)", TecSimpleProperty.Collection_String,
ValueType.COLLECTION_PRIMITIVE, "StringValue_1", "StringValue_2"));
entity.addProperty(createProperty("Collection(Edm.Boolean)", TecSimpleProperty.Collection_Boolean,
ValueType.COLLECTION_PRIMITIVE, Boolean.TRUE, Boolean.FALSE));
entity.addProperty(createProperty("Collection(Edm.Byte)", TecSimpleProperty.Collection_Byte,
ValueType.COLLECTION_PRIMITIVE, Byte.valueOf("19"), Byte.valueOf("42")));
entity.addProperty(createProperty("Collection(Edm.SByte)", TecSimpleProperty.Collection_SByte,
ValueType.COLLECTION_PRIMITIVE, Short.valueOf("1"), Short.valueOf("2")));
entity.addProperty(createProperty("Collection(Edm.Int32)", TecSimpleProperty.Collection_Int32,
ValueType.COLLECTION_PRIMITIVE, Integer.MAX_VALUE, Integer.MIN_VALUE));
entity.addProperty(createProperty("Collection(Edm.Int64)", TecSimpleProperty.Collection_Int64,
ValueType.COLLECTION_PRIMITIVE, Long.MAX_VALUE, Long.MIN_VALUE));
entity.addProperty(createProperty("Collection(Edm.Single)", TecSimpleProperty.Collection_Single,
ValueType.COLLECTION_PRIMITIVE, 47.11, 11.47));
entity.addProperty(createProperty("Collection(Edm.Double)", TecSimpleProperty.Collection_Double,
ValueType.COLLECTION_PRIMITIVE, 4.711, 711.4));
entity.addProperty(createProperty("Collection(Edm.Decimal)", TecSimpleProperty.Collection_Decimal,
ValueType.COLLECTION_PRIMITIVE, 4711.1174, 1174.4711));
entity.addProperty(createProperty("Collection(Edm.Binary)", TecSimpleProperty.Collection_Binary,
ValueType.COLLECTION_PRIMITIVE, new byte[]{0x04, 0x07, 0x01, 0x01}, "test".getBytes()));
entity.addProperty(createProperty("Collection(Edm.Date)", TecSimpleProperty.Collection_Date,
ValueType.COLLECTION_PRIMITIVE, date, date2));
entity.addProperty(createProperty("Collection(Edm.DateTimeOffset)", TecSimpleProperty.Collection_DateTimeOffset,
ValueType.COLLECTION_PRIMITIVE, date.getTime(), date2.getTime()));
entity.addProperty(createProperty("Collection(Edm.Duration)", TecSimpleProperty.Collection_Duration,
ValueType.COLLECTION_PRIMITIVE, date.getTimeInMillis(), date2.getTimeInMillis()));
entity.addProperty(createProperty("Collection(Edm.Guid)", TecSimpleProperty.Collection_Guid,
ValueType.COLLECTION_PRIMITIVE,
UUID.fromString("AAAA-BB-CC-DD-FFFFFF"),
UUID.fromString("FFFF-DD-CC-BB-AAAAAA")));
entity.addProperty(createProperty("Collection(Edm.TimeOfDay)", TecSimpleProperty.Collection_TimeOfDay,
ValueType.COLLECTION_PRIMITIVE, date, date2));
return entity;
}
private Entity createETAllPrim(int id) { private Entity createETAllPrim(int id) {
Entity entity = new EntityImpl(); Entity entity = new EntityImpl();
Calendar date = Calendar.getInstance(); Calendar date = Calendar.getInstance();

View File

@ -19,9 +19,7 @@
package org.apache.olingo.server.tecsvc.processor; package org.apache.olingo.server.tecsvc.processor;
import java.net.URI; import java.net.URI;
import java.util.ArrayList; import java.util.*;
import java.util.List;
import java.util.UUID;
import org.apache.olingo.commons.api.data.ContextURL; import org.apache.olingo.commons.api.data.ContextURL;
import org.apache.olingo.commons.api.data.Entity; import org.apache.olingo.commons.api.data.Entity;
@ -70,9 +68,9 @@ public class SampleJsonProcessor implements EntitySetProcessor, EntityProcessor
time = System.nanoTime(); time = System.nanoTime();
ODataSerializer serializer = odata.createSerializer(ODataFormat.JSON); ODataSerializer serializer = odata.createSerializer(ODataFormat.JSON);
EdmEntitySet edmEntitySet = getEntitySet(uriInfo); EdmEntitySet edmEntitySet = getEntitySet(uriInfo);
EntitySet entitySet = createEntitySet(edmEntitySet.getEntityType()); ContextURL contextUrl = getContextUrl(request, edmEntitySet.getEntityType());
response.setContent(serializer.entitySet(edmEntitySet, entitySet, EntitySet entitySet = createEntitySet(edmEntitySet.getEntityType(), contextUrl.getURI().toASCIIString());
getContextUrl(request, edmEntitySet.getEntityType()))); response.setContent(serializer.entitySet(edmEntitySet, entitySet, contextUrl));
LOG.info("Finished in " + (System.nanoTime() - time) / 1000 + " microseconds"); LOG.info("Finished in " + (System.nanoTime() - time) / 1000 + " microseconds");
response.setStatusCode(HttpStatusCode.OK.getStatusCode()); response.setStatusCode(HttpStatusCode.OK.getStatusCode());
@ -117,6 +115,9 @@ public class SampleJsonProcessor implements EntitySetProcessor, EntityProcessor
protected Entity createEntity(EdmEntityType entityType) { protected Entity createEntity(EdmEntityType entityType) {
boolean complex = (entityType.getName().contains("Comp")); boolean complex = (entityType.getName().contains("Comp"));
if(entityType.getName().contains("Coll")) {
return createEntityWithCollection(complex);
}
return createEntity(complex); return createEntity(complex);
} }
@ -142,6 +143,28 @@ public class SampleJsonProcessor implements EntitySetProcessor, EntityProcessor
return entity; return entity;
} }
protected Entity createEntityWithCollection(boolean complex) {
Entity entity = new EntityImpl();
Property propertyInt = new PropertyImpl();
propertyInt.setName("PropertyInt16");
propertyInt.setValue(ValueType.PRIMITIVE, 42);
Property property = new PropertyImpl();
property.setName("CollPropertyString");
property.setValue(ValueType.COLLECTION_PRIMITIVE, Arrays.asList("dummyValue", "dummyValue_2"));
entity.getProperties().add(property);
entity.getProperties().add(propertyInt);
Property propertyGuid = new PropertyImpl();
propertyGuid.setName("CollPropertyGuid");
propertyGuid.setValue(ValueType.COLLECTION_PRIMITIVE, Arrays.asList(UUID.randomUUID(), UUID.randomUUID()));
entity.getProperties().add(propertyGuid);
if(complex) {
entity.addProperty(createCollectionOfComplexProperty());
}
return entity;
}
protected Property createComplexProperty() { protected Property createComplexProperty() {
List<Property> properties = new ArrayList<Property>(); List<Property> properties = new ArrayList<Property>();
Property property = new PropertyImpl(); Property property = new PropertyImpl();
@ -161,12 +184,46 @@ public class SampleJsonProcessor implements EntitySetProcessor, EntityProcessor
properties); properties);
} }
protected Property createCollectionOfComplexProperty() {
List<Property> properties = new ArrayList<Property>();
Property property = new PropertyImpl();
property.setName("PropertyString");
property.setValue(ValueType.PRIMITIVE, "dummyValue");
properties.add(property);
Property propertyInt = new PropertyImpl();
propertyInt.setName("PropertyInt16");
propertyInt.setValue(ValueType.PRIMITIVE, 42);
properties.add(propertyInt);
Property propertyGuid = new PropertyImpl();
propertyGuid.setName("PropertyGuid");
propertyGuid.setValue(ValueType.PRIMITIVE, UUID.randomUUID());
properties.add(propertyGuid);
protected EntitySet createEntitySet(EdmEntityType edmEntityType) { List<Property> properties2 = new ArrayList<Property>();
Property property2 = new PropertyImpl();
property2.setName("PropertyString");
property2.setValue(ValueType.PRIMITIVE, "dummyValue2");
properties2.add(property2);
Property property2Int = new PropertyImpl();
property2Int.setName("PropertyInt16");
property2Int.setValue(ValueType.PRIMITIVE, 44);
properties2.add(property2Int);
Property property2Guid = new PropertyImpl();
property2Guid.setName("PropertyGuid");
property2Guid.setValue(ValueType.PRIMITIVE, UUID.randomUUID());
properties2.add(property2Guid);
return new PropertyImpl("com.sap.odata.test1.ETCompAllPrim", "PropertyComplex", ValueType.COMPLEX,
Arrays.asList(properties, properties2));
}
protected EntitySet createEntitySet(EdmEntityType edmEntityType, String baseUri) {
EntitySet entitySet = new EntitySetImpl(); EntitySet entitySet = new EntitySetImpl();
entitySet.setCount(4242); int count = (int) ((Math.random() * 50) + 1);
entitySet.setNext(URI.create("nextLinkURI")); entitySet.setCount(count);
for (int i = 0; i < 1000; i++) { entitySet.setNext(URI.create(baseUri + "nextLink"));
for (int i = 0; i < count; i++) {
entitySet.getEntities().add(createEntity(edmEntityType)); entitySet.getEntities().add(createEntity(edmEntityType));
} }
return entitySet; return entitySet;