Browse Source
This commit introduces MessagingExceptionTranslator, a messaging exception translation infrastructure similar to what PersistenceExceptionTranslator provides. JmsMessagingTemplate does not throw raw JmsException anymore but translates those to an instance of Spring's MessagingException hierarchy. Issue: SPR-12038pull/602/merge
Stephane Nicoll
10 years ago
5 changed files with 319 additions and 15 deletions
@ -0,0 +1,56 @@
@@ -0,0 +1,56 @@
|
||||
/* |
||||
* Copyright 2002-2014 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.springframework.jms.core; |
||||
|
||||
import org.springframework.jms.InvalidDestinationException; |
||||
import org.springframework.jms.JmsException; |
||||
import org.springframework.jms.support.converter.MessageConversionException; |
||||
import org.springframework.jms.support.destination.DestinationResolutionException; |
||||
import org.springframework.messaging.MessagingException; |
||||
import org.springframework.messaging.MessagingExceptionTranslator; |
||||
|
||||
/** |
||||
* {@link MessagingExceptionTranslator} capable of translating {@link JmsException} |
||||
* instances to Spring's {@link MessagingException} hierarchy. |
||||
* |
||||
* @author Stephane Nicoll |
||||
* @since 4.1 |
||||
*/ |
||||
public class JmsMessagingExceptionTranslator implements MessagingExceptionTranslator { |
||||
|
||||
@Override |
||||
public MessagingException translateExceptionIfPossible(RuntimeException ex) { |
||||
if (ex instanceof JmsException) { |
||||
return convertJmsException((JmsException) ex); |
||||
} |
||||
return null; |
||||
} |
||||
|
||||
private MessagingException convertJmsException(JmsException ex) { |
||||
if (ex instanceof DestinationResolutionException || |
||||
ex instanceof InvalidDestinationException) { |
||||
return new org.springframework.messaging.core.DestinationResolutionException(ex.getMessage(), ex); |
||||
} |
||||
if (ex instanceof MessageConversionException) { |
||||
return new org.springframework.messaging.converter.MessageConversionException(ex.getMessage(), ex); |
||||
} |
||||
|
||||
|
||||
// Fallback
|
||||
return new MessagingException(ex.getMessage(), ex); |
||||
} |
||||
} |
@ -0,0 +1,34 @@
@@ -0,0 +1,34 @@
|
||||
/* |
||||
* Copyright 2002-2014 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.springframework.jms.core; |
||||
|
||||
import org.junit.Test; |
||||
|
||||
import static org.junit.Assert.*; |
||||
|
||||
/** |
||||
* @author Stephane Nicoll |
||||
*/ |
||||
public class JmsMessagingExceptionTranslatorTests { |
||||
|
||||
private final JmsMessagingExceptionTranslator translator = new JmsMessagingExceptionTranslator(); |
||||
|
||||
@Test |
||||
public void translateNonJmsException() { |
||||
assertNull(translator.translateExceptionIfPossible(new NullPointerException())); |
||||
} |
||||
} |
@ -0,0 +1,44 @@
@@ -0,0 +1,44 @@
|
||||
/* |
||||
* Copyright 2002-2014 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.springframework.messaging; |
||||
|
||||
/** |
||||
* Interface implemented by Spring integrations with messaging technologies |
||||
* that throw runtime exceptions, such as JMS, STOMP and AMQP. |
||||
* |
||||
* <p>This allows consistent usage of combined exception translation functionality, |
||||
* without forcing a single translator to understand every single possible type |
||||
* of exception. |
||||
* |
||||
* @author Stephane Nicoll |
||||
* @since 4.1 |
||||
*/ |
||||
public interface MessagingExceptionTranslator { |
||||
|
||||
/** |
||||
* Translate the given runtime exception thrown by a messaging implementation |
||||
* to a corresponding exception from Spring's generic {@link MessagingException} |
||||
* hierarchy, if possible. |
||||
* <p>Do not translate exceptions that are not understand by this translator: |
||||
* for example, if resulting from user code and unrelated to messaging. |
||||
* @param ex a RuntimeException thrown |
||||
* @return the corresponding MessagingException (or {@code null} if the |
||||
* exception could not be translated, as in this case it may result from |
||||
* user code rather than an actual messaging problem) |
||||
*/ |
||||
MessagingException translateExceptionIfPossible(RuntimeException ex); |
||||
} |
Loading…
Reference in new issue