/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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.apache.camel.processor; import org.apache.camel.ContextTestSupport; import org.apache.camel.Exchange; import org.apache.camel.Processor; import org.apache.camel.builder.RouteBuilder; /** * Unit test to verify that redelivery counters is working as expected. */ public class DeadLetterChannelRedeliveryTest extends ContextTestSupport { private static int counter; private static int redeliveryCounter; public void testTwoRedeliveryTest() throws Exception { counter = 0; redeliveryCounter = 0; getMockEndpoint("mock:error").expectedMessageCount(1); template.sendBody("direct:two", "Hello World"); assertMockEndpointsSatisfied(); assertEquals(3, counter); // One call + 2 re-deliveries assertEquals(2, redeliveryCounter); // 2 re-deliveries } public void testNoRedeliveriesTest() throws Exception { counter = 0; redeliveryCounter = 0; getMockEndpoint("mock:error").expectedMessageCount(1); template.sendBody("direct:no", "Hello World"); assertMockEndpointsSatisfied(); assertEquals(1, counter); // One call assertEquals(0, redeliveryCounter); // no redeliveries } public void testOneRedeliveriesTest() throws Exception { counter = 0; redeliveryCounter = 0; getMockEndpoint("mock:error").expectedMessageCount(1); template.sendBody("direct:one", "Hello World"); assertMockEndpointsSatisfied(); assertEquals(2, counter); // One call + 1 redelivery assertEquals(1, redeliveryCounter); // 1 redelivery } @Override protected RouteBuilder createRouteBuilder() throws Exception { return new RouteBuilder() { public void configure() throws Exception { from("direct:two") .errorHandler(deadLetterChannel("mock:error").maximumRedeliveries(2).redeliveryDelay(0) .onRedelivery(new Processor() { @Override public void process(Exchange exchange) throws Exception { redeliveryCounter = exchange.getIn().getHeader(Exchange.REDELIVERY_COUNTER, Integer.class); } })) // route start here .process(new Processor() { public void process(Exchange exchange) throws Exception { counter++; throw new Exception("Forced exception by unit test"); } }); from("direct:no") .errorHandler(deadLetterChannel("mock:error").maximumRedeliveries(0) .onRedelivery(new Processor() { @Override public void process(Exchange exchange) throws Exception { redeliveryCounter = exchange.getIn().getHeader(Exchange.REDELIVERY_COUNTER, Integer.class); } })) // route start here .process(new Processor() { public void process(Exchange exchange) throws Exception { counter++; throw new Exception("Forced exception by unit test"); } }); from("direct:one") .errorHandler(deadLetterChannel("mock:error").maximumRedeliveries(1).redeliveryDelay(0) .onRedelivery(new Processor() { @Override public void process(Exchange exchange) throws Exception { redeliveryCounter = exchange.getIn().getHeader(Exchange.REDELIVERY_COUNTER, Integer.class); } })) // route start here .process(new Processor() { public void process(Exchange exchange) throws Exception { counter++; throw new Exception("Forced exception by unit test"); } }); } }; } }