diff --git a/org.springframework.integration/src/test/java/org/springframework/integration/config/xml/DelayerUsageTests-context.xml b/org.springframework.integration/src/test/java/org/springframework/integration/config/xml/DelayerUsageTests-context.xml
new file mode 100644
index 0000000000..c717a1a4de
--- /dev/null
+++ b/org.springframework.integration/src/test/java/org/springframework/integration/config/xml/DelayerUsageTests-context.xml
@@ -0,0 +1,46 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/org.springframework.integration/src/test/java/org/springframework/integration/config/xml/DelayerUsageTests.java b/org.springframework.integration/src/test/java/org/springframework/integration/config/xml/DelayerUsageTests.java
new file mode 100644
index 0000000000..0fc58840ff
--- /dev/null
+++ b/org.springframework.integration/src/test/java/org/springframework/integration/config/xml/DelayerUsageTests.java
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2002-2009 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.integration.config.xml;
+
+import static org.junit.Assert.assertTrue;
+
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Qualifier;
+import org.springframework.integration.channel.PollableChannel;
+import org.springframework.integration.core.Message;
+import org.springframework.integration.core.MessageChannel;
+import org.springframework.integration.message.MessageBuilder;
+import org.springframework.integration.message.StringMessage;
+import org.springframework.test.context.ContextConfiguration;
+import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
+
+/**
+ * @author Oleg Zhurakousky
+ * @since 1.0.3
+ */
+@RunWith(SpringJUnit4ClassRunner.class)
+@ContextConfiguration
+public class DelayerUsageTests {
+
+ @Autowired @Qualifier("inputA")
+ private MessageChannel inputA;
+ @Autowired @Qualifier("outputA")
+ private PollableChannel outputA;
+
+ @Autowired @Qualifier("inputB")
+ private MessageChannel inputB;
+ @Autowired @Qualifier("outputB1")
+ private PollableChannel outputB1;
+ @Autowired
+ private SampleService sampleHandler;
+
+ @Test
+ public void testDelayWithDefaultScheduler(){
+ long start = System.currentTimeMillis();
+ inputA.send(new StringMessage("Hello"));
+ Message msg = (Message) outputA.receive();
+ assertTrue((System.currentTimeMillis() - start) >= 1000);
+ }
+ @Test
+ public void testDelayWithDefaultSchedulerCustomDelayHeader(){
+ MessageBuilder builder = MessageBuilder.withPayload("Hello");
+ // set custom delay header
+ builder.setHeader("foo", 2000);
+ long start = System.currentTimeMillis();
+ inputA.send(builder.build());
+ Message msg = (Message) outputA.receive();
+ assertTrue((System.currentTimeMillis() - start) >= 2000);
+ }
+ @Test
+ public void testDelayWithCustomScheduler(){
+ long start = System.currentTimeMillis();
+ inputB.send(new StringMessage("1"));
+ inputB.send(new StringMessage("2"));
+ inputB.send(new StringMessage("3"));
+ inputB.send(new StringMessage("4"));
+ inputB.send(new StringMessage("5"));
+ inputB.send(new StringMessage("6"));
+ inputB.send(new StringMessage("7"));
+ Message msg = (Message) outputB1.receive();
+ msg = (Message) outputB1.receive();
+ msg = (Message) outputB1.receive();
+ msg = (Message) outputB1.receive();
+ msg = (Message) outputB1.receive();
+ msg = (Message) outputB1.receive();
+ msg = (Message) outputB1.receive();
+
+ // must execute under 3 seconds, since threadPool is set too 5.
+ // first batch is 5 concurrent invocations on SA, then 2 more
+ // elapsed time for the whole execution should be a bit over 2 seconds depending on the hardware
+ assertTrue(((System.currentTimeMillis() - start) >= 1000) && ((System.currentTimeMillis() - start) < 3000));
+ }
+
+
+ public static class SampleService{
+ public String processMessage(String message) throws Exception {
+ Thread.sleep(500);
+ return message;
+ }
+ }
+}