diff options
Diffstat (limited to 'apache-jstl/src/test/java/org/eclipse/jetty/jstl/JstlTest.java')
-rw-r--r-- | apache-jstl/src/test/java/org/eclipse/jetty/jstl/JstlTest.java | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/apache-jstl/src/test/java/org/eclipse/jetty/jstl/JstlTest.java b/apache-jstl/src/test/java/org/eclipse/jetty/jstl/JstlTest.java new file mode 100644 index 0000000000..719965cfd0 --- /dev/null +++ b/apache-jstl/src/test/java/org/eclipse/jetty/jstl/JstlTest.java @@ -0,0 +1,97 @@ +// +// ======================================================================== +// Copyright (c) 1995-2015 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.jstl; + +import static org.hamcrest.Matchers.*; +import static org.junit.Assert.*; + +import java.io.File; +import java.io.IOException; +import java.net.URI; + +import org.eclipse.jetty.server.Server; +import org.eclipse.jetty.server.ServerConnector; +import org.eclipse.jetty.toolchain.test.FS; +import org.eclipse.jetty.toolchain.test.MavenTestingUtils; +import org.eclipse.jetty.toolchain.test.SimpleRequest; +import org.eclipse.jetty.webapp.WebAppContext; +import org.junit.AfterClass; +import org.junit.BeforeClass; +import org.junit.Ignore; +import org.junit.Test; + +public class JstlTest +{ + private static Server server; + private static URI baseUri; + + @BeforeClass + public static void startServer() throws Exception + { + // Setup Server + server = new Server(); + ServerConnector connector = new ServerConnector(server); + connector.setPort(0); + server.addConnector(connector); + + // Setup WebAppContext + File testWebAppDir = MavenTestingUtils.getProjectDir("src/test/webapp"); + + WebAppContext context = new WebAppContext(); + context.setContextPath("/"); + + File scratchDir = MavenTestingUtils.getTargetFile("tests/" + JstlTest.class.getSimpleName() + "-scratch"); + FS.ensureEmpty(scratchDir); + JspConfig.init(context,testWebAppDir.toURI(),scratchDir); + + server.setHandler(context); + + // Start Server + server.start(); + + // Figure out Base URI + String host = connector.getHost(); + if (host == null) + { + host = "localhost"; + } + int port = connector.getLocalPort(); + baseUri = new URI(String.format("http://%s:%d/",host,port)); + } + + @AfterClass + public static void stopServer() throws Exception + { + server.stop(); + } + + @Test + @Ignore("Need sanity review from Jan and/or Greg") + public void testUrlsBasic() throws IOException + { + SimpleRequest req = new SimpleRequest(baseUri); + String resp = req.getString("/urls.jsp"); + assertThat("Response should be JSP processed", resp, not(containsString("<c:url"))); + assertThat("Response", resp, containsString("[c:url value] = /ref.jsp;jsessionid=")); + assertThat("Response", resp, containsString("[c:url param] = /ref.jsp;key=value;jsessionid=")); + + System.err.println("Response:"); + System.err.println(resp); + } +} |