[ 
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)

Reply via email to