/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* See LICENSE.txt included in this distribution for the specific
* language governing permissions and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at LICENSE.txt.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved.
*/
package org.opensolaris.opengrok.web;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.StringWriter;
import java.util.Locale;
import javax.xml.parsers.DocumentBuilderFactory;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import static org.junit.Assert.*;
/**
* Test of the methods in org.opensolaris.opengrok.web.Util
.
*/
public class UtilTest {
private static Locale savedLocale;
@BeforeClass
public static void setUpClass() {
// Some of the methods have different results in different locales.
// Set locale to en_US for these tests.
savedLocale = Locale.getDefault();
Locale.setDefault(Locale.US);
}
@AfterClass
public static void tearDownClass() {
Locale.setDefault(savedLocale);
savedLocale = null;
}
@Test
public void htmlize() throws IOException {
String[][] input_output = {
{"This is a test", "This is a test" },
{"Newline\nshould become
",
"Newline
should become <br/>" },
{"Open & Grok", "Open & Grok" },
{"&<>", "&<>" },
};
for (String[] in_out : input_output) {
// 1 arg
assertEquals(in_out[1], Util.htmlize(in_out[0]));
// 2 args
StringBuilder sb = new StringBuilder();
Util.htmlize(in_out[0], sb);
assertEquals(in_out[1], sb.toString());
}
}
@Test
public void breadcrumbPath() {
assertEquals(null, Util.breadcrumbPath("/root/", null));
assertEquals("", Util.breadcrumbPath("/root/", ""));
assertEquals("x",
Util.breadcrumbPath("/root/", "x"));
assertEquals("xx",
Util.breadcrumbPath("/root/", "xx"));
// parent directories have a trailing slash in href
assertEquals("a/b",
Util.breadcrumbPath("/r/", "a/b"));
// if basename is a dir (ends with file seperator), href link also
// ends with a '/'
assertEquals("a/b/",
Util.breadcrumbPath("/r/", "a/b/"));
// should work the same way with a '.' as file separator
assertEquals("java." +
"lang." +
"String",
Util.breadcrumbPath("/r/", "java.lang.String", '.'));
// suffix added to the link?
assertEquals("xx",
Util.breadcrumbPath("/root/", "xx", '/', "&project=y", false));
// compact: path needs to be resolved to /xx and no link is added
// for the virtual root directory (parent) but emitted as plain text.
// Prefix gets just prefixed as is and not mangled wrt. path -> "//"
assertEquals("/xx",
Util.breadcrumbPath("/root/", "../xx", '/', "&project=y", true));
// relative pathes are resolved wrt. / , so path resolves to /a/c/d
assertEquals("/a/" +
"c/" +
"d",
Util.breadcrumbPath("/r/", "../a/b/../c//d", '/', "", true));
}
@Test
public void redableSize() {
assertEquals("0 ", Util.readableSize(0));
assertEquals("1 ", Util.readableSize(1));
assertEquals("-1 ", Util.readableSize(-1));
assertEquals("1,000 ", Util.readableSize(1000));
assertEquals("1 KiB", Util.readableSize(1024));
assertEquals("2.4 KiB", Util.readableSize(2500));
assertEquals("1.4 MiB", Util.readableSize(1474560));
assertEquals("3.5 GiB", Util.readableSize(3758489600L));
assertEquals("8,589,934,592 GiB",
Util.readableSize(Long.MAX_VALUE));
}
@Test
public void readableLine() throws Exception {
StringWriter out = new StringWriter();
// hmmm - where do meaningful tests start?
Util.readableLine(42, out, null, null, null, null);
assertEquals("\n42",
out.toString());
out.getBuffer().setLength(0); // clear buffer
Util.readableLine(110, out, null, null, null, null);
assertEquals("\n110",
out.toString());
}
@Test
public void path2uid() {
assertEquals("\u0000etc\u0000passwd\u0000date",
Util.path2uid("/etc/passwd", "date"));
}
@Test
public void uid2url() {
assertEquals("/etc/passwd", Util.uid2url(
Util.path2uid("/etc/passwd", "date")));
}
@Test
public void URIEncode() {
assertEquals("", Util.URIEncode(""));
assertEquals("a+b", Util.URIEncode("a b"));
assertEquals("a%23b", Util.URIEncode("a#b"));
assertEquals("a%2Fb", Util.URIEncode("a/b"));
assertEquals("README.txt", Util.URIEncode("README.txt"));
}
@Test
public void URIEncodePath() {
assertEquals("", Util.URIEncodePath(""));
assertEquals("/", Util.URIEncodePath("/"));
assertEquals("a", Util.URIEncodePath("a"));
assertEquals("%09", Util.URIEncodePath("\t"));
assertEquals("a%2Bb", Util.URIEncodePath("a+b"));
assertEquals("a%20b", Util.URIEncodePath("a b"));
assertEquals("/a//x/yz/%23%23/%20/%20%3F",
Util.URIEncodePath("/a//x/yz/##/ / ?"));
assertEquals("foo%3A%3Abar%3A%3Atest.js",
Util.URIEncodePath("foo::bar::test.js"));
assertEquals("bl%C3%A5b%C3%A6rsyltet%C3%B8y",
Util.URIEncodePath("bl\u00E5b\u00E6rsyltet\u00F8y"));
}
@Test
public void formQuoteEscape() {
assertEquals("", Util.formQuoteEscape(null));
assertEquals("abc", Util.formQuoteEscape("abc"));
assertEquals(""abc"", Util.formQuoteEscape("\"abc\""));
assertEquals("å", Util.formQuoteEscape("å"));
}
@Test
public void diffline() {
String[][] tests = {
{
"if (a < b && foo < bar && c > d)",
"if (a < b && foo > bar && c > d)",
"if (a < b && foo < bar && c > d)",
"if (a < b && foo > bar && c > d)"
},
{
"foo << 1",
"foo >> 1",
"foo << 1",
"foo >> 1"
},
{
"\"(ses_id, mer_id, pass_id, \" + refCol +\" , mer_ref, amnt, "
+ "cur, ps_id, ret_url, d_req_time, d_req_mil, h_resp_time, "
+ "h_resp_mil) \"",
"\"(ses_id, mer_id, pass_id, \" + refCol +\" , mer_ref, amnt, "
+ "cur, ps_id, ret_url, exp_url, d_req_time, d_req_mil, "
+ "h_resp_time, h_resp_mil) \"",
"\"(ses_id, mer_id, pass_id, \" + refCol +\" , mer_ref, amnt, "
+ "cur, ps_id, ret_url, d_req_time, d_req_mil, h_resp_time, "
+ "h_resp_mil) \"",
"\"(ses_id, mer_id, pass_id, \" + refCol +\" , mer_ref, amnt, "
+ "cur, ps_id, ret_url, exp_url, "
+ "d_req_time, d_req_mil, h_resp_time, h_resp_mil) \""
},
{
"\"VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\", values);",
"\"VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\", values);",
"\"VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\", values);",
"\"VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\", values);"
},
{
"char *config_list = NULL;",
"char **config_list = NULL;",
"char *config_list = NULL;",
"char **config_list = NULL;"
},
{
"char **config_list = NULL;",
"char *config_list = NULL;",
"char **config_list = NULL;",
"char *config_list = NULL;"
},
{
"* An error occured or there is non-numeric stuff at the end",
"* An error occurred or there is non-numeric stuff at the end",
"* An error occured or there is non-numeric stuff at the end",
"* An error occurred or there is "
+ "non-numeric stuff at the end"
}
};
for (int i=0; i < tests.length; i++) {
String[] strings=Util.diffline(
new StringBuilder(tests[i][0]),
new StringBuilder(tests[i][1]));
assertEquals(""+ i + "," + 0, tests[i][2], strings[0]);
assertEquals(""+ i + "," + 1, tests[i][3], strings[1]);
}
}
@Test
public void dumpConfiguration() throws Exception {
StringBuilder out = new StringBuilder();
Util.dumpConfiguration(out);
String s = out.toString();
// Verify that we got a table.
assertTrue(s.startsWith("