Updated Branches:
  refs/heads/camel-2.12.x df567f9c2 -> 20671d6ea

CAMEL-7073: Overwrite org.restlet.http.headers in response instead of adding to 
it.


Project: http://git-wip-us.apache.org/repos/asf/camel/repo
Commit: http://git-wip-us.apache.org/repos/asf/camel/commit/20671d6e
Tree: http://git-wip-us.apache.org/repos/asf/camel/tree/20671d6e
Diff: http://git-wip-us.apache.org/repos/asf/camel/diff/20671d6e

Branch: refs/heads/camel-2.12.x
Commit: 20671d6eacbf227baf8eaf43b09727fedac9beb4
Parents: df567f9
Author: David Keen <dkk...@gmail.com>
Authored: Mon Dec 16 15:43:49 2013 +0000
Committer: Willem Jiang <willem.ji...@gmail.com>
Committed: Tue Dec 17 10:56:30 2013 +0800

----------------------------------------------------------------------
 .../restlet/DefaultRestletBinding.java          |  3 +-
 .../component/restlet/RestletPostFormTest.java  | 72 ++++++++++++++++++++
 2 files changed, 73 insertions(+), 2 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/camel/blob/20671d6e/components/camel-restlet/src/main/java/org/apache/camel/component/restlet/DefaultRestletBinding.java
----------------------------------------------------------------------
diff --git 
a/components/camel-restlet/src/main/java/org/apache/camel/component/restlet/DefaultRestletBinding.java
 
b/components/camel-restlet/src/main/java/org/apache/camel/component/restlet/DefaultRestletBinding.java
index ddbff14..ebef445 100644
--- 
a/components/camel-restlet/src/main/java/org/apache/camel/component/restlet/DefaultRestletBinding.java
+++ 
b/components/camel-restlet/src/main/java/org/apache/camel/component/restlet/DefaultRestletBinding.java
@@ -274,8 +274,7 @@ public class DefaultRestletBinding implements 
RestletBinding, HeaderFilterStrate
 
         // set HTTP headers so we return these in the response
         if (!series.isEmpty()) {
-            Series<Header> httpHeaders = (Series<Header>) 
response.getAttributes().get(HeaderConstants.ATTRIBUTE_HEADERS);
-            httpHeaders.addAll(series);
+            response.getAttributes().put(HeaderConstants.ATTRIBUTE_HEADERS, 
series);
         }
     }
 

http://git-wip-us.apache.org/repos/asf/camel/blob/20671d6e/components/camel-restlet/src/test/java/org/apache/camel/component/restlet/RestletPostFormTest.java
----------------------------------------------------------------------
diff --git 
a/components/camel-restlet/src/test/java/org/apache/camel/component/restlet/RestletPostFormTest.java
 
b/components/camel-restlet/src/test/java/org/apache/camel/component/restlet/RestletPostFormTest.java
new file mode 100644
index 0000000..41f05e6
--- /dev/null
+++ 
b/components/camel-restlet/src/test/java/org/apache/camel/component/restlet/RestletPostFormTest.java
@@ -0,0 +1,72 @@
+/**
+ * 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.component.restlet;
+
+import org.apache.camel.Exchange;
+import org.apache.camel.Processor;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.http.HttpResponse;
+import org.apache.http.NameValuePair;
+import org.apache.http.client.entity.UrlEncodedFormEntity;
+import org.apache.http.client.methods.HttpEntityEnclosingRequestBase;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.client.methods.HttpUriRequest;
+import org.apache.http.entity.StringEntity;
+import org.apache.http.message.BasicNameValuePair;
+import org.junit.Test;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ *
+ * @version 
+ */
+public class RestletPostFormTest extends RestletTestSupport {
+
+    @Override
+    protected RouteBuilder createRouteBuilder() {
+
+        return new RouteBuilder() {
+            @Override
+            public void configure() throws Exception {
+                from("restlet:http://localhost:"; + portNum + 
"/users?restletMethod=POST")
+                    .process(new PostProcessor());
+            }
+        };
+    }
+    
+    class PostProcessor implements Processor {
+        public void process(Exchange exchange) throws Exception {   
+            assertEquals("bar", exchange.getIn().getHeader("foo", 
String.class));
+        }
+    }
+    
+    @Test
+    public void testPostBody() throws Exception {
+        HttpUriRequest method = new HttpPost("http://localhost:"; + portNum + 
"/users");
+
+        List<NameValuePair> urlParameters = new ArrayList<NameValuePair>();
+        urlParameters.add(new BasicNameValuePair("foo", "bar"));
+
+        ((HttpEntityEnclosingRequestBase)method).setEntity(new 
UrlEncodedFormEntity(urlParameters));
+
+        HttpResponse response = doExecute(method);
+        
+        assertHttpResponse(response, 200, "text/plain");
+    }
+}
\ No newline at end of file

Reply via email to