- add test case for this
pull/1/head
reger 10 years ago
parent a5d19e2982
commit f94e34058c

@ -124,6 +124,15 @@ public class MultiProtocolURL implements Serializable, Comparable<MultiProtocolU
this.port = url.port; this.port = url.port;
} }
/**
* Create MultiProtocolURL
*
* decoding exception: if url string contains http url with char '%' the url string must be url encoded (percent-escaped) before
* as internal encoding is skipped if url string contains '%'.
*
* @param url '%' char url encoded before
* @throws MalformedURLException
*/
public MultiProtocolURL(String url) throws MalformedURLException { public MultiProtocolURL(String url) throws MalformedURLException {
if (url == null) throw new MalformedURLException("url string is null"); if (url == null) throw new MalformedURLException("url string is null");
@ -133,8 +142,7 @@ public class MultiProtocolURL implements Serializable, Comparable<MultiProtocolU
// identify protocol // identify protocol
assert (url != null); assert (url != null);
url = url.trim(); url = url.trim();
url = UTF8.decodeURL(url); // normalization here
//url = patternSpace.matcher(url).replaceAll(" ");
if (url.startsWith("//")) { if (url.startsWith("//")) {
// patch for urls starting with "//" which can be found in the wild // patch for urls starting with "//" which can be found in the wild
url = "http:" + url; url = "http:" + url;
@ -195,6 +203,7 @@ public class MultiProtocolURL implements Serializable, Comparable<MultiProtocolU
identSearchpart(); identSearchpart();
escape(); escape();
} else { } else {
url = UTF8.decodeURL(url); // normalization here
// this is not a http or ftp url // this is not a http or ftp url
if (this.protocol.equals("mailto")) { if (this.protocol.equals("mailto")) {
// parse email url // parse email url

@ -141,6 +141,30 @@ public class MultiProtocolURLTest {
} }
} }
/**
* Test of toNormalform method, of class MultiProtocolURL.
*/
@Test
public void testToNormalform() throws Exception {
// some test url/uri with problems in the past
String[][] testStrings = new String[][]{
// teststring , expectedresult
new String[]{"http://www.heise.de/newsticker/thema/%23saukontrovers", "http://www.heise.de/newsticker/thema/%23saukontrovers"}, // http://mantis.tokeek.de/view.php?id=519
new String[]{"http://www.heise.de/newsticker/thema/#saukontrovers", "http://www.heise.de/newsticker/thema/"}
};
for (String[] testString : testStrings) {
// desired conversion result
System.out.print("orig uri: " + testString[0]);
String shouldBe = testString[1];
// conversion result
String resolvedHost = new MultiProtocolURL(testString[0]).toNormalform(true);
// test if equal
assertEquals(shouldBe, resolvedHost);
System.out.println(" -> " + resolvedHost);
}
}
} }

Loading…
Cancel
Save