blob: 12f8a909fd009c23fd2657c6b66c60a629e3eb09 [file] [log] [blame]
/*
* Copyright 1999, 2000, 2001 ,2004 The Apache Software Foundation.
*
* Licensed 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.tester;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
/**
* Test to insure that an included servlet can set request attributes that are
* visible to the calling servlet after the <code>include()</code> returns.
* The spec is silent on this topic, but it seems consistent with the overall
* intent to behave in this manner.
*
* The test includes either a servlet ("/Include03a") or a JSP page
* ("/Include03b.jsp") depending on the value specified for the "path"
* parameter. The default is the servlet.
*
* @author Craig R. McClanahan
* @version $Revision$ $Date$
*/
public class Include03 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();
response.setContentType("text/plain");
PrintWriter writer = response.getWriter();
// Acquire the path to which we will issue an include
String path = request.getParameter("path");
if (path == null)
path = "/Include03a";
// Create a request dispatcher and call include() on it
RequestDispatcher rd =
getServletContext().getRequestDispatcher(path);
if (rd == null) {
sb.append(" No RequestDispatcher returned/");
} else {
rd.include(request, response);
}
response.resetBuffer();
// We MUST be able to see the attribute created by the includee
String value = null;
try {
value = (String)
request.getAttribute(path.substring(1));
} catch (ClassCastException e) {
sb.append(" Returned attribute not of type String/");
}
if ((sb.length() < 1) && (value == null)) {
sb.append(" No includee-created attribute was returned/");
}
// We MUST NOT see the special attributes created by the container
for (int i = 0; i < specials.length; i++) {
if (request.getAttribute(specials[i]) != null) {
sb.append(" Returned attribute ");
sb.append(specials[i]);
sb.append("/");
}
}
// Write our response
if (sb.length() < 1)
writer.println("Include03 PASSED");
else {
writer.print("Include03 FAILED -");
writer.println(sb.toString());
}
while (true) {
String message = StaticLogger.read();
if (message == null)
break;
writer.println(message);
}
StaticLogger.reset();
}
}