[
https://issues.apache.org/jira/browse/OLINGO-1403?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Vladislav Glinskiy updated OLINGO-1403:
---------------------------------------
Description:
Olingo V4 client does not parse expression annotations correctly.
Annotations on logical & comparison expressions and UrlRf expressions are not
parsed at all. The corresponding deserializers do not honor "Annotation"
elements.
Annotations on the following expressions get wrapped into another
CsdlAnnotation instance due to missing 'jp.nextToken()' calls in the
corresponding deserializers:
- ClientCsdlNull
- ClientCsdlApply
- ClientCsdlCast
- ClientCsdlIsOf
- ClientCsdlLabeledElement
Only annotations on
[Record|https://docs.oasis-open.org/odata/odata-csdl-xml/v4.01/csprd05/odata-csdl-xml-v4.01-csprd05.html#sec_Record]
expressions are parsed as expected. This is explained by 'jp.nextToken()'
[call in
ClientCsdlRecord|https://github.com/vladglinskiy/olingo-odata4/blob/master/lib/client-core/src/main/java/org/apache/olingo/client/core/edm/xml/annotation/ClientCsdlRecord.java#L49],
which is missing in other deserializers:
{code:java}
...
else if ("Annotation".equals(jp.getCurrentName())) {
jp.nextToken();
record.getAnnotations().add(jp.readValueAs(ClientCsdlAnnotation.class));
}
...
{code}
[I created a unit test to reproduce the
issue.|https://github.com/vladglinskiy/olingo-odata4/commit/2e2b355e9e07e4bb9dfb490cc0b50c66e090f483]
Steps to reproduce:
1. git clone https://github.com/vladglinskiy/olingo-odata4.git
2. git checkout csdl-deserializer-bugs
3. mvn clean test -pl lib/client-core/ -Dtest=AnnotatedExpressionTest
All tests except {{annotatedRecordExpressionTest}} will fail.
was:
Olingo V4 client does not parse expression annotations correctly.
Annotations on logical & comparison expressions and UrlRf expressions are not
parsed at all. The corresponding deserializers do not honor "Annotation"
elements.
Annotations on the following expressions get wrapped into another
CsdlAnnotation instance due to missing 'jp.nextToken()' calls in the
corresponding deserializers:
- ClientCsdlNull
- ClientCsdlApply
- ClientCsdlCast
- ClientCsdlIsOf
- ClientCsdlLabeledElement
Only annotations on Record expressions are parsed as expected. This is
explained by 'jp.nextToken()' [call in
ClientCsdlRecord|https://github.com/vladglinskiy/olingo-odata4/blob/master/lib/client-core/src/main/java/org/apache/olingo/client/core/edm/xml/annotation/ClientCsdlRecord.java#L49],
which is missing in other deserializers:
{code:java}
...
else if ("Annotation".equals(jp.getCurrentName())) {
jp.nextToken();
record.getAnnotations().add(jp.readValueAs(ClientCsdlAnnotation.class));
}
...
{code}
[I created a unit test to reproduce the
issue.|https://github.com/vladglinskiy/olingo-odata4/commit/2e2b355e9e07e4bb9dfb490cc0b50c66e090f483]
Steps to reproduce:
1. git clone https://github.com/vladglinskiy/olingo-odata4.git
2. git checkout csdl-deserializer-bugs
3. mvn clean test -pl lib/client-core/ -Dtest=AnnotatedExpressionTest
All tests except {{annotatedRecordExpressionTest}} will fail.
> Olingo V4 client does not parse expression annotations correctly
> ----------------------------------------------------------------
>
> Key: OLINGO-1403
> URL: https://issues.apache.org/jira/browse/OLINGO-1403
> Project: Olingo
> Issue Type: Bug
> Components: odata4-client
> Reporter: Vladislav Glinskiy
> Priority: Major
> Fix For: (Java) V4 4.7.0
>
>
> Olingo V4 client does not parse expression annotations correctly.
> Annotations on logical & comparison expressions and UrlRf expressions are not
> parsed at all. The corresponding deserializers do not honor "Annotation"
> elements.
> Annotations on the following expressions get wrapped into another
> CsdlAnnotation instance due to missing 'jp.nextToken()' calls in the
> corresponding deserializers:
> - ClientCsdlNull
> - ClientCsdlApply
> - ClientCsdlCast
> - ClientCsdlIsOf
> - ClientCsdlLabeledElement
> Only annotations on
> [Record|https://docs.oasis-open.org/odata/odata-csdl-xml/v4.01/csprd05/odata-csdl-xml-v4.01-csprd05.html#sec_Record]
> expressions are parsed as expected. This is explained by 'jp.nextToken()'
> [call in
> ClientCsdlRecord|https://github.com/vladglinskiy/olingo-odata4/blob/master/lib/client-core/src/main/java/org/apache/olingo/client/core/edm/xml/annotation/ClientCsdlRecord.java#L49],
> which is missing in other deserializers:
> {code:java}
> ...
> else if ("Annotation".equals(jp.getCurrentName())) {
> jp.nextToken();
> record.getAnnotations().add(jp.readValueAs(ClientCsdlAnnotation.class));
> }
> ...
> {code}
> [I created a unit test to reproduce the
> issue.|https://github.com/vladglinskiy/olingo-odata4/commit/2e2b355e9e07e4bb9dfb490cc0b50c66e090f483]
> Steps to reproduce:
> 1. git clone https://github.com/vladglinskiy/olingo-odata4.git
> 2. git checkout csdl-deserializer-bugs
> 3. mvn clean test -pl lib/client-core/ -Dtest=AnnotatedExpressionTest
> All tests except {{annotatedRecordExpressionTest}} will fail.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)