SEC-2888: Polish

This commit is contained in:
Rob Winch 2015-03-13 16:10:39 -05:00
parent 85955015f7
commit b85ad33aef
2 changed files with 11 additions and 1 deletions

View File

@ -103,7 +103,6 @@ public final class AntPathRequestMatcher implements RequestMatcher {
} }
// If the pattern ends with {@code /**} and has no other wildcards or path variables, then optimize to a sub-path match // If the pattern ends with {@code /**} and has no other wildcards or path variables, then optimize to a sub-path match
// TODO: use spring-framework AntPathMatcher.VARIABLE_PATTERN instead.
if (pattern.endsWith(MATCH_ALL) && (pattern.indexOf('?') == -1 && pattern.indexOf('{') == -1 && pattern.indexOf('}') == -1) && if (pattern.endsWith(MATCH_ALL) && (pattern.indexOf('?') == -1 && pattern.indexOf('{') == -1 && pattern.indexOf('}') == -1) &&
pattern.indexOf("*") == pattern.length() - 2) { pattern.indexOf("*") == pattern.length() - 2) {
matcher = new SubpathMatcher(pattern.substring(0, pattern.length() - 3)); matcher = new SubpathMatcher(pattern.substring(0, pattern.length() - 3));

View File

@ -93,6 +93,17 @@ public class AntPathRequestMatcherTests {
assertFalse(matcher.matches(createRequest("/paskos/bleh/"))); assertFalse(matcher.matches(createRequest("/paskos/bleh/")));
} }
@Test
public void nontrailingWildcardWithVariableMatchesCorrectly() {
AntPathRequestMatcher matcher = new AntPathRequestMatcher("/**/{id}");
assertTrue(matcher.matches(createRequest("/blah/1234")));
assertTrue(matcher.matches(createRequest("/bleh/4567")));
assertTrue(matcher.matches(createRequest("/paskos/blah/")));
assertTrue(matcher.matches(createRequest("/12345/blah/xxx")));
assertTrue(matcher.matches(createRequest("/12345/blaha")));
assertTrue(matcher.matches(createRequest("/paskos/bleh/")));
}
@Test @Test
public void requestHasNullMethodMatches() { public void requestHasNullMethodMatches() {
AntPathRequestMatcher matcher = new AntPathRequestMatcher("/something/*", "GET"); AntPathRequestMatcher matcher = new AntPathRequestMatcher("/something/*", "GET");