craigmcc 01/09/17 17:08:00
Modified: tester/src/bin tester.xml
tester/web/WEB-INF web.xml
Added: tester/src/tester/org/apache/tester Include10.java
Include10a.java
Log:
Add an even more stringent unit test on RequestDispatcher.include() to
ensure that, not only are the container-created attributes listed in
Section 8.3.1 created with correct values, the original request properties
are also checked to make sure that they were not modified.
Revision Changes Path
1.69 +11 -0 jakarta-tomcat-4.0/tester/src/bin/tester.xml
Index: tester.xml
===================================================================
RCS file: /home/cvs/jakarta-tomcat-4.0/tester/src/bin/tester.xml,v
retrieving revision 1.68
retrieving revision 1.69
diff -u -r1.68 -r1.69
--- tester.xml 2001/09/12 20:26:31 1.68
+++ tester.xml 2001/09/18 00:08:00 1.69
@@ -944,6 +944,17 @@
request="${context.path}/WrappedInclude09?path=Include00c.jsp"
outContent="Include00c PASSED" debug="${debug}"/>
+ <!-- ========== Container-Created Include Attributes ================== -->
+
+ <tester host="${host}" port="${port}" protocol="${protocol}"
+ request="${context.path}/Include10/extra/path?name1=value1"
+ outContent="Include10a PASSED" debug="${debug}"/>
+
+ <tester host="${host}" port="${port}" protocol="${protocol}"
+ request="${context.path}/WrappedInclude10/extra/path?name1=value1"
+ outContent="Include10a PASSED" debug="${debug}"/>
+
+
<!-- ========== Response Wrapping ===================================== -->
<tester host="${host}" port="${port}" protocol="${protocol}"
1.1
jakarta-tomcat-4.0/tester/src/tester/org/apache/tester/Include10.java
Index: Include10.java
===================================================================
/* ========================================================================= *
* *
* The Apache Software License, Version 1.1 *
* *
* Copyright (c) 1999, 2000, 2001 The Apache Software Foundation. *
* All rights reserved. *
* *
* ========================================================================= *
* *
* Redistribution and use in source and binary forms, with or without modi- *
* fication, are permitted provided that the following conditions are met: *
* *
* 1. Redistributions of source code must retain the above copyright notice *
* notice, this list of conditions and the following disclaimer. *
* *
* 2. Redistributions in binary form must reproduce the above copyright *
* notice, this list of conditions and the following disclaimer in the *
* documentation and/or other materials provided with the distribution. *
* *
* 3. The end-user documentation included with the redistribution, if any, *
* must include the following acknowlegement: *
* *
* "This product includes software developed by the Apache Software *
* Foundation <http://www.apache.org/>." *
* *
* Alternately, this acknowlegement may appear in the software itself, if *
* and wherever such third-party acknowlegements normally appear. *
* *
* 4. The names "The Jakarta Project", "Tomcat", and "Apache Software *
* Foundation" must not be used to endorse or promote products derived *
* from this software without prior written permission. For written *
* permission, please contact <[EMAIL PROTECTED]>. *
* *
* 5. Products derived from this software may not be called "Apache" nor may *
* "Apache" appear in their names without prior written permission of the *
* Apache Software Foundation. *
* *
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES *
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY *
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL *
* THE APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY *
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL *
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS *
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) *
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, *
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN *
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE *
* POSSIBILITY OF SUCH DAMAGE. *
* *
* ========================================================================= *
* *
* This software consists of voluntary contributions made by many indivi- *
* duals on behalf of the Apache Software Foundation. For more information *
* on the Apache Software Foundation, please see <http://www.apache.org/>. *
* *
* ========================================================================= */
package org.apache.tester;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
/**
* Make sure container sets up include reques attributes.
*
* @author Craig R. McClanahan
* @version $Revision: 1.1 $ $Date: 2001/09/18 00:08:00 $
*/
public class Include10 extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
// Prepare this response
StringBuffer sb = new StringBuffer();
response.setContentType("text/plain");
PrintWriter writer = response.getWriter();
// Pass copies of the original request properties
request.setAttribute("original.request_uri",
request.getRequestURI());
request.setAttribute("original.context_path",
request.getContextPath());
request.setAttribute("original.servlet_path",
request.getServletPath());
request.setAttribute("original.path_info",
request.getPathInfo());
request.setAttribute("original.query_string",
request.getQueryString());
// Create a request dispatcher and call include() on it
RequestDispatcher rd =
getServletContext().getRequestDispatcher
("/Include10a/include/path?name2=value2");
if (rd == null) {
sb.append(" No RequestDispatcher returned/");
} else {
if (sb.length() < 1)
rd.include(request, response);
}
// Write our response if an error occurred
if (sb.length() >= 1) {
writer.print("Include00 FAILED -");
writer.println(sb.toString());
while (true) {
String message = StaticLogger.read();
if (message == null)
break;
writer.println(message);
}
}
StaticLogger.reset();
}
}
1.1
jakarta-tomcat-4.0/tester/src/tester/org/apache/tester/Include10a.java
Index: Include10a.java
===================================================================
/* ========================================================================= *
* *
* The Apache Software License, Version 1.1 *
* *
* Copyright (c) 1999, 2000, 2001 The Apache Software Foundation. *
* All rights reserved. *
* *
* ========================================================================= *
* *
* Redistribution and use in source and binary forms, with or without modi- *
* fication, are permitted provided that the following conditions are met: *
* *
* 1. Redistributions of source code must retain the above copyright notice *
* notice, this list of conditions and the following disclaimer. *
* *
* 2. Redistributions in binary form must reproduce the above copyright *
* notice, this list of conditions and the following disclaimer in the *
* documentation and/or other materials provided with the distribution. *
* *
* 3. The end-user documentation included with the redistribution, if any, *
* must include the following acknowlegement: *
* *
* "This product includes software developed by the Apache Software *
* Foundation <http://www.apache.org/>." *
* *
* Alternately, this acknowlegement may appear in the software itself, if *
* and wherever such third-party acknowlegements normally appear. *
* *
* 4. The names "The Jakarta Project", "Tomcat", and "Apache Software *
* Foundation" must not be used to endorse or promote products derived *
* from this software without prior written permission. For written *
* permission, please contact <[EMAIL PROTECTED]>. *
* *
* 5. Products derived from this software may not be called "Apache" nor may *
* "Apache" appear in their names without prior written permission of the *
* Apache Software Foundation. *
* *
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES *
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY *
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL *
* THE APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY *
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL *
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS *
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) *
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, *
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN *
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE *
* POSSIBILITY OF SUCH DAMAGE. *
* *
* ========================================================================= *
* *
* This software consists of voluntary contributions made by many indivi- *
* duals on behalf of the Apache Software Foundation. For more information *
* on the Apache Software Foundation, please see <http://www.apache.org/>. *
* *
* ========================================================================= */
package org.apache.tester;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
/**
* Ensure the correct container managed request attributes are set.
*
* @author Craig R. McClanahan
* @version $Revision: 1.1 $ $Date: 2001/09/18 00:08:00 $
*/
public class Include10a extends HttpServlet {
private static final String specials[] =
{ "javax.servlet.include.request_uri",
"javax.servlet.include.context_path",
"javax.servlet.include.servlet_path",
"javax.servlet.include.path_info",
"javax.servlet.include.query_string" };
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
// Prepare this response
StringBuffer sb = new StringBuffer();
PrintWriter writer = response.getWriter();
// Validate the original request properties
String value = null;
value = (String) request.getAttribute("original.request_uri");
if (!value.equals(request.getRequestURI()))
sb.append(" getRequestURI() is " + request.getRequestURI() +
" but should be " + value + "|");
value = (String) request.getAttribute("original.context_path");
if (!value.equals(request.getContextPath()))
sb.append(" getContextPath() is " + request.getContextPath() +
" but should be " + value + "|");
value = (String) request.getAttribute("original.servlet_path");
if (!value.equals(request.getServletPath()))
sb.append(" getServletPath() is " + request.getServletPath() +
" but should be " + value + "|");
value = (String) request.getAttribute("original.path_info");
if (!value.equals(request.getPathInfo()))
sb.append(" getPathInfo() is " + request.getPathInfo() +
" but should be " + value + "|");
value = (String) request.getAttribute("original.query_string");
if (!value.equals(request.getQueryString()))
sb.append(" getQueryString() is " + request.getQueryString() +
" but should be " + value + "|");
// Validate the container provided request attributes
value = (String)
request.getAttribute("javax.servlet.include.request_uri");
if (!(request.getContextPath() + "/Include10a/include/path").equals(value))
sb.append(" request_uri is " + value +
" but should be " + request.getContextPath() +
"/Include10a/include/path|");
value = (String)
request.getAttribute("javax.servlet.include.context_path");
if (!request.getContextPath().equals(value))
sb.append(" context_path is " + value +
" but should be " + request.getContextPath() + "|");
value = (String)
request.getAttribute("javax.servlet.include.servlet_path");
if (!"/Include10a".equals(value))
sb.append(" servlet_path is " + value +
" but should be /Include10a|");
value = (String)
request.getAttribute("javax.servlet.include.path_info");
if (!"/include/path".equals(value))
sb.append(" path_info is " + value +
" but should be /include/path|");
value = (String)
request.getAttribute("javax.servlet.include.query_string");
if (!"name2=value2".equals(value))
sb.append(" query_string is " + value +
" but should be name2=value2|");
// Generate our success or failure report
if (sb.length() < 1)
writer.println("Include10a PASSED");
else
writer.println("Include10a FAILED -" + sb.toString());
}
}
1.50 +30 -0 jakarta-tomcat-4.0/tester/web/WEB-INF/web.xml
Index: web.xml
===================================================================
RCS file: /home/cvs/jakarta-tomcat-4.0/tester/web/WEB-INF/web.xml,v
retrieving revision 1.49
retrieving revision 1.50
diff -u -r1.49 -r1.50
--- web.xml 2001/09/10 04:20:53 1.49
+++ web.xml 2001/09/18 00:08:00 1.50
@@ -295,6 +295,11 @@
<filter-mapping>
<filter-name>HttpFilter</filter-name>
+ <url-pattern>/WrappedInclude10</url-pattern>
+ </filter-mapping>
+
+ <filter-mapping>
+ <filter-name>HttpFilter</filter-name>
<url-pattern>/WrappedJndi01</url-pattern>
</filter-mapping>
@@ -812,6 +817,16 @@
</servlet>
<servlet>
+ <servlet-name>Include10</servlet-name>
+ <servlet-class>org.apache.tester.Include10</servlet-class>
+ </servlet>
+
+ <servlet>
+ <servlet-name>Include10a</servlet-name>
+ <servlet-class>org.apache.tester.Include10a</servlet-class>
+ </servlet>
+
+ <servlet>
<servlet-name>Jndi01</servlet-name>
<servlet-class>org.apache.tester.Jndi01</servlet-class>
<load-on-startup>1</load-on-startup>
@@ -1498,6 +1513,21 @@
<servlet-mapping>
<servlet-name>Include09</servlet-name>
<url-pattern>/WrappedInclude09</url-pattern>
+ </servlet-mapping>
+
+ <servlet-mapping>
+ <servlet-name>Include10</servlet-name>
+ <url-pattern>/Include10/*</url-pattern>
+ </servlet-mapping>
+
+ <servlet-mapping>
+ <servlet-name>Include10</servlet-name>
+ <url-pattern>/WrappedInclude10/*</url-pattern>
+ </servlet-mapping>
+
+ <servlet-mapping>
+ <servlet-name>Include10a</servlet-name>
+ <url-pattern>/Include10a/*</url-pattern>
</servlet-mapping>
<servlet-mapping>