PathsServlet integration test added, uses sling.servlet.paths registration mechanism

git-svn-id: https://svn.apache.org/repos/asf/sling/trunk@899629 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/PathsServletTest.java b/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/PathsServletTest.java
new file mode 100644
index 0000000..4e2f24a
--- /dev/null
+++ b/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/PathsServletTest.java
@@ -0,0 +1,46 @@
+/*
+ * 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.sling.launchpad.webapp.integrationtest.servlets.resolution;
+
+import javax.servlet.http.HttpServletResponse;
+
+import org.apache.commons.httpclient.methods.GetMethod;
+
+public class PathsServletTest extends ResolutionTestBase {
+
+    private final static String[] TEST_PATH = { 
+        "/testing/PathsServlet/foo",
+        "/testing/PathsServlet/bar/more/foo.html" 
+    };
+    
+    public void testGetCorrectPaths() throws Exception {
+        for (String path : TEST_PATH) {
+            assertServlet(getContent(HTTP_BASE_URL + path, CONTENT_TYPE_PLAIN),
+                    PATHS_SERVLET_SUFFIX);
+        }
+    }
+    
+    public void testSubpath() throws Exception {
+        final String extra = "/something";
+        for (String p : TEST_PATH) {
+            String path = p + extra;
+            GetMethod get = new GetMethod(HTTP_BASE_URL + path);
+            int status = httpClient.executeMethod(get);
+            assertFalse("Expected non-200 status for path " + path, HttpServletResponse.SC_OK == status);
+        }
+    }
+}
diff --git a/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/ResolutionTestBase.java b/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/ResolutionTestBase.java
index 02511d2..9b65068 100644
--- a/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/ResolutionTestBase.java
+++ b/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/servlets/resolution/ResolutionTestBase.java
@@ -40,6 +40,7 @@
   public static final String PREFIX_M1_SERVLET_SUFFIX = "testservices.servlets.PrefixServletMinusOne";
   public static final String PUT_SERVLET_SUFFIX = "testservices.servlets.PutMethodServlet";
   public static final String REQUEST_URI_OPTING_SERVLET_SUFFIX = "testservices.servlets.RequestUriOptingServlet";
+  public static final String PATHS_SERVLET_SUFFIX = "testservices.servlets.PathsServlet";
   
   protected TestNode testNodeNORT;
   protected TestNode testNodeRT;