Skip to content

Commit

Permalink
Merge pull request #70 from WOVNio/hotfix/internal_redirect
Browse files Browse the repository at this point in the history
Only internal redirect when urlPattern is path
  • Loading branch information
hythof authored Jul 6, 2018
2 parents 82c8ce9 + afab339 commit ee28a06
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ private void tryTranslate(Headers headers, HttpServletRequest request, ServletRe
WovnHttpServletRequest wovnRequest = new WovnHttpServletRequest(request, headers);
WovnHttpServletResponse wovnResponse = new WovnHttpServletResponse((HttpServletResponse)response);

if (headers.getPathLang().length() > 0) {
if (settings.urlPattern.equals("path") && headers.getPathLang().length() > 0) {
wovnRequest.getRequestDispatcher(headers.pathNameKeepTrailingSlash).forward(wovnRequest, wovnResponse);
} else {
chain.doFilter(wovnRequest, wovnResponse);
Expand Down
30 changes: 23 additions & 7 deletions src/test/java/com/github/wovnio/wovnjava/TestUtil.java
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,13 @@


public class TestUtil {
private static final HashMap<String, String> emptySettings = new HashMap<String, String>();
private static final HashMap<String, String> emptyOption = new HashMap<String, String>();

public static Settings makeSettings() {
return makeSettings(emptySettings);
public static FilterConfig makeConfig() {
return makeConfig(emptyOption);
}

public static Settings makeSettings(HashMap<String, String> option) {
public static FilterConfig makeConfig(HashMap<String, String> option) {
FilterConfig mock = EasyMock.createMock(FilterConfig.class);
String[] keys = {"userToken", "projectToken", "sitePrefixPath", "secretKey", "urlPattern", "urlPatternReg", "query", "apiUrl", "defaultLang", "supportedLangs", "testMode", "testUrl", "useProxy", "debugMode", "originalUrlHeader", "originalQueryStringHeader", "strictHtmlCheck", "deleteInvalidClosingTag", "deleteInvalidUTF8", "connectTimeout", "readTimeout"};
for (int i=0; i<keys.length; ++i) {
Expand All @@ -31,7 +31,15 @@ public static Settings makeSettings(HashMap<String, String> option) {
EasyMock.expect(mock.getInitParameter(key)).andReturn(val);
}
EasyMock.replay(mock);
return new Settings(mock);
return mock;
}

public static Settings makeSettings() {
return makeSettings(emptyOption);
}

public static Settings makeSettings(HashMap<String, String> option) {
return new Settings(makeConfig(option));
}

public static HttpServletRequest mockRequestPath(String path) {
Expand Down Expand Up @@ -93,14 +101,22 @@ public static FilterConfig mockFilterConfig() {
}

public static FilterChainMock doServletFilter(String contentType, String path) throws ServletException, IOException {
return doServletFilter(contentType, path, path);
return doServletFilter(contentType, path, path, emptyOption);
}

public static FilterChainMock doServletFilter(String contentType, String path, HashMap<String, String> option) throws ServletException, IOException {
return doServletFilter(contentType, path, path, option);
}

public static FilterChainMock doServletFilter(String contentType, String path, String forwardPath) throws ServletException, IOException {
return doServletFilter(contentType, path, forwardPath, emptyOption);
}

public static FilterChainMock doServletFilter(String contentType, String path, String forwardPath, HashMap<String, String> option) throws ServletException, IOException {
RequestDispatcherMock dispatcher = new RequestDispatcherMock();
HttpServletRequest req = mockRequestPath(path, forwardPath, dispatcher);
ServletResponse res = TestUtil.mockResponse(contentType, "");
FilterConfig filterConfig = mockFilterConfig();
FilterConfig filterConfig = makeConfig(option);
FilterChainMock filterChain = new FilterChainMock();
WovnServletFilter filter = new WovnServletFilter();
filter.init(filterConfig);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.github.wovnio.wovnjava;

import java.io.IOException;
import java.util.HashMap;
import javax.servlet.FilterConfig;
import javax.servlet.FilterChain;
import javax.servlet.ServletRequest;
Expand All @@ -15,7 +16,6 @@


public class WovnServletFilterTest extends TestCase {

public void testHtml() throws ServletException, IOException {
FilterChainMock mock = TestUtil.doServletFilter("text/html; charset=utf-8", "/");
assertEquals("text/html; charset=utf-8", mock.res.getContentType());
Expand All @@ -28,6 +28,18 @@ public void testHtmlWithLang() throws ServletException, IOException {
assertEquals("/", mock.req.getRequestURI());
}

public void testHtmlWithQueryLang() throws ServletException, IOException {
FilterChainMock mock = TestUtil.doServletFilter("text/html; charset=utf-8", "/?wovn=ja", queryOption);
assertEquals("text/html; charset=utf-8", mock.res.getContentType());
assertEquals("/", mock.req.getRequestURI());
}

public void testHtmlWithSubdomain() throws ServletException, IOException {
FilterChainMock mock = TestUtil.doServletFilter("text/html; charset=utf-8", "/", subdomainOption("ja.wovn.io"));
assertEquals("text/html; charset=utf-8", mock.res.getContentType());
assertEquals("/", mock.req.getRequestURI());
}

public void testCss() throws ServletException, IOException {
FilterChainMock mock = TestUtil.doServletFilter("text/css", "/dir/style.css");
assertEquals("text/css", mock.res.getContentType());
Expand All @@ -51,4 +63,16 @@ public void testImageWithLang() throws ServletException, IOException {
assertEquals("image/png", mock.res.getContentType());
assertEquals("/image.png", mock.req.getRequestURI());
}

private final HashMap<String, String> queryOption = new HashMap<String, String>() {{
put("urlPattern", "query");
}};

private HashMap<String, String> subdomainOption(String host) {
return new HashMap<String, String>() {{
put("urlPattern", "subdomain");
put("host", host);
}};
}

}

0 comments on commit ee28a06

Please sign in to comment.