[ 
https://issues.apache.org/jira/browse/DAFFODIL-2808?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Olabusayo Kilo updated DAFFODIL-2808:
-------------------------------------
    Description: 


When you have an optional element with children element, daffodil calculates 
the number of occurrences it has by looking at the number of children it has, 
rather than calculating the number of times it appears. This results in an 
validation error saying the element occurred NUM_OF_CHILDREN_TIME when it was 
expected.

Attached is a TDML test that shows this incorrect validation error

I narrowed down the  error to 
src/main/scala/org/apache/daffodil/runtime1/processors/parsers/SequenceChildBases.scala
 line 543 in endArray

{code:scala}
        val occurrence = {
          val maybeLastChild = state.infoset.maybeLastChild
          if (maybeLastChild.isEmpty || maybeLastChild.get.erd != erd)
            0
          else
            maybeLastChild.get.numChildren
        }
{code}

  was:
When you have an optional element with children element, daffodil calculates 
the number of occurrences it has by looking at the number of children it has, 
rather than calculating the number of times it appears. This results in an 
validation error saying the element occurred NUM_OF_CHILDREN_TIME when it was 
expected.


Attached is a TDML test that shows this incorrect validation error


> Incorrect Validation Error on Optional Element with Children
> ------------------------------------------------------------
>
>                 Key: DAFFODIL-2808
>                 URL: https://issues.apache.org/jira/browse/DAFFODIL-2808
>             Project: Daffodil
>          Issue Type: Bug
>          Components: Back End
>    Affects Versions: 3.5.0
>            Reporter: Olabusayo Kilo
>            Priority: Major
>         Attachments: optionElementTest.scala, optionalElement.tdml
>
>
> When you have an optional element with children element, daffodil calculates 
> the number of occurrences it has by looking at the number of children it has, 
> rather than calculating the number of times it appears. This results in an 
> validation error saying the element occurred NUM_OF_CHILDREN_TIME when it was 
> expected.
> Attached is a TDML test that shows this incorrect validation error
> I narrowed down the  error to 
> src/main/scala/org/apache/daffodil/runtime1/processors/parsers/SequenceChildBases.scala
>  line 543 in endArray
> {code:scala}
>         val occurrence = {
>           val maybeLastChild = state.infoset.maybeLastChild
>           if (maybeLastChild.isEmpty || maybeLastChild.get.erd != erd)
>             0
>           else
>             maybeLastChild.get.numChildren
>         }
> {code}



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to