Author: davsclaus
Date: Fri Jun  5 06:42:31 2009
New Revision: 781923

URL: http://svn.apache.org/viewvc?rev=781923&view=rev
Log:
Added unit test based on user forum trouble with splitter.

Added:
    
camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java
   (with props)
Modified:
    camel/trunk/camel-core/src/main/java/org/apache/camel/processor/Delayer.java

Modified: 
camel/trunk/camel-core/src/main/java/org/apache/camel/processor/Delayer.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/camel-core/src/main/java/org/apache/camel/processor/Delayer.java?rev=781923&r1=781922&r2=781923&view=diff
==============================================================================
--- 
camel/trunk/camel-core/src/main/java/org/apache/camel/processor/Delayer.java 
(original)
+++ 
camel/trunk/camel-core/src/main/java/org/apache/camel/processor/Delayer.java 
Fri Jun  5 06:42:31 2009
@@ -74,5 +74,4 @@
         return currentSystemTime();
     }
 
-
 }

Added: 
camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java
URL: 
http://svn.apache.org/viewvc/camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java?rev=781923&view=auto
==============================================================================
--- 
camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java
 (added)
+++ 
camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java
 Fri Jun  5 06:42:31 2009
@@ -0,0 +1,83 @@
+/**
+ * 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.issues;
+
+import org.apache.camel.ContextTestSupport;
+import org.apache.camel.Exchange;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.processor.aggregate.AggregationStrategy;
+import static org.apache.camel.builder.xml.XPathBuilder.xpath;
+
+/**
+ * @version $Revision$
+ */
+public class SplitWithCustomAggregationStrategyTest extends ContextTestSupport 
{
+
+    public void testSplitWithCustomAggregatorStrategy() throws Exception {
+        int files = 10;
+        MockEndpoint mock = getMockEndpoint("mock:result");
+        mock.expectedMessageCount(files);
+        // no duplicates should be received
+        mock.expectsNoDuplicates(body());
+
+        for (int i = 0; i < files; i++) {
+            template.sendBody("direct:start", "");
+        }
+
+        assertMockEndpointsSatisfied();
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() throws Exception {
+        return new RouteBuilder() {
+            @Override
+            public void configure() throws Exception {
+                from("direct:start").
+                        
setBody().simple("<search><key>foo-${id}</key><key>bar-${id}</key><key>baz-${id}</key></search>").
+                        to("direct:splitInOut").
+                        to("mock:result");
+
+                //
+                // Need an inOut splitter that aggregates all results together.
+                //
+                from("direct:splitInOut").
+                        setHeader("com.example.id").simple("${id}").
+                        split(xpath("/search/key"), new AggregationStrategy() {
+                            public Exchange aggregate(Exchange oldExchange, 
Exchange newExchange) {
+                                if (oldExchange == null) {
+                                    return newExchange;
+                                }
+
+                                String oldBody = 
oldExchange.getOut().getBody(String.class);
+                                String newBody = 
newExchange.getOut().getBody(String.class);
+                                oldExchange.getOut().setBody(oldBody + 
newBody);
+
+                                return oldExchange;
+                            }
+                        }).parallelProcessing().streaming().
+                            to("direct:processLine").
+                        end().
+                        transform().simple("<results>${in.body}</results>");
+
+                from("direct:processLine").
+                        to("log:line").
+                        
transform().simple("<index>${in.header.CamelSplitIndex}</index>${in.body}");
+            }
+        };
+    }
+}

Propchange: 
camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
camel/trunk/camel-core/src/test/java/org/apache/camel/issues/SplitWithCustomAggregationStrategyTest.java
------------------------------------------------------------------------------
    svn:keywords = Rev Date


Reply via email to