blob: 150cc6bba7289e0b9a8c624fb8b6875f31ff3cbc [file] [log] [blame]
/*
* Copyright 2011 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.google.gwt.safehtml.shared;
import com.google.gwt.core.client.GWT;
import com.google.gwt.junit.client.GWTTestCase;
/**
* Unit tests for {@link UriUtils}.
*/
public class GwtUriUtilsTest extends GWTTestCase {
static final String INVALID_URL_UNPAIRED_SURROGATE = "a\uD800b";
static final String JAVASCRIPT_URL = "javascript:alert('BOOM!');";
static final String MAILTO_URL = "mailto:foo@example.com?subject=Hello%20world!";
static final String CONSTANT_URL =
"http://gwt.google.com/samples/Showcase/Showcase.html?locale=fr#!CwCheckBox";
static final String EMPTY_GIF_DATA_URL =
"data:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==";
static final String LONG_DATA_URL =
"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAHCAMAAADzjKfhAAAAGXRFWHRTb2Z0d2FyZQ"
+ "BBZG9iZSBJbWFnZVJlYWR5ccllPAAAAwBQTFRFZmZm////AgICAwMDBAQEBQUFBgYGBwcHCAgICQkJCgoKCwsL"
+ "DAwMDQ0NDg4ODw8PEBAQEREREhISExMTFBQUFRUVFhYWFxcXGBgYGRkZGhoaGxsbHBwcHR0dHh4eHx8fICAgIS"
+ "EhIiIiIyMjJCQkJSUlJiYmJycnKCgoKSkpKioqKysrLCwsLS0tLi4uLy8vMDAwMTExMjIyMzMzNDQ0NTU1NjY2"
+ "Nzc3ODg4OTk5Ojo6Ozs7PDw8PT09Pj4+Pz8/QEBAQUFBQkJCQ0NDRERERUVFRkZGR0dHSEhISUlJSkpKS0tLTE"
+ "xMTU1NTk5OT09PUFBQUVFRUlJSU1NTVFRUVVVVVlZWV1dXWFhYWVlZWlpaW1tbXFxcXV1dXl5eX19fYGBgYWFh"
+ "YmJiY2NjZGRkZWVlZmZmZ2dnaGhoaWlpampqa2trbGxsbW1tbm5ub29vcHBwcXFxcnJyc3NzdHR0dXV1dnZ2d3"
+ "d3eHh4eXl5enp6e3t7fHx8fX19fn5+f39/gICAgYGBgoKCg4ODhISEhYWFhoaGh4eHiIiIiYmJioqKi4uLjIyM"
+ "jY2Njo6Oj4+PkJCQkZGRkpKSk5OTlJSUlZWVlpaWl5eXmJiYmZmZmpqam5ubnJycnZ2dnp6en5+foKCgoaGhoq"
+ "Kio6OjpKSkpaWlpqamp6enqKioqampqqqqq6urrKysra2trq6ur6+vsLCwsbGxsrKys7OztLS0tbW1tra2t7e3"
+ "uLi4ubm5urq6u7u7vLy8vb29vr6+v7+/wMDAwcHBwsLCw8PDxMTExcXFxsbGx8fHyMjIycnJysrKy8vLzMzMzc"
+ "3Nzs7Oz8/P0NDQ0dHR0tLS09PT1NTU1dXV1tbW19fX2NjY2dnZ2tra29vb3Nzc3d3d3t7e39/f4ODg4eHh4uLi"
+ "4+Pj5OTk5eXl5ubm5+fn6Ojo6enp6urq6+vr7Ozs7e3t7u7u7+/v8PDw8fHx8vLy8/Pz9PT09fX19vb29/f3+P"
+ "j4+fn5+vr6+/v7/Pz8/f39/v7+////AADF2QAAAAJ0Uk5T/wDltzBKAAAAH0lEQVR42mJghAAGGJ0GAQyMYAok"
+ "DqLA8mlI6gACDAC8pAaCn/ezogAAAABJRU5ErkJggg==";
public void testEncode_noEscape() {
StringBuilder sb = new StringBuilder(UriUtils.DONT_NEED_ENCODING);
final int upcaseOffset = 'A' - 'a';
for (char c = 'a'; c <= 'z'; c++) {
sb.append(c).append((char) (c + upcaseOffset));
}
for (char c = '0'; c <= '9'; c++) {
sb.append(c);
}
final String expected = sb.toString();
assertEquals(expected, UriUtils.encode(expected));
}
public void testEncode_percent() {
assertEquals("foo%25bar", UriUtils.encode("foo%bar"));
}
public void testEncode_percentAndOthers() {
assertEquals("fo%20o%25b%0Aa%22r", UriUtils.encode("fo o%b\na\"r"));
}
public void testEncode_withEscapes1() {
assertEquals("foo%bar", UriUtils.encodeAllowEscapes("foo%bar"));
}
public void testEncode_withEscapes2() {
assertEquals("foo%25bar", UriUtils.encodeAllowEscapes("foo%25bar"));
}
public void testEncode_withEscapes3() {
assertEquals("foo%E2%82%ACbar", UriUtils.encodeAllowEscapes("foo\u20ACbar"));
}
public void testEncode_withEscapes4() {
assertEquals("foo%E2%82%ACbar", UriUtils.encodeAllowEscapes("foo%E2%82%ACbar"));
}
public void testEncode_withEscapesIncompleteEscapes() {
assertEquals("foob%25ar%25a", UriUtils.encodeAllowEscapes("foob%ar%a"));
}
public void testEncode_withEscapesInvalidEscapes() {
assertEquals("f%25ooba%25r", UriUtils.encodeAllowEscapes("f%ooba%r"));
}
public void testFromTrustedString() {
assertEquals(CONSTANT_URL, UriUtils.fromTrustedString(CONSTANT_URL).asString());
assertEquals(MAILTO_URL, UriUtils.fromTrustedString(MAILTO_URL).asString());
assertEquals(EMPTY_GIF_DATA_URL, UriUtils.fromTrustedString(EMPTY_GIF_DATA_URL).asString());
assertEquals(LONG_DATA_URL, UriUtils.fromTrustedString(LONG_DATA_URL).asString());
assertEquals(JAVASCRIPT_URL, UriUtils.fromTrustedString(JAVASCRIPT_URL).asString());
if (GWT.isClient()) {
assertEquals(GWT.getModuleBaseURL(),
UriUtils.fromTrustedString(GWT.getModuleBaseURL()).asString());
assertEquals(GWT.getHostPageBaseURL(),
UriUtils.fromTrustedString(GWT.getHostPageBaseURL()).asString());
}
}
public void testFromTrustedString_withInvalidUrl() {
if (GWT.isProdMode()) {
// fromTrustedString does not parse/validate its argument in prod mode.
// Hence we short-circuit this test in prod mode.
return;
}
try {
SafeUri u = UriUtils.fromTrustedString(INVALID_URL_UNPAIRED_SURROGATE);
fail("Should have thrown IllegalArgumentException");
} catch (IllegalArgumentException e) {
// expected
}
}
@SuppressWarnings("deprecation")
public void testUnsafeCastFromUntrustedString() {
assertEquals(CONSTANT_URL, UriUtils.unsafeCastFromUntrustedString(CONSTANT_URL).asString());
assertEquals(MAILTO_URL, UriUtils.unsafeCastFromUntrustedString(MAILTO_URL).asString());
assertEquals(EMPTY_GIF_DATA_URL, UriUtils.unsafeCastFromUntrustedString(EMPTY_GIF_DATA_URL)
.asString());
assertEquals(JAVASCRIPT_URL, UriUtils.unsafeCastFromUntrustedString(JAVASCRIPT_URL).asString());
assertEquals(INVALID_URL_UNPAIRED_SURROGATE,
UriUtils.unsafeCastFromUntrustedString(INVALID_URL_UNPAIRED_SURROGATE).asString());
if (GWT.isClient()) {
assertEquals(GWT.getModuleBaseURL(), UriUtils.unsafeCastFromUntrustedString(
GWT.getModuleBaseURL()).asString());
assertEquals(GWT.getHostPageBaseURL(), UriUtils.unsafeCastFromUntrustedString(
GWT.getHostPageBaseURL()).asString());
}
}
public void testFromString() {
assertEquals(CONSTANT_URL, UriUtils.fromString(CONSTANT_URL).asString());
assertEquals(MAILTO_URL, UriUtils.fromString(MAILTO_URL).asString());
assertEquals(UriUtils.sanitizeUri(EMPTY_GIF_DATA_URL),
UriUtils.fromString(EMPTY_GIF_DATA_URL).asString());
assertEquals(UriUtils.sanitizeUri(JAVASCRIPT_URL),
UriUtils.fromString(JAVASCRIPT_URL).asString());
if (GWT.isClient()) {
assertEquals(GWT.getModuleBaseURL(),
UriUtils.fromString(GWT.getModuleBaseURL()).asString());
assertEquals(GWT.getHostPageBaseURL(),
UriUtils.fromString(GWT.getHostPageBaseURL()).asString());
}
}
@Override
public String getModuleName() {
return "com.google.gwt.safehtml.SafeHtmlTestsModule";
}
}