[OLINGO-663] ETag annotation again in entity collections of technical service

Change-Id: Ia150ba1705fa22e36c3821d5295f1b7f464a4852

Signed-off-by: Christian Amend <christian.amend@sap.com>
This commit is contained in:
Klaus Straubinger 2015-06-10 15:06:33 +02:00 committed by Christian Amend
parent 39f0708d0c
commit 5501e8e331
11 changed files with 159 additions and 169 deletions

View File

@ -32,7 +32,6 @@ import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse
import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntity;
import org.apache.olingo.client.api.domain.ClientEntitySet; import org.apache.olingo.client.api.domain.ClientEntitySet;
import org.apache.olingo.client.api.domain.ClientObjectFactory; import org.apache.olingo.client.api.domain.ClientObjectFactory;
import org.apache.olingo.client.api.domain.ClientValuable;
import org.apache.olingo.client.core.ODataClientFactory; import org.apache.olingo.client.core.ODataClientFactory;
import org.apache.olingo.commons.api.edm.FullQualifiedName; import org.apache.olingo.commons.api.edm.FullQualifiedName;
import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.format.ODataFormat;
@ -62,7 +61,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -71,15 +70,15 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, response.getBody().getEntities().size()); assertEquals(2, response.getBody().getEntities().size());
ClientEntity clientEntity = response.getBody().getEntities().get(0); ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = response.getBody().getEntities().get(1); clientEntity = response.getBody().getEntities().get(1);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
response = sendRequest(ES_ALL_PRIM, "PropertyBoolean eq true"); response = sendRequest(ES_ALL_PRIM, "PropertyBoolean eq true");
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
clientEntity = response.getBody().getEntities().get(0); clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -88,7 +87,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -98,7 +97,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -109,7 +108,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -121,7 +120,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -130,12 +129,12 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("2", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -145,8 +144,8 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -166,8 +165,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
ClientEntity clientEntity = response.getBody().getEntities().get(0); ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString());
} }
@Test @Test
@ -176,7 +174,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("2", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -185,18 +183,18 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
sendRequest(ES_TWO_KEY_NAV, "PropertyString eq '2' and PropertyInt16 eq 1"); sendRequest(ES_TWO_KEY_NAV, "PropertyString eq '2' and PropertyInt16 eq 1");
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals("2", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
result = sendRequest(ES_TWO_KEY_NAV, "PropertyString eq '2' or PropertyInt16 eq 1"); result = sendRequest(ES_TWO_KEY_NAV, "PropertyString eq '2' or PropertyInt16 eq 1");
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
clientEntity = result.getBody().getEntities().get(0); clientEntity = result.getBody().getEntities().get(0);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals("2", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -296,26 +294,17 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
.appendKeySegment(32766) .appendKeySegment(32766)
.build())); .build()));
final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment("ESAllPrim").build(); final URI uri = client.newURIBuilder(SERVICE_URI).appendEntitySetSegment(ES_ALL_PRIM).build();
ODataEntityCreateResponse<ClientEntity> createResponse = ODataEntityCreateResponse<ClientEntity> createResponse =
client.getCUDRequestFactory().getEntityCreateRequest(uri, entity).execute(); client.getCUDRequestFactory().getEntityCreateRequest(uri, entity).execute();
final URI receiveURI = ODataRetrieveResponse<ClientEntitySet> filterResponse = sendRequest(ES_ALL_PRIM, filterString,
client.newURIBuilder(SERVICE_URI) createResponse.getHeader(HttpHeader.SET_COOKIE).iterator().next());
.appendEntitySetSegment("ESAllPrim")
.filter(filterString)
.build();
ODataEntitySetRequest<ClientEntitySet> filterRequest =
client.getRetrieveRequestFactory().getEntitySetRequest(receiveURI);
filterRequest.addCustomHeader(HttpHeader.COOKIE, createResponse.getHeader(HttpHeader.SET_COOKIE).iterator().next());
ODataRetrieveResponse<ClientEntitySet> filterResponse = filterRequest.execute();
assertEquals(1, filterResponse.getBody().getEntities().size()); assertEquals(1, filterResponse.getBody().getEntities().size());
} }
@Test @Test
public void testNumericComparisionOperators() { public void numericComparisonOperators() {
ODataRetrieveResponse<ClientEntitySet> result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 ge 1"); ODataRetrieveResponse<ClientEntitySet> result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 ge 1");
assertEquals(4, result.getBody().getEntities().size()); assertEquals(4, result.getBody().getEntities().size());
@ -355,25 +344,22 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(3, result.getBody().getEntities().size()); assertEquals(3, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
assertEquals("11", ((ClientValuable) ((ClientValuable) clientEntity.getProperty("PropertyComp")).getComplexValue() assertEquals(11, clientEntity.getProperty("PropertyComp").getComplexValue().get("PropertyInt16")
.get("PropertyInt16")).getValue() .getPrimitiveValue().toValue());
.toString());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("2", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
assertEquals("11", ((ClientValuable) ((ClientValuable) clientEntity.getProperty("PropertyComp")).getComplexValue() assertEquals(11, clientEntity.getProperty("PropertyComp").getComplexValue().get("PropertyInt16")
.get("PropertyInt16")).getValue() .getPrimitiveValue().toValue());
.toString());
clientEntity = result.getBody().getEntities().get(2); clientEntity = result.getBody().getEntities().get(2);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
assertEquals("11", ((ClientValuable) ((ClientValuable) clientEntity.getProperty("PropertyComp")).getComplexValue() assertEquals(11, clientEntity.getProperty("PropertyComp").getComplexValue().get("PropertyInt16")
.get("PropertyInt16")).getValue() .getPrimitiveValue().toValue());
.toString());
} }
@Test @Test
@ -382,12 +368,12 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(2, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -396,12 +382,12 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(2, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -410,12 +396,12 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(2, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -444,7 +430,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -455,30 +441,27 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(4, result.getBody().getEntities().size()); assertEquals(4, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(1, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("2", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(2); clientEntity = result.getBody().getEntities().get(2);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(2, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(3); clientEntity = result.getBody().getEntities().get(3);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
public void testSubstringDouble() { public void testSubstringDouble() {
try { fail(ES_ALL_PRIM,
sendRequest(ES_ALL_PRIM, "substring(PropertyString, length('First')" "substring(PropertyString, length('First') add 1, 2.0 * 4) eq ('Resource')",
+ "add 1, 2.0 * 4) eq ('Resource')"); HttpStatusCode.BAD_REQUEST);
} catch (ODataClientErrorException e) {
assertEquals(400, e.getStatusLine().getStatusCode());
}
} }
@Test @Test
@ -487,7 +470,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -496,7 +479,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -505,13 +488,13 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(3, result.getBody().getEntities().size()); assertEquals(3, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(2); clientEntity = result.getBody().getEntities().get(2);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -520,7 +503,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -529,13 +512,13 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(3, result.getBody().getEntities().size()); assertEquals(3, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(2); clientEntity = result.getBody().getEntities().get(2);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -544,7 +527,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -553,10 +536,10 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -565,7 +548,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -574,7 +557,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -583,7 +566,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -592,7 +575,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
ClientEntity clientEntity = response.getBody().getEntities().get(0); ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -601,7 +584,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
ClientEntity clientEntity = response.getBody().getEntities().get(0); ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -611,10 +594,12 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, response.getBody().getEntities().size()); assertEquals(2, response.getBody().getEntities().size());
ClientEntity clientEntity = response.getBody().getEntities().get(0); ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("W/\"32767\"", clientEntity.getETag());
clientEntity = response.getBody().getEntities().get(1); clientEntity = response.getBody().getEntities().get(1);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("W/\"0\"", clientEntity.getETag());
} }
@Test @Test
@ -653,15 +638,15 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq floor(3.1)"); result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq floor(3.1)");
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
clientEntity = result.getBody().getEntities().get(0); clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -670,15 +655,15 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq ceiling(2.6)"); result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq ceiling(2.6)");
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
clientEntity = result.getBody().getEntities().get(0); clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -687,29 +672,29 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq round(2.4)"); result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq round(2.4)");
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
clientEntity = result.getBody().getEntities().get(0); clientEntity = result.getBody().getEntities().get(0);
assertEquals("2", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(2, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq round(2.6)"); result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq round(2.6)");
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
clientEntity = result.getBody().getEntities().get(0); clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq round(3.1)"); result = sendRequest(ES_TWO_KEY_NAV, "PropertyInt16 eq round(3.1)");
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
clientEntity = result.getBody().getEntities().get(0); clientEntity = result.getBody().getEntities().get(0);
assertEquals("3", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(3, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
assertEquals("1", ((ClientValuable) clientEntity.getProperty("PropertyString")).getValue().toString()); assertEquals("1", clientEntity.getProperty("PropertyString").getPrimitiveValue().toValue());
} }
@Test @Test
@ -718,10 +703,10 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(2, result.getBody().getEntities().size()); assertEquals(2, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
clientEntity = result.getBody().getEntities().get(1); clientEntity = result.getBody().getEntities().get(1);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -731,7 +716,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -740,7 +725,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -750,7 +735,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -760,7 +745,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -770,7 +755,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -780,7 +765,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("-32768", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(-32768, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -790,7 +775,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, result.getBody().getEntities().size()); assertEquals(1, result.getBody().getEntities().size());
ClientEntity clientEntity = result.getBody().getEntities().get(0); ClientEntity clientEntity = result.getBody().getEntities().get(0);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -808,7 +793,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -818,7 +803,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -835,7 +820,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -845,7 +830,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -855,7 +840,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -865,7 +850,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("32767", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(32767, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -875,7 +860,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test
@ -885,7 +870,7 @@ public class FilterSystemQueryITCase extends AbstractBaseTestITCase {
assertEquals(1, response.getBody().getEntities().size()); assertEquals(1, response.getBody().getEntities().size());
final ClientEntity clientEntity = response.getBody().getEntities().get(0); final ClientEntity clientEntity = response.getBody().getEntities().get(0);
assertEquals("0", ((ClientValuable) clientEntity.getProperty("PropertyInt16")).getValue().toString()); assertEquals(0, clientEntity.getProperty("PropertyInt16").getPrimitiveValue().toValue());
} }
@Test @Test

View File

@ -28,7 +28,6 @@ import org.apache.olingo.client.api.communication.ODataClientErrorException;
import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse; import org.apache.olingo.client.api.communication.response.ODataRetrieveResponse;
import org.apache.olingo.client.api.domain.ClientEntity; import org.apache.olingo.client.api.domain.ClientEntity;
import org.apache.olingo.client.api.domain.ClientEntitySet; 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.client.core.ODataClientFactory;
import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.format.ODataFormat;
import org.apache.olingo.commons.api.http.HttpStatusCode; import org.apache.olingo.commons.api.http.HttpStatusCode;
@ -47,7 +46,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_ALL_PRIM) .appendEntitySetSegment(ES_ALL_PRIM)
.addQueryOption(QueryOption.COUNT, "true") .count(true)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -63,7 +62,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.addQueryOption(QueryOption.COUNT, "true") .count(true)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -79,7 +78,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.addQueryOption(QueryOption.TOP, new Integer(5).toString()) .top(5)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -99,7 +98,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.addQueryOption(QueryOption.SKIP, new Integer(5).toString()) .skip(5)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -119,8 +118,8 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.addQueryOption(QueryOption.TOP, new Integer(20).toString()) .top(20)
.addQueryOption(QueryOption.SKIP, new Integer(503).toString()) .skip(503)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -135,7 +134,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.addQueryOption(QueryOption.SKIP, new Integer(10000).toString()) .skip(10000)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -152,9 +151,9 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.filter("PropertyInt16 le 105") // 1, 2, ... , 105 .filter("PropertyInt16 le 105") // 1, 2, ... , 105
.orderBy("PropertyInt16 desc") // 105, 104, ..., 2, 1 .orderBy("PropertyInt16 desc") // 105, 104, ..., 2, 1
.addQueryOption(QueryOption.COUNT, Boolean.TRUE.toString()) // 105 .count(true) // 105
.addQueryOption(QueryOption.SKIP, new Integer(3).toString()) // 102, 101, ..., 2, 1 .skip(3) // 102, 101, ..., 2, 1
.addQueryOption(QueryOption.TOP, new Integer(43).toString()) // 102, 101, ...., 59 .top(43) // 102, 101, ...., 59
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -228,7 +227,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_SERVER_SIDE_PAGING) .appendEntitySetSegment(ES_SERVER_SIDE_PAGING)
.addQueryOption(QueryOption.COUNT, Boolean.TRUE.toString()) .count(true)
.build(); .build();
ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory() ODataRetrieveResponse<ClientEntitySet> response = client.getRetrieveRequestFactory()
@ -264,7 +263,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_ALL_PRIM) .appendEntitySetSegment(ES_ALL_PRIM)
.addQueryOption(QueryOption.SKIP, new Integer(-5).toString()) .skip(-5)
.build(); .build();
try { try {
@ -282,7 +281,7 @@ public class SystemQueryOptionITCase extends AbstractBaseTestITCase {
ODataClient client = getClient(); ODataClient client = getClient();
URI uri = client.newURIBuilder(SERVICE_URI) URI uri = client.newURIBuilder(SERVICE_URI)
.appendEntitySetSegment(ES_ALL_PRIM) .appendEntitySetSegment(ES_ALL_PRIM)
.addQueryOption(QueryOption.TOP, new Integer(-5).toString()) .top(-5)
.build(); .build();
try { try {
client.getRetrieveRequestFactory() client.getRetrieveRequestFactory()

View File

@ -36,8 +36,8 @@ public abstract class AbstractODataObject extends Annotatable {
return baseURI; return baseURI;
} }
public void setBaseURI(final String baseURI) { public void setBaseURI(final URI baseURI) {
this.baseURI = baseURI == null ? null : URI.create(baseURI); this.baseURI = baseURI;
} }
/** /**

View File

@ -431,7 +431,7 @@ public class AtomDeserializer extends AbstractAtomDealer implements ODataDeseria
final Delta delta = new Delta(); final Delta delta = new Delta();
final Attribute xmlBase = start.getAttributeByName(Constants.QNAME_ATTR_XML_BASE); final Attribute xmlBase = start.getAttributeByName(Constants.QNAME_ATTR_XML_BASE);
if (xmlBase != null) { if (xmlBase != null) {
delta.setBaseURI(xmlBase.getValue()); delta.setBaseURI(URI.create(xmlBase.getValue()));
} }
boolean foundEndFeed = false; boolean foundEndFeed = false;
@ -579,7 +579,7 @@ public class AtomDeserializer extends AbstractAtomDealer implements ODataDeseria
entity = new Entity(); entity = new Entity();
final Attribute xmlBase = start.getAttributeByName(Constants.QNAME_ATTR_XML_BASE); final Attribute xmlBase = start.getAttributeByName(Constants.QNAME_ATTR_XML_BASE);
if (xmlBase != null) { if (xmlBase != null) {
entity.setBaseURI(xmlBase.getValue()); entity.setBaseURI(URI.create(xmlBase.getValue()));
} }
final Attribute etag = start.getAttributeByName(etagQName); final Attribute etag = start.getAttributeByName(etagQName);
@ -737,7 +737,7 @@ public class AtomDeserializer extends AbstractAtomDealer implements ODataDeseria
final EntityCollection entitySet = new EntityCollection(); final EntityCollection entitySet = new EntityCollection();
final Attribute xmlBase = start.getAttributeByName(Constants.QNAME_ATTR_XML_BASE); final Attribute xmlBase = start.getAttributeByName(Constants.QNAME_ATTR_XML_BASE);
if (xmlBase != null) { if (xmlBase != null) {
entitySet.setBaseURI(xmlBase.getValue()); entitySet.setBaseURI(URI.create(xmlBase.getValue()));
} }
boolean foundEndFeed = false; boolean foundEndFeed = false;

View File

@ -550,7 +550,7 @@ public class AtomSerializer extends AbstractAtomDealer implements ODataSerialize
if (container.getContextURL() != null) { if (container.getContextURL() != null) {
final ContextURL contextURL = ContextURLParser.parse(container.getContextURL()); final ContextURL contextURL = ContextURLParser.parse(container.getContextURL());
String base = contextURL.getServiceRoot().toASCIIString(); final URI base = contextURL.getServiceRoot();
if (container.getPayload() instanceof EntityCollection) { if (container.getPayload() instanceof EntityCollection) {
((EntityCollection) container.getPayload()).setBaseURI(base); ((EntityCollection) container.getPayload()).setBaseURI(base);
} }

View File

@ -52,7 +52,7 @@ public class JsonDeltaDeserializer extends JsonDeserializer {
final URI contextURL = tree.hasNonNull(Constants.JSON_CONTEXT) ? final URI contextURL = tree.hasNonNull(Constants.JSON_CONTEXT) ?
URI.create(tree.get(Constants.JSON_CONTEXT).textValue()) : null; URI.create(tree.get(Constants.JSON_CONTEXT).textValue()) : null;
if (contextURL != null) { if (contextURL != null) {
delta.setBaseURI(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA)); delta.setBaseURI(URI.create(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA)));
} }
if (tree.hasNonNull(Constants.JSON_COUNT)) { if (tree.hasNonNull(Constants.JSON_COUNT)) {

View File

@ -76,7 +76,7 @@ public class JsonEntityDeserializer extends JsonDeserializer {
contextURL = null; contextURL = null;
} }
if (contextURL != null) { if (contextURL != null) {
entity.setBaseURI(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA)); entity.setBaseURI(URI.create(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA)));
} }
final String metadataETag; final String metadataETag;

View File

@ -66,7 +66,7 @@ public class JsonEntitySetDeserializer extends JsonDeserializer {
contextURL = null; contextURL = null;
} }
if (contextURL != null) { if (contextURL != null) {
entitySet.setBaseURI(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA)); entitySet.setBaseURI(URI.create(StringUtils.substringBefore(contextURL.toASCIIString(), Constants.METADATA)));
} }
final String metadataETag; final String metadataETag;

View File

@ -435,7 +435,7 @@ public class TechnicalEntityProcessor extends TechnicalProcessor
final CountOption countOption = uriInfo.getCountOption(); final CountOption countOption = uriInfo.getCountOption();
// Serialize // Serialize
final SerializerResult serializerResult = (isReference) ? final SerializerResult serializerResult = isReference ?
serializeReferenceCollection(entitySetSerialization, edmEntitySet, format) : serializeReferenceCollection(entitySetSerialization, edmEntitySet, format) :
serializeEntityCollection(entitySetSerialization, edmEntitySet, edmEntityType, format, serializeEntityCollection(entitySetSerialization, edmEntitySet, edmEntityType, format,
expand, select, countOption); expand, select, countOption);

View File

@ -41,6 +41,7 @@ import org.apache.olingo.server.api.uri.queryoption.FilterOption;
import org.apache.olingo.server.api.uri.queryoption.OrderByOption; import org.apache.olingo.server.api.uri.queryoption.OrderByOption;
import org.apache.olingo.server.api.uri.queryoption.SkipOption; import org.apache.olingo.server.api.uri.queryoption.SkipOption;
import org.apache.olingo.server.api.uri.queryoption.TopOption; import org.apache.olingo.server.api.uri.queryoption.TopOption;
import org.apache.olingo.server.tecsvc.processor.queryoptions.options.CountHandler;
import org.apache.olingo.server.tecsvc.processor.queryoptions.options.FilterHandler; import org.apache.olingo.server.tecsvc.processor.queryoptions.options.FilterHandler;
import org.apache.olingo.server.tecsvc.processor.queryoptions.options.OrderByHandler; import org.apache.olingo.server.tecsvc.processor.queryoptions.options.OrderByHandler;
import org.apache.olingo.server.tecsvc.processor.queryoptions.options.SkipHandler; import org.apache.olingo.server.tecsvc.processor.queryoptions.options.SkipHandler;
@ -105,7 +106,7 @@ public class ExpandSystemQueryOptionHandler {
FilterHandler.applyFilterSystemQuery(filterOption, entitySet, edmBindingTarget); FilterHandler.applyFilterSystemQuery(filterOption, entitySet, edmBindingTarget);
OrderByHandler.applyOrderByOption(orderByOption, entitySet, edmBindingTarget); OrderByHandler.applyOrderByOption(orderByOption, entitySet, edmBindingTarget);
// TODO Add CountHandler CountHandler.applyCountSystemQueryOption(countOption, entitySet);
SkipHandler.applySkipSystemQueryHandler(skipOption, entitySet); SkipHandler.applySkipSystemQueryHandler(skipOption, entitySet);
TopHandler.applyTopSystemQueryOption(topOption, entitySet); TopHandler.applyTopSystemQueryOption(topOption, entitySet);
@ -168,25 +169,29 @@ public class ExpandSystemQueryOptionHandler {
newEntitySet.setCount(entitySet.getCount()); newEntitySet.setCount(entitySet.getCount());
newEntitySet.setDeltaLink(entitySet.getDeltaLink()); newEntitySet.setDeltaLink(entitySet.getDeltaLink());
newEntitySet.setNext(entitySet.getNext()); newEntitySet.setNext(entitySet.getNext());
newEntitySet.setId(entitySet.getId());
newEntitySet.setBaseURI(entitySet.getBaseURI());
return newEntitySet; return newEntitySet;
} }
private Entity newEntity(final Entity entity) { private Entity newEntity(final Entity entity) {
final Entity newEntity = new Entity(); Entity newEntity = new Entity();
newEntity.getProperties().addAll(entity.getProperties()); newEntity.getProperties().addAll(entity.getProperties());
newEntity.getAnnotations().addAll(entity.getAnnotations()); newEntity.getAnnotations().addAll(entity.getAnnotations());
newEntity.getAssociationLinks().addAll(entity.getAssociationLinks());
newEntity.setEditLink(entity.getEditLink());
newEntity.setId(entity.getId()); newEntity.setId(entity.getId());
newEntity.setBaseURI(entity.getBaseURI());
newEntity.setType(entity.getType());
newEntity.setETag(entity.getETag());
newEntity.setMediaContentSource(entity.getMediaContentSource()); newEntity.setMediaContentSource(entity.getMediaContentSource());
newEntity.setMediaContentType(entity.getMediaContentType()); newEntity.setMediaContentType(entity.getMediaContentType());
newEntity.setMediaETag(entity.getMediaETag()); newEntity.setMediaETag(entity.getMediaETag());
newEntity.getOperations().addAll(entity.getOperations());
newEntity.setSelfLink(entity.getSelfLink()); newEntity.setSelfLink(entity.getSelfLink());
newEntity.setType(entity.getType()); newEntity.setEditLink(entity.getEditLink());
newEntity.getAssociationLinks().addAll(entity.getAssociationLinks());
newEntity.getNavigationBindings().addAll(entity.getNavigationBindings()); newEntity.getNavigationBindings().addAll(entity.getNavigationBindings());
newEntity.getOperations().addAll(entity.getOperations());
return newEntity; return newEntity;
} }

View File

@ -37,7 +37,6 @@ import org.apache.olingo.commons.api.edm.EdmEntityType;
import org.apache.olingo.commons.api.edm.EdmPrimitiveType; import org.apache.olingo.commons.api.edm.EdmPrimitiveType;
import org.apache.olingo.commons.api.edm.EdmProperty; import org.apache.olingo.commons.api.edm.EdmProperty;
import org.apache.olingo.commons.api.format.ODataFormat; import org.apache.olingo.commons.api.format.ODataFormat;
import org.apache.olingo.server.api.OData;
import org.apache.olingo.server.api.ServiceMetadata; import org.apache.olingo.server.api.ServiceMetadata;
import org.apache.olingo.server.api.edmx.EdmxReference; import org.apache.olingo.server.api.edmx.EdmxReference;
import org.apache.olingo.server.api.serializer.ComplexSerializerOptions; import org.apache.olingo.server.api.serializer.ComplexSerializerOptions;
@ -53,6 +52,7 @@ import org.apache.olingo.server.api.uri.queryoption.ExpandItem;
import org.apache.olingo.server.api.uri.queryoption.ExpandOption; import org.apache.olingo.server.api.uri.queryoption.ExpandOption;
import org.apache.olingo.server.api.uri.queryoption.SelectItem; import org.apache.olingo.server.api.uri.queryoption.SelectItem;
import org.apache.olingo.server.api.uri.queryoption.SelectOption; import org.apache.olingo.server.api.uri.queryoption.SelectOption;
import org.apache.olingo.server.core.ServiceMetadataImpl;
import org.apache.olingo.server.core.serializer.ExpandSelectMock; import org.apache.olingo.server.core.serializer.ExpandSelectMock;
import org.apache.olingo.server.core.uri.UriHelperImpl; import org.apache.olingo.server.core.uri.UriHelperImpl;
import org.apache.olingo.server.tecsvc.MetadataETagSupport; import org.apache.olingo.server.tecsvc.MetadataETagSupport;
@ -64,7 +64,7 @@ import org.junit.Test;
import org.mockito.Mockito; import org.mockito.Mockito;
public class ODataJsonSerializerTest { public class ODataJsonSerializerTest {
private static final ServiceMetadata metadata = OData.newInstance().createServiceMetadata( private static final ServiceMetadata metadata = new ServiceMetadataImpl(
new EdmTechProvider(), Collections.<EdmxReference> emptyList(), new MetadataETagSupport("W/\"metadataETag\"")); new EdmTechProvider(), Collections.<EdmxReference> emptyList(), new MetadataETagSupport("W/\"metadataETag\""));
private static final EdmEntityContainer entityContainer = metadata.getEdm().getEntityContainer(); private static final EdmEntityContainer entityContainer = metadata.getEdm().getEntityContainer();
private final DataProvider data = new DataProvider(); private final DataProvider data = new DataProvider();
@ -157,8 +157,8 @@ public class ODataJsonSerializerTest {
} }
@Test @Test
public void entitySetAllPrim() throws Exception { public void entitySetCompAllPrim() throws Exception {
final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESAllPrim"); final EdmEntitySet edmEntitySet = entityContainer.getEntitySet("ESCompAllPrim");
EntityCollection entitySet = data.readAll(edmEntitySet); EntityCollection entitySet = data.readAll(edmEntitySet);
entitySet.setCount(entitySet.getEntities().size()); entitySet.setCount(entitySet.getEntities().size());
entitySet.setNext(URI.create("/next")); entitySet.setNext(URI.create("/next"));
@ -172,10 +172,11 @@ public class ODataJsonSerializerTest {
final String resultString = IOUtils.toString(result); final String resultString = IOUtils.toString(result);
Assert.assertThat(resultString, CoreMatchers.startsWith("{" Assert.assertThat(resultString, CoreMatchers.startsWith("{"
+ "\"@odata.context\":\"$metadata#ESAllPrim\"," + "\"@odata.context\":\"$metadata#ESCompAllPrim\","
+ "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\"," + "\"@odata.metadataEtag\":\"W/\\\"metadataETag\\\"\","
+ "\"@odata.count\":3,\"value\":[")); + "\"@odata.count\":3,\"value\":["
Assert.assertThat(resultString, CoreMatchers.endsWith("]," + "{\"@odata.etag\":\"W/\\\"32767\\\"\","));
Assert.assertThat(resultString, CoreMatchers.endsWith("\"}}],"
+ "\"@odata.nextLink\":\"/next\"}")); + "\"@odata.nextLink\":\"/next\"}"));
int count = 0; int count = 0;
@ -183,7 +184,7 @@ public class ODataJsonSerializerTest {
while ((index = resultString.indexOf("PropertyInt16\":", ++index)) > 0) { while ((index = resultString.indexOf("PropertyInt16\":", ++index)) > 0) {
count++; count++;
} }
Assert.assertEquals(3, count); Assert.assertEquals(6, count);
} }
@Test @Test