593ba2fe47
Reviewed-by: jlahoda, jjg
129 lines
4.8 KiB
Java
129 lines
4.8 KiB
Java
/*
|
|
* Copyright (c) 2013, 2023, Oracle and/or its affiliates. All rights reserved.
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
* accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU General Public License version
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
* questions.
|
|
*/
|
|
|
|
/**
|
|
* @test
|
|
* @bug 8029800 8043186 8313693
|
|
* @summary Unit test StringUtils
|
|
* @modules jdk.compiler/com.sun.tools.javac.util
|
|
* @run main StringUtilsTest
|
|
*/
|
|
|
|
import java.util.List;
|
|
import java.util.Locale;
|
|
import java.util.Objects;
|
|
import com.sun.tools.javac.util.StringUtils;
|
|
import com.sun.tools.javac.util.StringUtils.DamerauLevenshteinDistance;
|
|
|
|
public class StringUtilsTest {
|
|
public static void main(String... args) throws Exception {
|
|
new StringUtilsTest().run();
|
|
}
|
|
|
|
void run() throws Exception {
|
|
Locale.setDefault(Locale.of("tr", "TR"));
|
|
|
|
//verify the properties of the default locale:
|
|
assertEquals("\u0131", "I".toLowerCase());
|
|
assertEquals("\u0130", "i".toUpperCase());
|
|
|
|
//verify the StringUtils.toLowerCase/toUpperCase do what they should:
|
|
assertEquals("i", StringUtils.toLowerCase("I"));
|
|
assertEquals("I", StringUtils.toUpperCase("i"));
|
|
|
|
//verify StringUtils.caseInsensitiveIndexOf works:
|
|
assertEquals(2, StringUtils.indexOfIgnoreCase(" lookFor", "lookfor"));
|
|
assertEquals(11, StringUtils.indexOfIgnoreCase(" lookFor LOOKfor", "lookfor", 11));
|
|
assertEquals(2, StringUtils.indexOfIgnoreCase("\u0130\u0130lookFor", "lookfor"));
|
|
|
|
//verify Damerau-Levenshtein
|
|
|
|
assertEquals(3, DamerauLevenshteinDistance.of("kitten", "sitting"));
|
|
// note that the restricted Damerau-Levenshtein distance would be 3, not 2:
|
|
assertEquals(2, DamerauLevenshteinDistance.of("ca", "abc"));
|
|
//verify strings comprising only non-LATIN1 characters
|
|
assertEquals(1, DamerauLevenshteinDistance.of("\u0438\u044e\u043d\u044c",
|
|
"\u0438\u044e\u043b\u044c"));
|
|
//verify strings comprising mixed characters: non-LATIN1 and ASCII
|
|
// it's important to start with ASCII characters, so that we
|
|
// test switching a storage (see current implementation)
|
|
assertEquals(2, DamerauLevenshteinDistance.of("c\u043ede", "cod\u0435"));
|
|
|
|
//verify metric properties
|
|
for (String a : List.of("", "a", "b", "abc")) {
|
|
for (String b : List.of("", "a", "b", "abc")) {
|
|
assertNonNegativity(a, b);
|
|
assertSymmetry(a, b);
|
|
}
|
|
}
|
|
|
|
for (String a : List.of("", "a", "b", "c")) {
|
|
for (String b : List.of("ab", "ac", "bc")) {
|
|
for (String c : List.of("abc", "bca", "cab")) {
|
|
assertTriangleInequality(a, b, c);
|
|
assertTriangleInequality(b, c, a);
|
|
assertTriangleInequality(c, a, b);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private void assertNonNegativity(String a, String b) {
|
|
if (a.equals(b)) {
|
|
assertEquals(0, DamerauLevenshteinDistance.of(a, b));
|
|
} else {
|
|
assertTrue(DamerauLevenshteinDistance.of(a, b) > 0);
|
|
}
|
|
}
|
|
|
|
private void assertSymmetry(String a, String b) {
|
|
assertEquals(DamerauLevenshteinDistance.of(a, b),
|
|
DamerauLevenshteinDistance.of(b, a));
|
|
}
|
|
|
|
private void assertTriangleInequality(String a, String b, String c) {
|
|
int ab = DamerauLevenshteinDistance.of(a, b);
|
|
int bc = DamerauLevenshteinDistance.of(b, c);
|
|
int ac = DamerauLevenshteinDistance.of(a, c);
|
|
assertTrue(ab + bc >= ac);
|
|
}
|
|
|
|
void assertEquals(String expected, String actual) {
|
|
if (!Objects.equals(expected, actual)) {
|
|
throw new IllegalStateException("expected=" + expected + "; actual=" + actual);
|
|
}
|
|
}
|
|
|
|
void assertEquals(int expected, int actual) {
|
|
if (expected != actual) {
|
|
throw new IllegalStateException("expected=" + expected + "; actual=" + actual);
|
|
}
|
|
}
|
|
|
|
void assertTrue(boolean cond) {
|
|
if (!cond) {
|
|
throw new IllegalStateException();
|
|
}
|
|
}
|
|
}
|