Author: davsclaus Date: Sun Mar 3 07:30:12 2013 New Revision: 1452014 URL: http://svn.apache.org/r1452014 Log: CAMEL-6105: Direct component will throw specific exception if no direct consumer is available to process the Exchange. Thanks to Aaron Whiteside for the patch.
Added: camel/branches/camel-2.10.x/camel-core/src/main/java/org/apache/camel/component/direct/DirectConsumerNotAvailableException.java - copied unchanged from r1452013, camel/trunk/camel-core/src/main/java/org/apache/camel/component/direct/DirectConsumerNotAvailableException.java Modified: camel/branches/camel-2.10.x/ (props changed) camel/branches/camel-2.10.x/camel-core/src/main/java/org/apache/camel/component/direct/DirectProducer.java camel/branches/camel-2.10.x/camel-core/src/test/java/org/apache/camel/component/direct/SendToNonExistingDirectEndpointTest.java Propchange: camel/branches/camel-2.10.x/ ------------------------------------------------------------------------------ Merged /camel/trunk:r1452013 Propchange: camel/branches/camel-2.10.x/ ------------------------------------------------------------------------------ Binary property 'svnmerge-integrated' - no diff available. Modified: camel/branches/camel-2.10.x/camel-core/src/main/java/org/apache/camel/component/direct/DirectProducer.java URL: http://svn.apache.org/viewvc/camel/branches/camel-2.10.x/camel-core/src/main/java/org/apache/camel/component/direct/DirectProducer.java?rev=1452014&r1=1452013&r2=1452014&view=diff ============================================================================== --- camel/branches/camel-2.10.x/camel-core/src/main/java/org/apache/camel/component/direct/DirectProducer.java (original) +++ camel/branches/camel-2.10.x/camel-core/src/main/java/org/apache/camel/component/direct/DirectProducer.java Sun Mar 3 07:30:12 2013 @@ -18,7 +18,6 @@ package org.apache.camel.component.direc import org.apache.camel.AsyncCallback; import org.apache.camel.AsyncProcessor; -import org.apache.camel.CamelExchangeException; import org.apache.camel.Exchange; import org.apache.camel.impl.DefaultAsyncProducer; import org.apache.camel.util.AsyncProcessorConverterHelper; @@ -43,7 +42,7 @@ public class DirectProducer extends Defa public void process(Exchange exchange) throws Exception { if (endpoint.getConsumer() == null) { LOG.warn("No consumers available on endpoint: " + endpoint + " to process: " + exchange); - throw new CamelExchangeException("No consumers available on endpoint: " + endpoint, exchange); + throw new DirectConsumerNotAvailableException("No consumers available on endpoint: " + endpoint, exchange); } else { endpoint.getConsumer().getProcessor().process(exchange); } @@ -53,7 +52,7 @@ public class DirectProducer extends Defa if (endpoint.getConsumer() == null) { LOG.warn("No consumers available on endpoint: " + endpoint + " to process: " + exchange); // indicate its done synchronously - exchange.setException(new CamelExchangeException("No consumers available on endpoint: " + endpoint, exchange)); + exchange.setException(new DirectConsumerNotAvailableException("No consumers available on endpoint: " + endpoint, exchange)); callback.done(true); return true; } else { Modified: camel/branches/camel-2.10.x/camel-core/src/test/java/org/apache/camel/component/direct/SendToNonExistingDirectEndpointTest.java URL: http://svn.apache.org/viewvc/camel/branches/camel-2.10.x/camel-core/src/test/java/org/apache/camel/component/direct/SendToNonExistingDirectEndpointTest.java?rev=1452014&r1=1452013&r2=1452014&view=diff ============================================================================== --- camel/branches/camel-2.10.x/camel-core/src/test/java/org/apache/camel/component/direct/SendToNonExistingDirectEndpointTest.java (original) +++ camel/branches/camel-2.10.x/camel-core/src/test/java/org/apache/camel/component/direct/SendToNonExistingDirectEndpointTest.java Sun Mar 3 07:30:12 2013 @@ -35,7 +35,8 @@ public class SendToNonExistingDirectEndp template.sendBody("direct:foo", "Hello World"); fail("Should have thrown exception"); } catch (CamelExecutionException e) { - CamelExchangeException cause = assertIsInstanceOf(CamelExchangeException.class, e.getCause()); + DirectConsumerNotAvailableException cause = assertIsInstanceOf(DirectConsumerNotAvailableException.class, e.getCause()); + assertIsInstanceOf(CamelExchangeException.class, cause); // ensure backwards compatibility assertEquals("No consumers available on endpoint: Endpoint[direct://foo]. Exchange[Message: Hello World]", cause.getMessage()); assertNotNull(cause.getExchange()); }