Return-Path: Delivered-To: apmail-camel-commits-archive@www.apache.org Received: (qmail 2490 invoked from network); 13 Aug 2009 08:24:41 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (140.211.11.3) by minotaur.apache.org with SMTP; 13 Aug 2009 08:24:41 -0000 Received: (qmail 33773 invoked by uid 500); 13 Aug 2009 08:24:48 -0000 Delivered-To: apmail-camel-commits-archive@camel.apache.org Received: (qmail 33721 invoked by uid 500); 13 Aug 2009 08:24:48 -0000 Mailing-List: contact commits-help@camel.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@camel.apache.org Delivered-To: mailing list commits@camel.apache.org Received: (qmail 33712 invoked by uid 99); 13 Aug 2009 08:24:48 -0000 Received: from nike.apache.org (HELO nike.apache.org) (192.87.106.230) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 13 Aug 2009 08:24:48 +0000 X-ASF-Spam-Status: No, hits=-2000.0 required=10.0 tests=ALL_TRUSTED X-Spam-Check-By: apache.org Received: from [140.211.11.4] (HELO eris.apache.org) (140.211.11.4) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 13 Aug 2009 08:24:37 +0000 Received: by eris.apache.org (Postfix, from userid 65534) id EDB212388872; Thu, 13 Aug 2009 08:24:15 +0000 (UTC) Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: svn commit: r803805 - in /camel/trunk/components/camel-servlet: ./ src/main/java/org/apache/camel/component/servlet/ src/test/java/org/apache/camel/component/servlet/ src/test/resources/org/apache/camel/component/servlet/ Date: Thu, 13 Aug 2009 08:24:15 -0000 To: commits@camel.apache.org From: ningjiang@apache.org X-Mailer: svnmailer-1.0.8 Message-Id: <20090813082415.EDB212388872@eris.apache.org> X-Virus-Checked: Checked by ClamAV on apache.org Author: ningjiang Date: Thu Aug 13 08:24:15 2009 New Revision: 803805 URL: http://svn.apache.org/viewvc?rev=803805&view=rev Log: CAMEL-1910 CamelHttpTransportServlet supports to init the camel context itself Added: camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java (with props) camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml (with props) camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml (with props) Modified: camel/trunk/components/camel-servlet/pom.xml camel/trunk/components/camel-servlet/src/main/java/org/apache/camel/component/servlet/CamelHttpTransportServlet.java camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteTest.java camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/ServletCamelRouterTestSupport.java Modified: camel/trunk/components/camel-servlet/pom.xml URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/pom.xml?rev=803805&r1=803804&r2=803805&view=diff ============================================================================== --- camel/trunk/components/camel-servlet/pom.xml (original) +++ camel/trunk/components/camel-servlet/pom.xml Thu Aug 13 08:24:15 2009 @@ -55,5 +55,21 @@ test + + + + + maven-surefire-plugin + + pertest + false + true + + **/*Test.* + + + + + Modified: camel/trunk/components/camel-servlet/src/main/java/org/apache/camel/component/servlet/CamelHttpTransportServlet.java URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/src/main/java/org/apache/camel/component/servlet/CamelHttpTransportServlet.java?rev=803805&r1=803804&r2=803805&view=diff ============================================================================== --- camel/trunk/components/camel-servlet/src/main/java/org/apache/camel/component/servlet/CamelHttpTransportServlet.java (original) +++ camel/trunk/components/camel-servlet/src/main/java/org/apache/camel/component/servlet/CamelHttpTransportServlet.java Thu Aug 13 08:24:15 2009 @@ -26,11 +26,14 @@ import org.apache.camel.component.http.CamelServlet; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; +import org.springframework.context.support.AbstractApplicationContext; +import org.springframework.context.support.ClassPathXmlApplicationContext; public class CamelHttpTransportServlet extends CamelServlet { private static final transient Log LOG = LogFactory.getLog(CamelHttpTransportServlet.class); private static final Map CAMEL_SERVLET_MAP = new ConcurrentHashMap(); private String servletName; + private AbstractApplicationContext applicationContext; public CamelHttpTransportServlet() { super(false); @@ -43,6 +46,18 @@ this.setMatchOnUriPrefix(Boolean.valueOf(matchOnUriPrefix)); // parser the servlet init parameters CAMEL_SERVLET_MAP.put(servletName, this); + String contextConfigLocation = config.getInitParameter("contextConfigLocation"); + if (contextConfigLocation != null) { + //Create a spring application context for it + applicationContext = new ClassPathXmlApplicationContext(new String[]{contextConfigLocation}); + } + } + + public void destroy() { + CAMEL_SERVLET_MAP.remove(servletName); + if (applicationContext != null) { + applicationContext.stop(); + } } public static CamelServlet getCamelServlet(String servletName) { Added: camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java?rev=803805&view=auto ============================================================================== --- camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java (added) +++ camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java Thu Aug 13 08:24:15 2009 @@ -0,0 +1,32 @@ +/** + * 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.servlet; + +import org.junit.Before; + +public class HttpClientRouteSpringTest extends HttpClientRouteTest { + @Before + public void setUp() throws Exception { + startCamelContext = false; + super.setUp(); + } + + protected String getConfiguration() { + return "/org/apache/camel/component/servlet/web-spring.xml"; + } + +} Propchange: camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java ------------------------------------------------------------------------------ svn:eol-style = native Propchange: camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteSpringTest.java ------------------------------------------------------------------------------ svn:keywords = Rev Date Modified: camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteTest.java URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteTest.java?rev=803805&r1=803804&r2=803805&view=diff ============================================================================== --- camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteTest.java (original) +++ camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/HttpClientRouteTest.java Thu Aug 13 08:24:15 2009 @@ -54,27 +54,32 @@ assertEquals("The response message is wrong ", "OK", response.getResponseMessage()); client.setExceptionsThrownOnErrorStatus(false); } + + public static class MyServletRoute extends RouteBuilder { + + @Override + public void configure() throws Exception { + errorHandler(noErrorHandler()); + // START SNIPPET: route + from("servlet:///hello").process(new Processor() { + public void process(Exchange exchange) throws Exception { + String contentType = exchange.getIn().getHeader(Exchange.CONTENT_TYPE, String.class); + String path = exchange.getIn().getHeader(Exchange.HTTP_PATH, String.class); + assertEquals("Get a wrong content type", CONTENT_TYPE, contentType); + String charsetEncoding = exchange.getIn().getHeader(Exchange.HTTP_CHARACTER_ENCODING, String.class); + assertEquals("Get a wrong charset name", "UTF-8", charsetEncoding); + exchange.getOut().setHeader(Exchange.CONTENT_TYPE, contentType + "; charset=UTF-8"); + exchange.getOut().setHeader("PATH", path); + exchange.getOut().setBody("Hello World"); + } + }); + // END SNIPPET: route + } + + } protected RouteBuilder createRouteBuilder() throws Exception { - return new RouteBuilder() { - public void configure() { - errorHandler(noErrorHandler()); - // START SNIPPET: route - from("servlet:///hello").process(new Processor() { - public void process(Exchange exchange) throws Exception { - String contentType = exchange.getIn().getHeader(Exchange.CONTENT_TYPE, String.class); - String path = exchange.getIn().getHeader(Exchange.HTTP_PATH, String.class); - assertEquals("Get a wrong content type", CONTENT_TYPE, contentType); - String charsetEncoding = exchange.getIn().getHeader(Exchange.HTTP_CHARACTER_ENCODING, String.class); - assertEquals("Get a wrong charset name", "UTF-8", charsetEncoding); - exchange.getOut().setHeader(Exchange.CONTENT_TYPE, contentType + "; charset=UTF-8"); - exchange.getOut().setHeader("PATH", path); - exchange.getOut().setBody("Hello World"); - } - }); - // END SNIPPET: route - } - }; + return new MyServletRoute(); } Modified: camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/ServletCamelRouterTestSupport.java URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/ServletCamelRouterTestSupport.java?rev=803805&r1=803804&r2=803805&view=diff ============================================================================== --- camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/ServletCamelRouterTestSupport.java (original) +++ camel/trunk/components/camel-servlet/src/test/java/org/apache/camel/component/servlet/ServletCamelRouterTestSupport.java Thu Aug 13 08:24:15 2009 @@ -28,12 +28,14 @@ import com.meterware.servletunit.ServletRunner; import com.meterware.servletunit.ServletUnitClient; import org.apache.camel.test.junit4.CamelTestSupport; +import org.junit.After; import org.junit.Before; public class ServletCamelRouterTestSupport extends CamelTestSupport { public static final String CONTEXT = "/mycontext"; public static final String CONTEXT_URL = "http://localhost/mycontext"; protected ServletRunner sr; + protected boolean startCamelContext = true; @Before public void setUp() throws Exception { @@ -44,8 +46,16 @@ loadServlets(); HttpUnitOptions.setExceptionsThrownOnErrorStatus(true); - - super.setUp(); + if (startCamelContext) { + super.setUp(); + } + } + + @After + public void tearDown() throws Exception { + if (startCamelContext) { + super.tearDown(); + } } protected void loadServlets() throws Exception { Added: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml?rev=803805&view=auto ============================================================================== --- camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml (added) +++ camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml Thu Aug 13 08:24:15 2009 @@ -0,0 +1,33 @@ + + + + + + + + + + + + \ No newline at end of file Propchange: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml ------------------------------------------------------------------------------ svn:eol-style = native Propchange: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml ------------------------------------------------------------------------------ svn:keywords = Rev Date Propchange: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/camelContext.xml ------------------------------------------------------------------------------ svn:mime-type = text/xml Added: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml URL: http://svn.apache.org/viewvc/camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml?rev=803805&view=auto ============================================================================== --- camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml (added) +++ camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml Thu Aug 13 08:24:15 2009 @@ -0,0 +1,50 @@ + + + + + + + + + + CamelServlet + Camel Http Transport Servlet + + org.apache.camel.component.servlet.CamelHttpTransportServlet + + + matchOnUriPrefix + true + + + contextConfigLocation + /org/apache/camel/component/servlet/camelContext.xml + + + + + CamelServlet + /services/* + + + + \ No newline at end of file Propchange: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml ------------------------------------------------------------------------------ svn:eol-style = native Propchange: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml ------------------------------------------------------------------------------ svn:keywords = Rev Date Propchange: camel/trunk/components/camel-servlet/src/test/resources/org/apache/camel/component/servlet/web-spring.xml ------------------------------------------------------------------------------ svn:mime-type = text/xml