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

Thomas Diesler resolved CAMEL-9122.
-----------------------------------
       Resolution: Fixed
    Fix Version/s:     (was: 2.17.0)

If we stick to a working jruby version, we can resolve this. Its no longer a 
bug.

> Ruby script cannot access request object
> ----------------------------------------
>
>                 Key: CAMEL-9122
>                 URL: https://issues.apache.org/jira/browse/CAMEL-9122
>             Project: Camel
>          Issue Type: Bug
>          Components: camel-script
>            Reporter: Thomas Diesler
>
> with script
> {code}
> body = $request.getBody()
> $request.setBody("Hello " + body);
> {code}
> we get 
> {code}
> uby: body = $request.getBody();
> $request.setBody("Hello " + body);. Cause: 
> org.jruby.embed.EvalFailedException: (NoMethodError) undefined method 
> `getBody' for nil:NilClass
>       at 
> org.apache.camel.builder.script.ScriptBuilder.createScriptEvaluationException(ScriptBuilder.java:540)
>       at 
> org.apache.camel.builder.script.ScriptBuilder.evaluateScript(ScriptBuilder.java:409)
>       at 
> org.apache.camel.builder.script.ScriptBuilder.process(ScriptBuilder.java:181)
>       at 
> org.apache.camel.processor.DelegateSyncProcessor.process(DelegateSyncProcessor.java:63)
>       at 
> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:77)
>       at 
> org.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:460)
>       at 
> org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:190)
>       at 
> org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:190)
>       at 
> org.apache.camel.component.direct.DirectProducer.process(DirectProducer.java:62)
>       at 
> org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:190)
>       at 
> org.apache.camel.util.AsyncProcessorHelper.process(AsyncProcessorHelper.java:109)
>       at 
> org.apache.camel.processor.UnitOfWorkProducer.process(UnitOfWorkProducer.java:68)
>       at 
> org.apache.camel.impl.ProducerCache$2.doInProducer(ProducerCache.java:404)
>       at 
> org.apache.camel.impl.ProducerCache$2.doInProducer(ProducerCache.java:372)
>       at 
> org.apache.camel.impl.ProducerCache.doInProducer(ProducerCache.java:262)
>       at 
> org.apache.camel.impl.ProducerCache.sendExchange(ProducerCache.java:372)
>       at org.apache.camel.impl.ProducerCache.send(ProducerCache.java:230)
>       at 
> org.apache.camel.impl.DefaultProducerTemplate.send(DefaultProducerTemplate.java:128)
>       at 
> org.apache.camel.impl.DefaultProducerTemplate.sendBody(DefaultProducerTemplate.java:132)
>       at 
> org.apache.camel.impl.DefaultProducerTemplate.sendBody(DefaultProducerTemplate.java:149)
>       at 
> org.apache.camel.impl.DefaultProducerTemplate.requestBody(DefaultProducerTemplate.java:301)
>       at 
> org.apache.camel.impl.DefaultProducerTemplate.requestBody(DefaultProducerTemplate.java:331)
>       at 
> org.wildfly.camel.test.script.ScriptIntegrationTest.scriptProcessing(ScriptIntegrationTest.java:100)
>       at 
> org.wildfly.camel.test.script.ScriptIntegrationTest.testRuby(ScriptIntegrationTest.java:75)
> {code}
> It seems that the scriptengine can load the script and that the request 
> object is nil.
> This used to work 2.15.2 and earlier 2.16 snapshots 
> CrossRef: https://github.com/wildfly-extras/wildfly-camel/issues/845



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to