[OLINGO-206] validation of 1st level uri completed
This commit is contained in:
parent
99d5781940
commit
d9532784fb
|
@ -115,11 +115,4 @@ public interface UriInfoResource {
|
|||
*/
|
||||
List<UriResource> getUriResourceParts();
|
||||
|
||||
/**
|
||||
* Give the last part of a resource path.
|
||||
*
|
||||
* @return An uri resource object.
|
||||
*/
|
||||
UriResource getUriResourceLastPart();
|
||||
|
||||
}
|
||||
|
|
|
@ -287,8 +287,4 @@ public class UriInfoImpl implements UriInfo {
|
|||
return Collections.unmodifiableCollection(systemQueryOptions.values());
|
||||
}
|
||||
|
||||
@Override
|
||||
public UriResource getUriResourceLastPart() {
|
||||
return lastResourcePart;
|
||||
}
|
||||
}
|
|
@ -18,12 +18,11 @@
|
|||
*/
|
||||
package org.apache.olingo.server.core.uri.validator;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.olingo.commons.api.ODataRuntimeException;
|
||||
import org.apache.olingo.commons.api.edm.Edm;
|
||||
import org.apache.olingo.server.api.uri.UriInfo;
|
||||
import org.apache.olingo.server.api.uri.UriResource;
|
||||
import org.apache.olingo.server.api.uri.UriResourcePartTyped;
|
||||
import org.apache.olingo.server.api.uri.queryoption.SystemQueryOption;
|
||||
import org.apache.olingo.server.api.uri.queryoption.SystemQueryOptionKind;
|
||||
|
||||
|
@ -42,9 +41,7 @@ public class SystemQueryValidator {
|
|||
/* resource 5 */ { false, true , false, false, false, false, false, false, false, false, false, false },
|
||||
/* service 6 */ { false, true , false, false, false, false, false, false, false, false, false, false },
|
||||
/* entitySet 7 */ { true , true , true , false, true , true , true , true , true , true , true , true },
|
||||
|
||||
/* entitySetCount 8 */ { false, false, false, false, false, false, false, false, false, false, false, false },
|
||||
|
||||
/* entity 9 */ { false, true , true , false, false, false, false, true , false, false, true , false },
|
||||
/* mediaStream 10 */ { false, true , false, false, false, false, false, false, false, false, false, false },
|
||||
/* references 11 */ { true , true , false, false, false, true , true , false, true , true , false, true },
|
||||
|
@ -55,7 +52,7 @@ public class SystemQueryValidator {
|
|||
/* propertyPrimitive 16 */ { false, true , false, false, false, false, false, false, false, false, false, false },
|
||||
/* propertyPrimitiveCollection 17 */ { true , true , false, false, false, true , false, false, true , true , false, true },
|
||||
/* propertyPrimitiveCollectionCount 18 */ { false, false, false, false, false, false, false, false, false, false, false, false },
|
||||
/* propertyPrimitiveValue 19 */ { false, true , false, false, false, false, false, false, false, false, false, false },
|
||||
/* propertyPrimitiveValue 19 */ { false, true , false, false, false, false, false, false, false, false, false, false },
|
||||
};
|
||||
//CHECKSTYLE:ON
|
||||
//@formatter:on
|
||||
|
@ -148,25 +145,55 @@ public class SystemQueryValidator {
|
|||
private int rowIndexForResourceKind(UriInfo uriInfo, Edm edm) throws UriValidationException {
|
||||
int idx = 5;
|
||||
|
||||
UriResource lastPathSegemnt = uriInfo.getUriResourceLastPart();
|
||||
int lastPathSegmentIndex = uriInfo.getUriResourceParts().size() - 1;
|
||||
UriResource lastPathSegemnt = uriInfo.getUriResourceParts().get(lastPathSegmentIndex);
|
||||
|
||||
switch (lastPathSegemnt.getKind()) {
|
||||
case count:
|
||||
List<UriResource> parts = uriInfo.getUriResourceParts();
|
||||
UriResource secondLastPart = parts.get(parts.size() - 2);
|
||||
switch (secondLastPart.getKind()) {
|
||||
case count: {
|
||||
int secondLastPathSegmentIndex = uriInfo.getUriResourceParts().size() - 2;
|
||||
UriResource secondLastPathSegment = uriInfo.getUriResourceParts().get(secondLastPathSegmentIndex);
|
||||
switch (secondLastPathSegment.getKind()) {
|
||||
case entitySet:
|
||||
idx = 8;
|
||||
break;
|
||||
default : throw new UriValidationException("Illegal path part kind: " + lastPathSegemnt.getKind());
|
||||
case complexProperty:
|
||||
idx = 15;
|
||||
break;
|
||||
case primitiveProperty:
|
||||
idx = 18;
|
||||
break;
|
||||
default:
|
||||
throw new UriValidationException("Illegal path part kind: " + lastPathSegemnt.getKind());
|
||||
}
|
||||
}
|
||||
break;
|
||||
case action:
|
||||
break;
|
||||
case complexProperty:
|
||||
if (lastPathSegemnt instanceof UriResourcePartTyped) {
|
||||
if (((UriResourcePartTyped) lastPathSegemnt).isCollection()) {
|
||||
idx = 14;
|
||||
}
|
||||
else {
|
||||
idx = 13;
|
||||
}
|
||||
} else {
|
||||
throw new UriValidationException("lastPathSegment not a class of UriResourcePartTyped: "
|
||||
+ lastPathSegemnt.getClass());
|
||||
}
|
||||
break;
|
||||
case entitySet:
|
||||
idx = 7;
|
||||
if (lastPathSegemnt instanceof UriResourcePartTyped) {
|
||||
if (((UriResourcePartTyped) lastPathSegemnt).isCollection()) {
|
||||
idx = 7;
|
||||
}
|
||||
else {
|
||||
idx = 9;
|
||||
}
|
||||
} else {
|
||||
throw new UriValidationException("lastPathSegment not a class of UriResourcePartTyped: "
|
||||
+ lastPathSegemnt.getClass());
|
||||
}
|
||||
break;
|
||||
case function:
|
||||
break;
|
||||
|
@ -181,14 +208,55 @@ public class SystemQueryValidator {
|
|||
case navigationProperty:
|
||||
break;
|
||||
case primitiveProperty:
|
||||
if (lastPathSegemnt instanceof UriResourcePartTyped) {
|
||||
if (((UriResourcePartTyped) lastPathSegemnt).isCollection()) {
|
||||
idx = 17;
|
||||
}
|
||||
else {
|
||||
idx = 16;
|
||||
}
|
||||
} else {
|
||||
throw new UriValidationException("lastPathSegment not a class of UriResourcePartTyped: "
|
||||
+ lastPathSegemnt.getClass());
|
||||
}
|
||||
|
||||
break;
|
||||
case ref:
|
||||
case ref: {
|
||||
int secondLastPathSegmentIndex = uriInfo.getUriResourceParts().size() - 2;
|
||||
UriResource secondLastPathSegment = uriInfo.getUriResourceParts().get(secondLastPathSegmentIndex);
|
||||
|
||||
if (secondLastPathSegment instanceof UriResourcePartTyped) {
|
||||
if (((UriResourcePartTyped) secondLastPathSegment).isCollection()) {
|
||||
idx = 11;
|
||||
}
|
||||
else {
|
||||
idx = 12;
|
||||
}
|
||||
} else {
|
||||
throw new UriValidationException("secondLastPathSegment not a class of UriResourcePartTyped: "
|
||||
+ lastPathSegemnt.getClass());
|
||||
}
|
||||
}
|
||||
break;
|
||||
case root:
|
||||
break;
|
||||
case singleton:
|
||||
break;
|
||||
case value:
|
||||
case value: {
|
||||
int secondLastPathSegmentIndex = uriInfo.getUriResourceParts().size() - 2;
|
||||
UriResource secondLastPathSegment = uriInfo.getUriResourceParts().get(secondLastPathSegmentIndex);
|
||||
switch (secondLastPathSegment.getKind()) {
|
||||
case primitiveProperty:
|
||||
idx = 19;
|
||||
break;
|
||||
case entitySet:
|
||||
idx = 10;
|
||||
break;
|
||||
default:
|
||||
throw new UriValidationException("Unexpected kind in path segment before $value: "
|
||||
+ secondLastPathSegment.getKind());
|
||||
}
|
||||
}
|
||||
break;
|
||||
default:
|
||||
throw new ODataRuntimeException("Unsupported uriResource kind: " + lastPathSegemnt.getKind());
|
||||
|
|
|
@ -29,6 +29,7 @@ import org.apache.olingo.server.core.edm.provider.EdmProviderImpl;
|
|||
import org.apache.olingo.server.core.testutil.EdmTechProvider;
|
||||
import org.apache.olingo.server.core.uri.parser.Parser;
|
||||
import org.apache.olingo.server.core.uri.parser.UriParserException;
|
||||
import org.junit.Before;
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
|
||||
|
@ -45,7 +46,7 @@ public class UriEdmValidatorTest {
|
|||
private static final String URI_ENTITY = "/ESAllPrim(1)";
|
||||
private static final String URI_MEDIA_STREAM = "/ESMedia(1)/$value";
|
||||
private static final String URI_REFERENCES = "/ESAllPrim/$ref";
|
||||
private static final String URI_REFERENECE = "/ESAllPrim(1)/$ref";
|
||||
private static final String URI_REFERENCE = "/ESAllPrim(1)/$ref";
|
||||
private static final String URI_PROPERTY_COMPLEX = "/ESCompComp(1)/PropertyComplex";
|
||||
private static final String URI_PROPERTY_COMPLEX_COLLECTION =
|
||||
"/ESCompCollComp(1)/PropertyComplex/CollPropertyComplex";
|
||||
|
@ -62,7 +63,7 @@ public class UriEdmValidatorTest {
|
|||
private static final String QO_EXPAND = "$expand=*";
|
||||
private static final String QO_ID = "$id=Products(0)";
|
||||
private static final String QO_COUNT = "$count";
|
||||
// private static final String QO_ORDERBY = "$orderby=bla asc";
|
||||
// private static final String QO_ORDERBY = "$orderby=true";
|
||||
// private static final String QO_SEARCH = "$search='bla'";
|
||||
private static final String QO_SELECT = "$select=*";
|
||||
private static final String QO_SKIP = "$skip=3";
|
||||
|
@ -95,6 +96,31 @@ public class UriEdmValidatorTest {
|
|||
{ URI_ENTITY_SET, QO_SKIP }, { URI_ENTITY_SET, QO_SKIPTOKEN }, { URI_ENTITY_SET, QO_LEVELS },
|
||||
{ URI_ENTITY_SET, QO_TOP },
|
||||
|
||||
{ URI_ENTITY, QO_FORMAT }, { URI_ENTITY, QO_EXPAND }, { URI_ENTITY, QO_SELECT }, { URI_ENTITY, QO_LEVELS },
|
||||
|
||||
{ URI_MEDIA_STREAM, QO_FORMAT },
|
||||
|
||||
{ URI_REFERENCES, QO_FILTER }, { URI_REFERENCES, QO_FORMAT }, /* { URI_REFERENCES, QO_ORDERBY }, */
|
||||
/* { URI_REFERENCES, QO_SEARCH }, */{ URI_REFERENCES, QO_SKIP }, { URI_REFERENCES, QO_SKIPTOKEN },
|
||||
{ URI_REFERENCES, QO_TOP },
|
||||
|
||||
{ URI_REFERENCE, QO_FORMAT },
|
||||
|
||||
{ URI_PROPERTY_COMPLEX, QO_FORMAT }, { URI_PROPERTY_COMPLEX, QO_SELECT }, { URI_PROPERTY_COMPLEX, QO_EXPAND },
|
||||
{ URI_PROPERTY_COMPLEX, QO_LEVELS },
|
||||
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION, QO_FILTER }, { URI_PROPERTY_COMPLEX_COLLECTION, QO_FORMAT },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION, QO_EXPAND }, { URI_PROPERTY_COMPLEX_COLLECTION, QO_COUNT },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION, QO_SKIP }, { URI_PROPERTY_COMPLEX_COLLECTION, QO_SKIPTOKEN },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION, QO_LEVELS }, { URI_PROPERTY_COMPLEX_COLLECTION, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE, QO_FORMAT },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION, QO_FILTER }, { URI_PROPERTY_PRIMITIVE_COLLECTION, QO_FORMAT },
|
||||
/* { URI_PROPERTY_PRIMITIVE_COLLECTION, QO_ORDERBY }, */{ URI_PROPERTY_PRIMITIVE_COLLECTION, QO_SKIP },
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION, QO_SKIPTOKEN }, { URI_PROPERTY_PRIMITIVE_COLLECTION, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE_VALUE, QO_FORMAT },
|
||||
};
|
||||
|
||||
private String[][] urisWithNonValidSystemQueryOptions = {
|
||||
|
@ -127,11 +153,75 @@ public class UriEdmValidatorTest {
|
|||
/* { URI_ENTITY_SET_COUNT, QO_ORDERBY }, *//* { URI_ENTITY_SET_COUNT, QO_SEARCH }, */
|
||||
{ URI_ENTITY_SET_COUNT, QO_SELECT }, { URI_ENTITY_SET_COUNT, QO_SKIP }, { URI_ENTITY_SET_COUNT, QO_SKIPTOKEN },
|
||||
{ URI_ENTITY_SET_COUNT, QO_LEVELS }, { URI_ENTITY_SET_COUNT, QO_TOP },
|
||||
|
||||
{ URI_ENTITY, QO_FILTER }, { URI_ENTITY, QO_ID }, { URI_ENTITY, QO_COUNT }, /* { URI_ENTITY, QO_ORDERBY }, */
|
||||
/* { URI_ENTITY, QO_SEARCH }, */{ URI_ENTITY, QO_SKIP }, { URI_ENTITY, QO_SKIPTOKEN }, { URI_ENTITY, QO_TOP },
|
||||
|
||||
{ URI_MEDIA_STREAM, QO_FILTER }, { URI_MEDIA_STREAM, QO_ID, }, { URI_MEDIA_STREAM, QO_EXPAND },
|
||||
{ URI_MEDIA_STREAM, QO_COUNT }, /* { URI_MEDIA_STREAM, QO_ORDERBY }, *//* { URI_MEDIA_STREAM, QO_SEARCH }, */
|
||||
{ URI_MEDIA_STREAM, QO_SELECT }, { URI_MEDIA_STREAM, QO_SKIP }, { URI_MEDIA_STREAM, QO_SKIPTOKEN },
|
||||
{ URI_MEDIA_STREAM, QO_LEVELS }, { URI_MEDIA_STREAM, QO_TOP },
|
||||
|
||||
{ URI_REFERENCES, QO_ID, }, { URI_REFERENCES, QO_EXPAND }, { URI_REFERENCES, QO_COUNT },
|
||||
{ URI_REFERENCES, QO_SELECT }, { URI_REFERENCES, QO_LEVELS },
|
||||
|
||||
{ URI_REFERENCE, QO_FILTER }, { URI_REFERENCE, QO_ID, }, { URI_REFERENCE, QO_EXPAND },
|
||||
{ URI_REFERENCE, QO_COUNT }, /* { URI_REFERENCE, QO_ORDERBY }, *//* { URI_REFERENCE, QO_SEARCH }, */
|
||||
{ URI_REFERENCE, QO_SELECT }, { URI_REFERENCE, QO_SKIP }, { URI_REFERENCE, QO_SKIPTOKEN },
|
||||
{ URI_REFERENCE, QO_LEVELS }, { URI_REFERENCE, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_COMPLEX, QO_FILTER }, { URI_PROPERTY_COMPLEX, QO_ID, }, { URI_PROPERTY_COMPLEX, QO_COUNT },
|
||||
/* { URI_PROPERTY_COMPLEX, QO_ORDERBY }, *//* { URI_PROPERTY_COMPLEX, QO_SEARCH }, */
|
||||
{ URI_PROPERTY_COMPLEX, QO_SKIP }, { URI_PROPERTY_COMPLEX, QO_SKIPTOKEN }, { URI_PROPERTY_COMPLEX, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION, QO_ID, }, /* { URI_PROPERTY_COMPLEX_COLLECTION, QO_ORDERBY }, */
|
||||
/* { URI_PROPERTY_COMPLEX_COLLECTION, QO_SEARCH }, */{ URI_PROPERTY_COMPLEX_COLLECTION, QO_SELECT },
|
||||
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_FILTER }, { URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_FORMAT },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_ID, }, { URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_EXPAND },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_COUNT }, /* { URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_ORDERBY }, */
|
||||
/* { URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_SEARCH }, */{ URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_SELECT },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_SKIP }, { URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_SKIPTOKEN },
|
||||
{ URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_LEVELS }, { URI_PROPERTY_COMPLEX_COLLECTION_COUNT, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE, QO_FILTER }, { URI_PROPERTY_PRIMITIVE, QO_ID, }, { URI_PROPERTY_PRIMITIVE, QO_EXPAND },
|
||||
{ URI_PROPERTY_PRIMITIVE, QO_COUNT }, /* { URI_PROPERTY_PRIMITIVE, QO_ORDERBY }, */
|
||||
/* { URI_PROPERTY_PRIMITIVE, QO_SEARCH }, */{ URI_PROPERTY_PRIMITIVE, QO_SELECT },
|
||||
{ URI_PROPERTY_PRIMITIVE, QO_SKIP }, { URI_PROPERTY_PRIMITIVE, QO_SKIPTOKEN },
|
||||
{ URI_PROPERTY_PRIMITIVE, QO_LEVELS }, { URI_PROPERTY_PRIMITIVE, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION, QO_ID, }, { URI_PROPERTY_PRIMITIVE_COLLECTION, QO_EXPAND },
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION, QO_COUNT }, /* { URI_PROPERTY_PRIMITIVE_COLLECTION, QO_SEARCH }, */
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION, QO_SELECT }, { URI_PROPERTY_PRIMITIVE_COLLECTION, QO_LEVELS },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_FILTER }, { URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_FORMAT },
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_ID, }, { URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_EXPAND },
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_COUNT },
|
||||
/* { URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_ORDERBY }, */
|
||||
/* { URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_SEARCH }, */
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_SELECT }, { URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_SKIP },
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_SKIPTOKEN },
|
||||
{ URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_LEVELS }, { URI_PROPERTY_PRIMITIVE_COLLECTION_COUNT, QO_TOP },
|
||||
|
||||
{ URI_PROPERTY_PRIMITIVE_VALUE, QO_FILTER }, { URI_PROPERTY_PRIMITIVE_VALUE, QO_ID, },
|
||||
{ URI_PROPERTY_PRIMITIVE_VALUE, QO_EXPAND }, { URI_PROPERTY_PRIMITIVE_VALUE, QO_COUNT },
|
||||
/* { URI_PROPERTY_PRIMITIVE_VALUE, QO_ORDERBY }, *//* { URI_PROPERTY_PRIMITIVE_VALUE, QO_SEARCH }, */
|
||||
{ URI_PROPERTY_PRIMITIVE_VALUE, QO_SELECT }, { URI_PROPERTY_PRIMITIVE_VALUE, QO_SKIP },
|
||||
{ URI_PROPERTY_PRIMITIVE_VALUE, QO_SKIPTOKEN }, { URI_PROPERTY_PRIMITIVE_VALUE, QO_LEVELS },
|
||||
{ URI_PROPERTY_PRIMITIVE_VALUE, QO_TOP },
|
||||
|
||||
};
|
||||
private Parser parser;
|
||||
|
||||
@Before
|
||||
public void before() {
|
||||
parser = new Parser();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore
|
||||
public void bla() throws Exception {
|
||||
String[][] m = { { URI_ENTITY_SET_COUNT, QO_FILTER } };
|
||||
String[][] m = { { URI_PROPERTY_PRIMITIVE_VALUE, QO_SELECT } };
|
||||
String[] uris = constructUri(m);
|
||||
System.out.println(uris[0]);
|
||||
|
||||
|
@ -165,91 +255,6 @@ public class UriEdmValidatorTest {
|
|||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore
|
||||
public void systemQueryOptionValid() throws Exception {
|
||||
String[] uris =
|
||||
{
|
||||
/* $filter */
|
||||
"/$all?$format=bla",
|
||||
// "/$batch?$format=bla",
|
||||
"/$crossjoin(ESAllPrim)?$format=bla",
|
||||
"/$entity?$id=Products(0)?$format=bla",
|
||||
"/$metadata?$format=bla",
|
||||
"?$format=bla",
|
||||
"/ESAllPrim?$format=bla",
|
||||
"/ESAllPrim/$count?$format=bla",
|
||||
"/ESAllPrim(1)?$format=bla",
|
||||
"/ESMedia(1)/$value?$format=bla",
|
||||
"/ESAllPrim/$ref?$format=bla",
|
||||
"/ESAllPrim(1)/$ref?$format=bla",
|
||||
"/ESCompComp(1)/PropertyComplex?$format=bla",
|
||||
"/ESCompCollComp(1)/PropertyComplex/CollPropertyComplex?$format=bla",
|
||||
"/ESCompCollComp(1)/PropertyComplex/CollPropertyComplex/$count?$format=bla",
|
||||
"/ESAllPrim(1)/PropertyString?$format=bla",
|
||||
"/ESCollAllPrim/CollPropertyString?$format=bla",
|
||||
"/ESCollAllPrim/CollPropertyString/$count?$format=bla",
|
||||
"/ESAllPrim(1)/PropertyString/$value?$format=bla"
|
||||
};
|
||||
|
||||
for (String uri : uris) {
|
||||
try {
|
||||
parseAndValidate(uri);
|
||||
} catch (Exception e) {
|
||||
throw new Exception("Faild for uri: " + uri, e);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
String[] tmpUri = {
|
||||
"$crossjoin(ESKeyNav, ESTwoKeyNav)/invalid ",
|
||||
"$crossjoin(invalidEntitySet) ",
|
||||
"$entity ",
|
||||
"$entity?$idfalse=ESKeyNav(1) ",
|
||||
"ESAllPrim(PropertyInt16='1') ",
|
||||
"ESCollAllPrim(null) ",
|
||||
"ESTwoPrim(1)/com.sap.odata.test1.ETBase(1) ",
|
||||
"ESTwoPrim/com.sap.odata.test1.ETBase(1)/com.sap.odata.test1.ETTwoBase(1) ",
|
||||
"ESTwoPrim/com.sap.odata.test1.ETBase(1)/com.sap.odata.test1.ETTwoBase(1) ",
|
||||
"FICRTCollCTTwoPrimParam(ParameterInt16='1',ParameterString='2') ",
|
||||
"FICRTESTwoKeyNavParam(ParameterInt16=@invalidAlias)?@validAlias=1 ",
|
||||
"FINRTESMixPrimCollCompTwoParam(ParameterInt16=1,ParameterString='2')/PropertyComplex ",
|
||||
"FINRTESMixPrimCollCompTwoParam(ParameterInt16=1,ParameterString='2')/$count ",
|
||||
// "ESKeyNav(1)?$expand=NavPropertyETKeyNavOne/$ref ",
|
||||
// "ESKeyNav(1)?$expand=NavPropertyETKeyNavOne/$count ",
|
||||
// "ESKeyNav?$top=-3 ",
|
||||
// "ESAllPrim?$count=foo ",
|
||||
// "ESAllPrim?$skip=-3 "
|
||||
};
|
||||
|
||||
@Test
|
||||
@Ignore("key predicate validation not implemented")
|
||||
public void keyPredicateValidTypes() throws Exception {
|
||||
String[] uris = {};
|
||||
|
||||
for (String uri : uris) {
|
||||
parseAndValidate(uri);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore("key predicate validation not implemented")
|
||||
public void keyPredicateInvalidTypes() throws UriParserException {
|
||||
String[] uris = {};
|
||||
|
||||
for (String uri : uris) {
|
||||
|
||||
try {
|
||||
parseAndValidate(uri);
|
||||
fail("Validation Exception not thrown: " + uri);
|
||||
} catch (UriValidationException e) {
|
||||
assertTrue(e instanceof UriValidationException);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private String[] constructUri(String[][] uriParameterMatrix) {
|
||||
ArrayList<String> uris = new ArrayList<String>();
|
||||
for (String[] uriParameter : uriParameterMatrix) {
|
||||
|
@ -268,26 +273,8 @@ public class UriEdmValidatorTest {
|
|||
return uris.toArray(new String[0]);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore
|
||||
public void systemQueryOptionInvalid() throws Exception {
|
||||
String[] uris =
|
||||
{
|
||||
};
|
||||
|
||||
for (String uri : uris) {
|
||||
|
||||
try {
|
||||
parseAndValidate(uri);
|
||||
fail("Validation Exception not thrown: " + uri);
|
||||
} catch (UriValidationException e) {
|
||||
assertTrue(e instanceof UriValidationException);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void parseAndValidate(String uri) throws UriParserException, UriValidationException {
|
||||
UriInfo uriInfo = new Parser().parseUri(uri.trim(), edm);
|
||||
UriInfo uriInfo = parser.parseUri(uri.trim(), edm);
|
||||
SystemQueryValidator validator = new SystemQueryValidator();
|
||||
|
||||
System.out.print("URI: " + uri);
|
||||
|
|
Loading…
Reference in New Issue