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

Henrik Karlsson updated CAMEL-16918:
------------------------------------
    Description: 
I use a multicast().parallelProcessing() that calls three routes that all use 
DataSonnet expressions. After starting the app the first runs of this route 
fails with an java.util.ConcurrentModificationException.

I getting these two stack traces from to different threads:

Thread #1: 
{noformat}
org.apache.camel.RuntimeExpressionException: Unable to evaluate DataSonnet 
expression: 'PayerId = :?payer_id' + if (!ds.isEmpty(cml.header('orderer_id'))) 
then (' and OrdererId = :?orderer_id' + if 
(!ds.isEmpty(cml.header('workplace_id'))) then ' and Id = :?workplace_id' else 
'') else ''
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:115)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.SetHeaderProcessor.process(SetHeaderProcessor.java:48)
 ~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.errorhandler.RedeliveryErrorHandler$SimpleTask.run(RedeliveryErrorHandler.java:463)
 ~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
org.apache.camel.impl.engine.DefaultReactiveExecutor$Worker.schedule(DefaultReactiveExecutor.java:179)
 ~[camel-base-engine-3.11.1.jar:3.11.1]
        at 
org.apache.camel.impl.engine.DefaultReactiveExecutor.schedule(DefaultReactiveExecutor.java:59)
 ~[camel-base-engine-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.MulticastProcessor.lambda$schedule$1(MulticastProcessor.java:348)
 ~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
 ~[na:na]
        at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) 
~[na:na]
        at 
java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
 ~[na:na]
        at 
java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
 ~[na:na]
        at java.base/java.lang.Thread.run(Thread.java:831) ~[na:na]
Caused by: java.util.ConcurrentModificationException: null
        at java.base/java.util.HashMap.computeIfAbsent(HashMap.java:1225) 
~[na:na]
        at 
org.apache.camel.language.datasonnet.DatasonnetLanguage.computeIfMiss(DatasonnetLanguage.java:103)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.doEvaluate(DatasonnetExpression.java:143)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:106)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        ... 10 common frames omitted
{noformat}
Thread #2: 
{noformat}
org.apache.camel.RuntimeExpressionException: Unable to evaluate DataSonnet 
expression: !ds.isEmpty(cml.header('payer_id'))
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:115)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.matches(DatasonnetExpression.java:93)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.FilterProcessor.matches(FilterProcessor.java:77) 
~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.ChoiceProcessor.process(ChoiceProcessor.java:71) 
~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.errorhandler.RedeliveryErrorHandler$SimpleTask.run(RedeliveryErrorHandler.java:463)
 ~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
org.apache.camel.impl.engine.DefaultReactiveExecutor$Worker.schedule(DefaultReactiveExecutor.java:179)
 ~[camel-base-engine-3.11.1.jar:3.11.1]
        at 
org.apache.camel.impl.engine.DefaultReactiveExecutor.schedule(DefaultReactiveExecutor.java:59)
 ~[camel-base-engine-3.11.1.jar:3.11.1]
        at 
org.apache.camel.processor.MulticastProcessor.lambda$schedule$1(MulticastProcessor.java:348)
 ~[camel-core-processor-3.11.1.jar:3.11.1]
        at 
java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
 ~[na:na]
        at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) 
~[na:na]
        at 
java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
 ~[na:na]
        at 
java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
 ~[na:na]
        at java.base/java.lang.Thread.run(Thread.java:831) ~[na:na]
Caused by: java.util.ConcurrentModificationException: null
        at java.base/java.util.HashMap.computeIfAbsent(HashMap.java:1225) 
~[na:na]
        at 
org.apache.camel.language.datasonnet.DatasonnetLanguage.computeIfMiss(DatasonnetLanguage.java:103)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.doEvaluate(DatasonnetExpression.java:143)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:106)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]
        ... 12 common frames omitted
{noformat}

  was:
I use a multicast().parallelProcessing() that calls three routes that all use 
DataSonnet expressions. After starting the app the first runs of this route 
fails with an java.util.ConcurrentModificationException.

I getting these two stack traces from to different threads:

Thread #1: 

{{org.apache.camel.RuntimeExpressionException: Unable to evaluate DataSonnet 
expression: 'PayerId = :?payer_id' + if (!ds.isEmpty(cml.header('orderer_id'))) 
then (' and OrdererId = :?orderer_id' + if 
(!ds.isEmpty(cml.header('workplace_id'))) then ' and Id = :?workplace_id' else 
'') else ''}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:115)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.SetHeaderProcessor.process(SetHeaderProcessor.java:48)
 ~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.errorhandler.RedeliveryErrorHandler$SimpleTask.run(RedeliveryErrorHandler.java:463)
 ~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.impl.engine.DefaultReactiveExecutor$Worker.schedule(DefaultReactiveExecutor.java:179)
 ~[camel-base-engine-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.impl.engine.DefaultReactiveExecutor.schedule(DefaultReactiveExecutor.java:59)
 ~[camel-base-engine-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.MulticastProcessor.lambda$schedule$1(MulticastProcessor.java:348)
 ~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
 ~[na:na]}}{{at 
java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) 
~[na:na]}}{{at 
java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
 ~[na:na]}}{{at 
java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
 ~[na:na]}}{{at java.base/java.lang.Thread.run(Thread.java:831) 
~[na:na]}}{{Caused by: java.util.ConcurrentModificationException: null}}{{at 
java.base/java.util.HashMap.computeIfAbsent(HashMap.java:1225) ~[na:na]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetLanguage.computeIfMiss(DatasonnetLanguage.java:103)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.doEvaluate(DatasonnetExpression.java:143)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:106)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{... 10 common frames omitted}}

Thread #2:

{{org.apache.camel.RuntimeExpressionException: Unable to evaluate DataSonnet 
expression: !ds.isEmpty(cml.header('payer_id'))}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:115)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.matches(DatasonnetExpression.java:93)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.FilterProcessor.matches(FilterProcessor.java:77) 
~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.ChoiceProcessor.process(ChoiceProcessor.java:71) 
~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.errorhandler.RedeliveryErrorHandler$SimpleTask.run(RedeliveryErrorHandler.java:463)
 ~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.impl.engine.DefaultReactiveExecutor$Worker.schedule(DefaultReactiveExecutor.java:179)
 ~[camel-base-engine-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.impl.engine.DefaultReactiveExecutor.schedule(DefaultReactiveExecutor.java:59)
 ~[camel-base-engine-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.processor.MulticastProcessor.lambda$schedule$1(MulticastProcessor.java:348)
 ~[camel-core-processor-3.11.1.jar:3.11.1]}}{{at 
java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
 ~[na:na]}}{{at 
java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) 
~[na:na]}}{{at 
java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
 ~[na:na]}}{{at 
java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
 ~[na:na]}}{{at java.base/java.lang.Thread.run(Thread.java:831) 
~[na:na]}}{{Caused by: java.util.ConcurrentModificationException: null}}{{at 
java.base/java.util.HashMap.computeIfAbsent(HashMap.java:1225) ~[na:na]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetLanguage.computeIfMiss(DatasonnetLanguage.java:103)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.doEvaluate(DatasonnetExpression.java:143)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{at 
org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:106)
 ~[camel-datasonnet-3.11.1.jar:3.11.1]}}{{... 12 common frames omitted}}

 


> Datasonnet expression fails on first runs in a route called in multicast 
> -------------------------------------------------------------------------
>
>                 Key: CAMEL-16918
>                 URL: https://issues.apache.org/jira/browse/CAMEL-16918
>             Project: Camel
>          Issue Type: Bug
>          Components: camel-language
>    Affects Versions: 3.11.1
>            Reporter: Henrik Karlsson
>            Priority: Major
>
> I use a multicast().parallelProcessing() that calls three routes that all use 
> DataSonnet expressions. After starting the app the first runs of this route 
> fails with an java.util.ConcurrentModificationException.
> I getting these two stack traces from to different threads:
> Thread #1: 
> {noformat}
> org.apache.camel.RuntimeExpressionException: Unable to evaluate DataSonnet 
> expression: 'PayerId = :?payer_id' + if 
> (!ds.isEmpty(cml.header('orderer_id'))) then (' and OrdererId = :?orderer_id' 
> + if (!ds.isEmpty(cml.header('workplace_id'))) then ' and Id = 
> :?workplace_id' else '') else ''
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:115)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.SetHeaderProcessor.process(SetHeaderProcessor.java:48)
>  ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.errorhandler.RedeliveryErrorHandler$SimpleTask.run(RedeliveryErrorHandler.java:463)
>  ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.impl.engine.DefaultReactiveExecutor$Worker.schedule(DefaultReactiveExecutor.java:179)
>  ~[camel-base-engine-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.impl.engine.DefaultReactiveExecutor.schedule(DefaultReactiveExecutor.java:59)
>  ~[camel-base-engine-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.MulticastProcessor.lambda$schedule$1(MulticastProcessor.java:348)
>  ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
>  ~[na:na]
>       at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) 
> ~[na:na]
>       at 
> java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
>  ~[na:na]
>       at 
> java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
>  ~[na:na]
>       at java.base/java.lang.Thread.run(Thread.java:831) ~[na:na]
> Caused by: java.util.ConcurrentModificationException: null
>       at java.base/java.util.HashMap.computeIfAbsent(HashMap.java:1225) 
> ~[na:na]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetLanguage.computeIfMiss(DatasonnetLanguage.java:103)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.doEvaluate(DatasonnetExpression.java:143)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:106)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       ... 10 common frames omitted
> {noformat}
> Thread #2: 
> {noformat}
> org.apache.camel.RuntimeExpressionException: Unable to evaluate DataSonnet 
> expression: !ds.isEmpty(cml.header('payer_id'))
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:115)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.matches(DatasonnetExpression.java:93)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.FilterProcessor.matches(FilterProcessor.java:77) 
> ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.ChoiceProcessor.process(ChoiceProcessor.java:71) 
> ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.errorhandler.RedeliveryErrorHandler$SimpleTask.run(RedeliveryErrorHandler.java:463)
>  ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.impl.engine.DefaultReactiveExecutor$Worker.schedule(DefaultReactiveExecutor.java:179)
>  ~[camel-base-engine-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.impl.engine.DefaultReactiveExecutor.schedule(DefaultReactiveExecutor.java:59)
>  ~[camel-base-engine-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.processor.MulticastProcessor.lambda$schedule$1(MulticastProcessor.java:348)
>  ~[camel-core-processor-3.11.1.jar:3.11.1]
>       at 
> java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
>  ~[na:na]
>       at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) 
> ~[na:na]
>       at 
> java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
>  ~[na:na]
>       at 
> java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
>  ~[na:na]
>       at java.base/java.lang.Thread.run(Thread.java:831) ~[na:na]
> Caused by: java.util.ConcurrentModificationException: null
>       at java.base/java.util.HashMap.computeIfAbsent(HashMap.java:1225) 
> ~[na:na]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetLanguage.computeIfMiss(DatasonnetLanguage.java:103)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.doEvaluate(DatasonnetExpression.java:143)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       at 
> org.apache.camel.language.datasonnet.DatasonnetExpression.evaluate(DatasonnetExpression.java:106)
>  ~[camel-datasonnet-3.11.1.jar:3.11.1]
>       ... 12 common frames omitted
> {noformat}



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to