From c4e77feefa19c8e6ed069f088456691a43bd9dff Mon Sep 17 00:00:00 2001 From: Greg Wilkins Date: Tue, 15 Jan 2013 15:53:54 +1100 Subject: [PATCH 1/2] unit test uses fake JSP --- .../jetty/test/jsp/FakeJspServlet.java | 65 +++++++++++++++++++ .../jsp/JspAndDefaultWithAliasesTest.java | 7 +- .../jsp/JspAndDefaultWithoutAliasesTest.java | 3 +- 3 files changed, 73 insertions(+), 2 deletions(-) create mode 100644 tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/FakeJspServlet.java diff --git a/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/FakeJspServlet.java b/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/FakeJspServlet.java new file mode 100644 index 00000000000..2397faec6ca --- /dev/null +++ b/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/FakeJspServlet.java @@ -0,0 +1,65 @@ +// +// ======================================================================== +// Copyright (c) 1995-2013 Mort Bay Consulting Pty. Ltd. +// ------------------------------------------------------------------------ +// All rights reserved. This program and the accompanying materials +// are made available under the terms of the Eclipse Public License v1.0 +// and Apache License v2.0 which accompanies this distribution. +// +// The Eclipse Public License is available at +// http://www.eclipse.org/legal/epl-v10.html +// +// The Apache License v2.0 is available at +// http://www.opensource.org/licenses/apache2.0.php +// +// You may elect to redistribute this code under either of these licenses. +// ======================================================================== +// + +package org.eclipse.jetty.test.jsp; + +import java.io.File; +import java.io.IOException; +import java.net.URISyntaxException; +import java.net.URL; + +import javax.servlet.ServletException; +import javax.servlet.http.HttpServlet; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; + +public class FakeJspServlet extends HttpServlet +{ + + /* ------------------------------------------------------------ */ + /* + * @see javax.servlet.http.HttpServlet#doGet(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) + */ + protected void doGet(HttpServletRequest req, HttpServletResponse response) throws ServletException, IOException + { + String path = req.getServletPath(); + URL url =getServletContext().getResource(path); + if (url==null) + { + response.sendError(404); + return; + } + + try + { + File file=new File(url.toURI()); + if (file.exists()) + { + response.sendError(200,"fake JSP response"); + return; + } + } + catch (Exception e) + { + e.printStackTrace(); + } + + response.sendError(404); + } + +} diff --git a/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithAliasesTest.java b/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithAliasesTest.java index 6dc439d017f..019a3c70030 100644 --- a/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithAliasesTest.java +++ b/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithAliasesTest.java @@ -34,6 +34,7 @@ import org.eclipse.jetty.security.HashLoginService; import org.eclipse.jetty.server.Server; import org.eclipse.jetty.server.nio.SelectChannelConnector; import org.eclipse.jetty.servlet.DefaultServlet; +import org.eclipse.jetty.servlet.NoJspServlet; import org.eclipse.jetty.servlet.ServletContextHandler; import org.eclipse.jetty.servlet.ServletHolder; import org.eclipse.jetty.toolchain.test.MavenTestingUtils; @@ -106,7 +107,8 @@ public class JspAndDefaultWithAliasesTest defaultServHolder.setInitParameter("aliases","true"); // important! must be TRUE // add jsp - ServletHolder jsp = context.addServlet(JspServlet.class,"*.jsp"); + ServletHolder jsp = new ServletHolder(new FakeJspServlet()); + context.addServlet(jsp,"*.jsp"); jsp.setInitParameter("classpath",context.getClassPath()); // add context @@ -157,6 +159,9 @@ public class JspAndDefaultWithAliasesTest return; } + if (conn.getResponseCode()!=404) + System.err.println(conn.getResponseMessage()); + // Of other possible paths, only 404 Not Found is expected Assert.assertThat("Response Code",conn.getResponseCode(),is(404)); } diff --git a/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithoutAliasesTest.java b/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithoutAliasesTest.java index 8ff51609240..3a82d88b4c5 100644 --- a/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithoutAliasesTest.java +++ b/tests/test-integration/src/test/java/org/eclipse/jetty/test/jsp/JspAndDefaultWithoutAliasesTest.java @@ -106,7 +106,8 @@ public class JspAndDefaultWithoutAliasesTest defaultServHolder.setInitParameter("aliases","false"); // important! must be FALSE // add jsp - ServletHolder jsp = context.addServlet(JspServlet.class,"*.jsp"); + ServletHolder jsp = new ServletHolder(new FakeJspServlet()); + context.addServlet(jsp,"*.jsp"); jsp.setInitParameter("classpath",context.getClassPath()); // add context From 747eeb87c1d33e7646747a6c2f03ae4ae23b429b Mon Sep 17 00:00:00 2001 From: Greg Wilkins Date: Thu, 17 Jan 2013 09:04:04 +1100 Subject: [PATCH 2/2] 398337 UTF-16 percent encoding in UTF-16 form content --- .../main/java/org/eclipse/jetty/util/UrlEncoded.java | 2 +- .../java/org/eclipse/jetty/util/URLEncodedTest.java | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/UrlEncoded.java b/jetty-util/src/main/java/org/eclipse/jetty/util/UrlEncoded.java index 3e3ab8441f6..6824efcdd34 100644 --- a/jetty-util/src/main/java/org/eclipse/jetty/util/UrlEncoded.java +++ b/jetty-util/src/main/java/org/eclipse/jetty/util/UrlEncoded.java @@ -580,7 +580,7 @@ public class UrlEncoded extends MultiMap implements Cloneable StringWriter buf = new StringWriter(8192); IO.copy(input,buf,maxLength); - decodeTo(buf.getBuffer().toString(),map,ENCODING,maxKeys); + decodeTo(buf.getBuffer().toString(),map,StringUtil.__UTF16,maxKeys); } /* -------------------------------------------------------------- */ diff --git a/jetty-util/src/test/java/org/eclipse/jetty/util/URLEncodedTest.java b/jetty-util/src/test/java/org/eclipse/jetty/util/URLEncodedTest.java index 64195a3d702..d9b69a85fb9 100644 --- a/jetty-util/src/test/java/org/eclipse/jetty/util/URLEncodedTest.java +++ b/jetty-util/src/test/java/org/eclipse/jetty/util/URLEncodedTest.java @@ -174,16 +174,16 @@ public class URLEncodedTest { String [][] charsets = new String[][] { - {StringUtil.__UTF8,null}, - {StringUtil.__ISO_8859_1,StringUtil.__ISO_8859_1}, - {StringUtil.__UTF8,StringUtil.__UTF8}, - {StringUtil.__UTF16,StringUtil.__UTF16}, + {StringUtil.__UTF8,null,"%30"}, + {StringUtil.__ISO_8859_1,StringUtil.__ISO_8859_1,"%30"}, + {StringUtil.__UTF8,StringUtil.__UTF8,"%30"}, + {StringUtil.__UTF16,StringUtil.__UTF16,"%00%30"}, }; for (int i=0;i