Claus:

Thanks, I've put in a workaround for now but will definitely test it in
Camel 2.3.

David


Claus Ibsen-2 wrote:
> 
> Hi
> 
> I have implemented the fix in the codebase. You are welcome to test
> with latest source code or wait for the Camel 2.3 release, which is
> out in a couple of weeks.
> 
> 
> On Thu, May 20, 2010 at 2:54 PM, Claus Ibsen <claus.ib...@gmail.com>
> wrote:
>> Hi
>>
>> I have created a ticket
>> https://issues.apache.org/activemq/browse/CAMEL-2742
>>
>> You could most likely use a custom JMSBinding by setting it on the
>> endpoint uri
>>
>> to("mq:xxxx?binding=#myCustomBinding");
>>
>> And then myCustomBinding is the id of a bean in the registry to lookup
>> as a JmsBinding type.
>>
>> Otherwise if you do not need the given property you can also provide a
>> custom header filter strategy where you can skip this header.
>> Or use a custom messageConverter when you can do all the mapping
>> yourself.
>>
>>
>> On Thu, May 20, 2010 at 2:26 PM, dlawson <david.law...@metastorm.com>
>> wrote:
>>>
>>> To All:
>>>
>>>
>>> I am experiencing a problem when routing a Camel message from ActiveMQ
>>> to
>>> WebSphereMQ 7 using the JMSComponent. My Camel version is 2.2.0. As the
>>> stack trace below indicates,
>>>
>>> the exception is thrown when the "JMS-IBM_Last_Msg_In_Group"
>>> header/property
>>> in the Camel Message is being mapped to the JMS message property. The
>>> underlying JMS Message
>>>
>>> expects the field to be of type Boolean but Camel is delivering it as a
>>> String. In the Camel JMSBinding class, the getValidJMSHeaderValue method
>>> is
>>> performing the following
>>>
>>> mapping:
>>>
>>>
>>> 390      protected Object getValidJMSHeaderValue(String headerName,
>>> Object
>>> headerValue) {
>>> 391     if (headerValue instanceof String) {
>>> 392     return headerValue;
>>> 393     } else if (headerValue instanceof Number) {
>>> 394     return headerValue;
>>> 395     } else if (headerValue instanceof Character) {
>>> 396     return headerValue;
>>> 397     } else if (headerValue instanceof CharSequence) {
>>> 398     return headerValue.toString();
>>> 399     } else if (headerValue instanceof Boolean) {
>>> 400     return headerValue.toString();
>>> 401     } else if (headerValue instanceof Date) {
>>> 402     return headerValue.toString();
>>> 403     }
>>> 404     return null;
>>> 405     }
>>>
>>> Is there a way to specify a custom JMSBinding in this instance or do I
>>> have
>>> to patch the code to get around this problem? Thanks,
>>>
>>> David
>>>
>>>
>>>
>>>
>>> org.springframework.jms.MessageFormatException: JMSCC0051: The property
>>> 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean',
>>> not 'java.lang.String'.;
>>>
>>> nested exception is
>>> com.ibm.msg.client.jms.DetailedMessageFormatException:
>>> JMSCC0051: The property 'JMS_IBM_Last_Msg_In_Group' should be set using
>>> type
>>> 'java.lang.Boolean',
>>>
>>> not 'java.lang.String'. JMS_IBM properties may only be set using a
>>> specific
>>> variable type. Correct application code to use the required variable
>>> type
>>> when setting this JMS_IBM
>>>
>>> property.
>>>        at
>>> org.springframework.jms.support.JmsUtils.convertJmsAccessException(JmsUtils.java:289)
>>>        at
>>> org.springframework.jms.support.JmsAccessor.convertJmsAccessException(JmsAccessor.java:168)
>>>        at
>>> org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:474)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.send(JmsConfiguration.java:195)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.doSend(JmsProducer.java:375)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.processInOnly(JmsProducer.java:320)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.process(JmsProducer.java:150)
>>>        at
>>> org.apache.camel.processor.SendProcessor$1.doInProducer(SendProcessor.java:97)
>>>        at
>>> org.apache.camel.processor.SendProcessor$1.doInProducer(SendProcessor.java:95)
>>>        at
>>> org.apache.camel.impl.ProducerCache.doInProducer(ProducerCache.java:146)
>>>        at
>>> org.apache.camel.processor.SendProcessor.doProcess(SendProcessor.java:94)
>>>        at
>>> org.apache.camel.processor.SendProcessor.process(SendProcessor.java:82)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.processNext(DelegateProcessor.java:53)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.proceed(DelegateProcessor.java:82)
>>>        at
>>> org.apache.camel.processor.interceptor.TraceInterceptor.process(TraceInterceptor.java:93)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.processExchange(RedeliveryErrorHandler.java:177)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.processErrorHandler(RedeliveryErrorHandler.java:143)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:88)
>>>        at
>>> org.apache.camel.processor.DefaultErrorHandler.process(DefaultErrorHandler.java:49)
>>>        at
>>> org.apache.camel.processor.DefaultChannel.process(DefaultChannel.java:228)
>>>        at org.apache.camel.processor.Pipeline.process(Pipeline.java:74)
>>>        at
>>> org.apache.camel.processor.UnitOfWorkProcessor.processNext(UnitOfWorkProcessor.java:66)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.process(DelegateProcessor.java:48)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.component.jms.EndpointMessageListener.onMessage(EndpointMessageListener.java:84)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.doInvokeListener(AbstractMessageListenerContainer.java:543)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.invokeListener(AbstractMessageListenerContainer.java:482)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.doExecuteListener(AbstractMessageListenerContainer.java:451)
>>>        at
>>> org.springframework.jms.listener.AbstractPollingMessageListenerContainer.doReceiveAndExecute(AbstractPollingMessageListenerContainer.java:323)
>>>        at
>>> org.springframework.jms.listener.AbstractPollingMessageListenerContainer.receiveAndExecute(AbstractPollingMessageListenerContainer.java:261)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.invokeListener(DefaultMessageListenerContainer.java:982)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.executeOngoingLoop(DefaultMessageListenerContainer.java:974)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.run(DefaultMessageListenerContainer.java:876)
>>>        at java.lang.Thread.run(Thread.java:619)
>>> Caused by: com.ibm.msg.client.jms.DetailedMessageFormatException:
>>> JMSCC0051:
>>> The property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not
>>>
>>> 'java.lang.String'. JMS_IBM properties may only be set using a specific
>>> variable type. Correct application code to use the required variable
>>> type
>>> when setting this JMS_IBM
>>>
>>> property.
>>>        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native
>>> Method)
>>>        at
>>> sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
>>>        at
>>> sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
>>>        at
>>> java.lang.reflect.Constructor.newInstance(Constructor.java:513)
>>>        at
>>> com.ibm.msg.client.commonservices.j2se.NLSServices.createException(NLSServices.java:313)
>>>        at
>>> com.ibm.msg.client.commonservices.nls.NLSServices.createException(NLSServices.java:390)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsErrorUtils.createException(JmsErrorUtils.java:104)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsMessageImpl.checkSettablePropertyName(JmsMessageImpl.java:1968)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsMessageImpl.setObjectProperty(JmsMessageImpl.java:1502)
>>>        at com.ibm.jms.JMSMessage.setObjectProperty(JMSMessage.java:1421)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.appendJmsProperty(JmsBinding.java:336)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.appendJmsProperties(JmsBinding.java:300)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.makeJmsMessage(JmsBinding.java:278)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer$2.createMessage(JmsProducer.java:316)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.doSendToDestination(JmsConfiguration.java:221)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.access$100(JmsConfiguration.java:164)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate$3.doInJms(JmsConfiguration.java:198)
>>>        at
>>> org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:471)
>>>        ... 33 more
>>> DEBUG 19 May 2010 14:11:06,531 [DefaultErrorHandler:377] - This exchange
>>> is
>>> not handled so its marked as failed: Exchange[JmsMessage:
>>> ActiveMQTextMessage {commandId = 5,
>>>
>>> responseRequired = true, messageId =
>>> ID:DLAWSON701-58897-1274292657513-0:17:1:1:1, originalDestination =
>>> null,
>>> originalTransactionId = null, producerId = ID:DLAWSON701-58897-
>>>
>>> 1274292657513-0:17:1:1, destination = queue://NEXUS.FTS.DATA.JMSNODE1,
>>> transactionId = null, expiration = 0, timestamp = 1274292665860, arrival
>>> =
>>> 0, brokerInTime =
>>>
>>> 1274292665860, brokerOutTime = 1274292666034, correlationId = null,
>>> replyTo
>>> = null, persistent = true, type = null, priority = 4, groupID =
>>> 9TTY5M6LGOH7NSWA2LY2K29V,
>>>
>>> groupSequence = 15, targetConsumerId = null, compressed = false, userID
>>> =
>>> null, content = null, marshalledProperties =
>>> org.apache.activemq.util.byteseque...@4e32c8,
>>>
>>> dataStructure = null, redeliveryCounter = 0, size = 0, properties =
>>> {seqnum=15, JMS_IBM_Last_Msg_In_Group=true}, readOnlyProperties = true,
>>> readOnlyBody = true, droppable =
>>>
>>> false, text = }]
>>> DEBUG 19 May 2010 14:11:06,532 [Pipeline:99] - Message exchange has
>>> failed
>>> so breaking out of pipeline: Exchange[JmsMessage: ActiveMQTextMessage
>>> {commandId = 5,
>>>
>>> responseRequired = true, messageId =
>>> ID:DLAWSON701-58897-1274292657513-0:17:1:1:1, originalDestination =
>>> null,
>>> originalTransactionId = null, producerId = ID:DLAWSON701-58897-
>>>
>>> 1274292657513-0:17:1:1, destination = queue://NEXUS.FTS.DATA.JMSNODE1,
>>> transactionId = null, expiration = 0, timestamp = 1274292665860, arrival
>>> =
>>> 0, brokerInTime =
>>>
>>> 1274292665860, brokerOutTime = 1274292666034, correlationId = null,
>>> replyTo
>>> = null, persistent = true, type = null, priority = 4, groupID =
>>> 9TTY5M6LGOH7NSWA2LY2K29V,
>>>
>>> groupSequence = 15, targetConsumerId = null, compressed = false, userID
>>> =
>>> null, content = null, marshalledProperties =
>>> org.apache.activemq.util.byteseque...@4e32c8,
>>>
>>> dataStructure = null, redeliveryCounter = 0, size = 0, properties =
>>> {seqnum=15, JMS_IBM_Last_Msg_In_Group=true}, readOnlyProperties = true,
>>> readOnlyBody = true, droppable =
>>>
>>> false, text = }] Exception:
>>> org.springframework.jms.MessageFormatException:
>>> JMSCC0051: The property 'JMS_IBM_Last_Msg_In_Group' should be set using
>>> type
>>> 'java.lang.Boolean',
>>>
>>> not 'java.lang.String'.; nested exception is
>>> com.ibm.msg.client.jms.DetailedMessageFormatException: JMSCC0051: The
>>> property 'JMS_IBM_Last_Msg_In_Group' should be set using
>>>
>>> type 'java.lang.Boolean', not 'java.lang.String'. JMS_IBM properties may
>>> only be set using a specific variable type. Correct application code to
>>> use
>>> the required variable type
>>>
>>> when setting this JMS_IBM property.
>>> ERROR 19 May 2010 14:11:06,533 [EndpointMessageListener:248] - Caused
>>> by:
>>> [org.apache.camel.RuntimeCamelException -
>>> org.springframework.jms.MessageFormatException: JMSCC0051:
>>>
>>> The property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not 'java.lang.String'.; nested exception is
>>>
>>> com.ibm.msg.client.jms.DetailedMessageFormatException: JMSCC0051: The
>>> property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not
>>>
>>> 'java.lang.String'. JMS_IBM properties may only be set using a specific
>>> variable type. Correct application code to use the required variable
>>> type
>>> when setting this JMS_IBM
>>>
>>> property.]
>>> org.apache.camel.RuntimeCamelException:
>>> org.springframework.jms.MessageFormatException: JMSCC0051: The property
>>> 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>>
>>> 'java.lang.Boolean', not 'java.lang.String'.; nested exception is
>>> com.ibm.msg.client.jms.DetailedMessageFormatException: JMSCC0051: The
>>> property 'JMS_IBM_Last_Msg_In_Group'
>>>
>>> should be set using type 'java.lang.Boolean', not 'java.lang.String'.
>>> JMS_IBM properties may only be set using a specific variable type.
>>> Correct
>>> application code to use the
>>>
>>> required variable type when setting this JMS_IBM property.
>>>        at
>>> org.apache.camel.util.ObjectHelper.wrapRuntimeCamelException(ObjectHelper.java:1055)
>>>        at
>>> org.apache.camel.component.jms.EndpointMessageListener.onMessage(EndpointMessageListener.java:104)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.doInvokeListener(AbstractMessageListenerContainer.java:543)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.invokeListener(AbstractMessageListenerContainer.java:482)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.doExecuteListener(AbstractMessageListenerContainer.java:451)
>>>        at
>>> org.springframework.jms.listener.AbstractPollingMessageListenerContainer.doReceiveAndExecute(AbstractPollingMessageListenerContainer.java:323)
>>>        at
>>> org.springframework.jms.listener.AbstractPollingMessageListenerContainer.receiveAndExecute(AbstractPollingMessageListenerContainer.java:261)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.invokeListener(DefaultMessageListenerContainer.java:982)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.executeOngoingLoop(DefaultMessageListenerContainer.java:974)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.run(DefaultMessageListenerContainer.java:876)
>>>        at java.lang.Thread.run(Thread.java:619)
>>> Caused by: org.springframework.jms.MessageFormatException: JMSCC0051:
>>> The
>>> property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not
>>>
>>> 'java.lang.String'.; nested exception is
>>> com.ibm.msg.client.jms.DetailedMessageFormatException: JMSCC0051: The
>>> property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>>
>>> 'java.lang.Boolean', not 'java.lang.String'. JMS_IBM properties may only
>>> be
>>> set using a specific variable type. Correct application code to use the
>>> required variable type when
>>>
>>> setting this JMS_IBM property.
>>>        at
>>> org.springframework.jms.support.JmsUtils.convertJmsAccessException(JmsUtils.java:289)
>>>        at
>>> org.springframework.jms.support.JmsAccessor.convertJmsAccessException(JmsAccessor.java:168)
>>>        at
>>> org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:474)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.send(JmsConfiguration.java:195)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.doSend(JmsProducer.java:375)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.processInOnly(JmsProducer.java:320)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.process(JmsProducer.java:150)
>>>        at
>>> org.apache.camel.processor.SendProcessor$1.doInProducer(SendProcessor.java:97)
>>>        at
>>> org.apache.camel.processor.SendProcessor$1.doInProducer(SendProcessor.java:95)
>>>        at
>>> org.apache.camel.impl.ProducerCache.doInProducer(ProducerCache.java:146)
>>>        at
>>> org.apache.camel.processor.SendProcessor.doProcess(SendProcessor.java:94)
>>>        at
>>> org.apache.camel.processor.SendProcessor.process(SendProcessor.java:82)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.processNext(DelegateProcessor.java:53)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.proceed(DelegateProcessor.java:82)
>>>        at
>>> org.apache.camel.processor.interceptor.TraceInterceptor.process(TraceInterceptor.java:93)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.processExchange(RedeliveryErrorHandler.java:177)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.processErrorHandler(RedeliveryErrorHandler.java:143)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:88)
>>>        at
>>> org.apache.camel.processor.DefaultErrorHandler.process(DefaultErrorHandler.java:49)
>>>        at
>>> org.apache.camel.processor.DefaultChannel.process(DefaultChannel.java:228)
>>>        at org.apache.camel.processor.Pipeline.process(Pipeline.java:74)
>>>        at
>>> org.apache.camel.processor.UnitOfWorkProcessor.processNext(UnitOfWorkProcessor.java:66)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.process(DelegateProcessor.java:48)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.component.jms.EndpointMessageListener.onMessage(EndpointMessageListener.java:84)
>>>        ... 9 more
>>> Caused by: com.ibm.msg.client.jms.DetailedMessageFormatException:
>>> JMSCC0051:
>>> The property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not
>>>
>>> 'java.lang.String'. JMS_IBM properties may only be set using a specific
>>> variable type. Correct application code to use the required variable
>>> type
>>> when setting this JMS_IBM
>>>
>>> property.
>>>        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native
>>> Method)
>>>        at
>>> sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
>>>        at
>>> sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
>>>        at
>>> java.lang.reflect.Constructor.newInstance(Constructor.java:513)
>>>        at
>>> com.ibm.msg.client.commonservices.j2se.NLSServices.createException(NLSServices.java:313)
>>>        at
>>> com.ibm.msg.client.commonservices.nls.NLSServices.createException(NLSServices.java:390)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsErrorUtils.createException(JmsErrorUtils.java:104)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsMessageImpl.checkSettablePropertyName(JmsMessageImpl.java:1968)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsMessageImpl.setObjectProperty(JmsMessageImpl.java:1502)
>>>        at com.ibm.jms.JMSMessage.setObjectProperty(JMSMessage.java:1421)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.appendJmsProperty(JmsBinding.java:336)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.appendJmsProperties(JmsBinding.java:300)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.makeJmsMessage(JmsBinding.java:278)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer$2.createMessage(JmsProducer.java:316)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.doSendToDestination(JmsConfiguration.java:221)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.access$100(JmsConfiguration.java:164)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate$3.doInJms(JmsConfiguration.java:198)
>>>        at
>>> org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:471)
>>>        ... 33 more
>>> WARN  19 May 2010 14:11:06,534 [DefaultMessageListenerContainer:646] -
>>> Execution of JMS message listener failed
>>> org.apache.camel.RuntimeCamelException:
>>> org.springframework.jms.MessageFormatException: JMSCC0051: The property
>>> 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>>
>>> 'java.lang.Boolean', not 'java.lang.String'.; nested exception is
>>> com.ibm.msg.client.jms.DetailedMessageFormatException: JMSCC0051: The
>>> property 'JMS_IBM_Last_Msg_In_Group'
>>>
>>> should be set using type 'java.lang.Boolean', not 'java.lang.String'.
>>> JMS_IBM properties may only be set using a specific variable type.
>>> Correct
>>> application code to use the
>>>
>>> required variable type when setting this JMS_IBM property.
>>>        at
>>> org.apache.camel.util.ObjectHelper.wrapRuntimeCamelException(ObjectHelper.java:1055)
>>>        at
>>> org.apache.camel.component.jms.EndpointMessageListener.onMessage(EndpointMessageListener.java:104)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.doInvokeListener(AbstractMessageListenerContainer.java:543)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.invokeListener(AbstractMessageListenerContainer.java:482)
>>>        at
>>> org.springframework.jms.listener.AbstractMessageListenerContainer.doExecuteListener(AbstractMessageListenerContainer.java:451)
>>>        at
>>> org.springframework.jms.listener.AbstractPollingMessageListenerContainer.doReceiveAndExecute(AbstractPollingMessageListenerContainer.java:323)
>>>        at
>>> org.springframework.jms.listener.AbstractPollingMessageListenerContainer.receiveAndExecute(AbstractPollingMessageListenerContainer.java:261)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.invokeListener(DefaultMessageListenerContainer.java:982)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.executeOngoingLoop(DefaultMessageListenerContainer.java:974)
>>>        at
>>> org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.run(DefaultMessageListenerContainer.java:876)
>>>        at java.lang.Thread.run(Thread.java:619)
>>> Caused by: org.springframework.jms.MessageFormatException: JMSCC0051:
>>> The
>>> property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not
>>>
>>> 'java.lang.String'.; nested exception is
>>> com.ibm.msg.client.jms.DetailedMessageFormatException: JMSCC0051: The
>>> property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>>
>>> 'java.lang.Boolean', not 'java.lang.String'. JMS_IBM properties may only
>>> be
>>> set using a specific variable type. Correct application code to use the
>>> required variable type when
>>>
>>> setting this JMS_IBM property.
>>>        at
>>> org.springframework.jms.support.JmsUtils.convertJmsAccessException(JmsUtils.java:289)
>>>        at
>>> org.springframework.jms.support.JmsAccessor.convertJmsAccessException(JmsAccessor.java:168)
>>>        at
>>> org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:474)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.send(JmsConfiguration.java:195)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.doSend(JmsProducer.java:375)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.processInOnly(JmsProducer.java:320)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer.process(JmsProducer.java:150)
>>>        at
>>> org.apache.camel.processor.SendProcessor$1.doInProducer(SendProcessor.java:97)
>>>        at
>>> org.apache.camel.processor.SendProcessor$1.doInProducer(SendProcessor.java:95)
>>>        at
>>> org.apache.camel.impl.ProducerCache.doInProducer(ProducerCache.java:146)
>>>        at
>>> org.apache.camel.processor.SendProcessor.doProcess(SendProcessor.java:94)
>>>        at
>>> org.apache.camel.processor.SendProcessor.process(SendProcessor.java:82)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.processNext(DelegateProcessor.java:53)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.proceed(DelegateProcessor.java:82)
>>>        at
>>> org.apache.camel.processor.interceptor.TraceInterceptor.process(TraceInterceptor.java:93)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.processExchange(RedeliveryErrorHandler.java:177)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.processErrorHandler(RedeliveryErrorHandler.java:143)
>>>        at
>>> org.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:88)
>>>        at
>>> org.apache.camel.processor.DefaultErrorHandler.process(DefaultErrorHandler.java:49)
>>>        at
>>> org.apache.camel.processor.DefaultChannel.process(DefaultChannel.java:228)
>>>        at org.apache.camel.processor.Pipeline.process(Pipeline.java:74)
>>>        at
>>> org.apache.camel.processor.UnitOfWorkProcessor.processNext(UnitOfWorkProcessor.java:66)
>>>        at
>>> org.apache.camel.processor.DelegateProcessor.process(DelegateProcessor.java:48)
>>>        at
>>> org.apache.camel.management.InstrumentationProcessor.process(InstrumentationProcessor.java:67)
>>>        at
>>> org.apache.camel.component.jms.EndpointMessageListener.onMessage(EndpointMessageListener.java:84)
>>>        ... 9 more
>>> Caused by: com.ibm.msg.client.jms.DetailedMessageFormatException:
>>> JMSCC0051:
>>> The property 'JMS_IBM_Last_Msg_In_Group' should be set using type
>>> 'java.lang.Boolean', not
>>>
>>> 'java.lang.String'. JMS_IBM properties may only be set using a specific
>>> variable type. Correct application code to use the required variable
>>> type
>>> when setting this JMS_IBM
>>>
>>> property.
>>>        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native
>>> Method)
>>>        at
>>> sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
>>>        at
>>> sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
>>>        at
>>> java.lang.reflect.Constructor.newInstance(Constructor.java:513)
>>>        at
>>> com.ibm.msg.client.commonservices.j2se.NLSServices.createException(NLSServices.java:313)
>>>        at
>>> com.ibm.msg.client.commonservices.nls.NLSServices.createException(NLSServices.java:390)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsErrorUtils.createException(JmsErrorUtils.java:104)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsMessageImpl.checkSettablePropertyName(JmsMessageImpl.java:1968)
>>>        at
>>> com.ibm.msg.client.jms.internal.JmsMessageImpl.setObjectProperty(JmsMessageImpl.java:1502)
>>>        at com.ibm.jms.JMSMessage.setObjectProperty(JMSMessage.java:1421)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.appendJmsProperty(JmsBinding.java:336)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.appendJmsProperties(JmsBinding.java:300)
>>>        at
>>> org.apache.camel.component.jms.JmsBinding.makeJmsMessage(JmsBinding.java:278)
>>>        at
>>> org.apache.camel.component.jms.JmsProducer$2.createMessage(JmsProducer.java:316)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.doSendToDestination(JmsConfiguration.java:221)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate.access$100(JmsConfiguration.java:164)
>>>        at
>>> org.apache.camel.component.jms.JmsConfiguration$CamelJmsTemplate$3.doInJms(JmsConfiguration.java:198)
>>>        at
>>> org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:471)
>>>
>>> --
>>> View this message in context:
>>> http://old.nabble.com/jmsbinding-problem-tp28620489p28620489.html
>>> Sent from the Camel - Users mailing list archive at Nabble.com.
>>>
>>>
>>
>>
>>
>> --
>> Claus Ibsen
>> Apache Camel Committer
>>
>> Author of Camel in Action: http://www.manning.com/ibsen/
>> Open Source Integration: http://fusesource.com
>> Blog: http://davsclaus.blogspot.com/
>> Twitter: http://twitter.com/davsclaus
>>
> 
> 
> 
> -- 
> Claus Ibsen
> Apache Camel Committer
> 
> Author of Camel in Action: http://www.manning.com/ibsen/
> Open Source Integration: http://fusesource.com
> Blog: http://davsclaus.blogspot.com/
> Twitter: http://twitter.com/davsclaus
> 
> 

-- 
View this message in context: 
http://old.nabble.com/jmsbinding-problem-tp28620489p28636748.html
Sent from the Camel - Users mailing list archive at Nabble.com.

Reply via email to