/*
* Copyright (c) 2015, 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.
*/
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import static org.testng.Assert .assertEquals;
/*
* @test
* @bug 8077559
* @summary Tests Compact String. This one is for String.indexOf.
* @run testng/othervm -XX:+CompactStrings IndexOf
* @run testng/othervm -XX:-CompactStrings IndexOf
*/
public class IndexOf extends CompactString {
@DataProvider
public Object[][] provider() {
return new Object[][] {
new Object[] { STRING_EMPTY, (int ) 'A' , -1 },
new Object[] { STRING_L1, (int ) 'A' , 0 },
new Object[] { STRING_L2, (int ) 'A' , 0 },
new Object[] { STRING_L2, (int ) 'B' , 1 },
new Object[] { STRING_L4, (int ) 'A' , 0 },
new Object[] { STRING_L4, (int ) 'D' , 3 },
new Object[] { STRING_L4, (int ) 'E' , -1 },
new Object[] { STRING_LLONG, (int ) 'A' , 0 },
new Object[] { STRING_LLONG, (int ) 'H' , 7 },
new Object[] { STRING_U1, (int ) '\uFF21' , 0 },
new Object[] { STRING_U1, (int ) 'A' , -1 },
new Object[] { STRING_U2, (int ) '\uFF21' , 0 },
new Object[] { STRING_U2, (int ) '\uFF22' , 1 },
new Object[] { STRING_M12, (int ) '\uFF21' , 0 },
new Object[] { STRING_M12, (int ) 'A' , 1 },
new Object[] { STRING_M11, (int ) 'A' , 0 },
new Object[] { STRING_M11, (int ) '\uFF21' , 1 },
new Object[] { STRING_UDUPLICATE, (int ) '\uFF21' , 0 },
new Object[] { STRING_UDUPLICATE, (int ) '\uFF22' , 1 },
new Object[] { STRING_SUPPLEMENTARY, 'A' , 5 },
new Object[] { STRING_SUPPLEMENTARY, '\uFF21' , 4 },
new Object[] { STRING_SUPPLEMENTARY,
Character.toCodePoint('\uD801' , '\uDC00' ), 0 },
new Object[] { STRING_SUPPLEMENTARY,
Character.toCodePoint('\uD801' , '\uDC01' ), 2 }, };
}
@Test(dataProvider = "provider" )
public void testIndexOf(String str, int ch, int expected) {
map.get(str).forEach(
(source, data) -> {
assertEquals(data.indexOf(ch), expected, String.format(
"testing String(%s).indexOf(%d), source : %s, " ,
escapeNonASCIIs(data), ch, source));
});
}
@DataProvider
public Object[][] provider2() {
return new Object[][] {
new Object[] { STRING_EMPTY, (int ) 'A' , 0, -1 },
new Object[] { STRING_L1, (int ) 'A' , 0, 0 },
new Object[] { STRING_L1, (int ) 'A' , 1, -1 },
new Object[] { STRING_L1, (int ) 'B' , 0, -1 },
new Object[] { STRING_L2, (int ) 'A' , 0, 0 },
new Object[] { STRING_L2, (int ) 'A' , 1, -1 },
new Object[] { STRING_L2, (int ) 'B' , 0, 1 },
new Object[] { STRING_L2, (int ) 'B' , 1, 1 },
new Object[] { STRING_L4, (int ) 'A' , 0, 0 },
new Object[] { STRING_L4, (int ) 'D' , 2, 3 },
new Object[] { STRING_L4, (int ) 'B' , 2, -1 },
new Object[] { STRING_LLONG, (int ) 'A' , 0, 0 },
new Object[] { STRING_LLONG, (int ) 'H' , 5, 7 },
new Object[] { STRING_U1, (int ) '\uFF21' , 0, 0 },
new Object[] { STRING_U1, (int ) 'A' , 0, -1 },
new Object[] { STRING_U2, (int ) '\uFF21' , 0, 0 },
new Object[] { STRING_U2, (int ) '\uFF22' , 0, 1 },
new Object[] { STRING_M12, (int ) '\uFF21' , 0, 0 },
new Object[] { STRING_M12, (int ) 'A' , 1, 1 },
new Object[] { STRING_M11, (int ) 'A' , 0, 0 },
new Object[] { STRING_M11, (int ) '\uFF21' , 1, 1 },
new Object[] { STRING_UDUPLICATE, (int ) '\uFF21' , 1, 2 },
new Object[] { STRING_UDUPLICATE, (int ) '\uFF22' , 1, 1 }, };
}
@Test(dataProvider = "provider2" )
public void testIndexOf(String str, int ch, int fromIndex, int expected) {
map.get(str)
.forEach(
(source, data) -> {
assertEquals(
data.indexOf(ch, fromIndex),
expected,
String.format(
"testing String(%s).indexOf(%d, %d), source : %s, " ,
escapeNonASCIIs(data), ch,
fromIndex, source));
});
}
@DataProvider
public Object[][] provider3() {
return new Object[][] {
new Object[] { STRING_EMPTY, "A" , -1 },
new Object[] { STRING_L1, "A" , 0 },
new Object[] { STRING_L1, "AB" , -1 },
new Object[] { STRING_L2, "A" , 0 },
new Object[] { STRING_L2, "B" , 1 },
new Object[] { STRING_L2, "AB" , 0 },
new Object[] { STRING_L2, "AC" , -1 },
new Object[] { STRING_L2, "ABC" , -1 },
new Object[] { STRING_L4, "ABCD" , 0 },
new Object[] { STRING_L4, "D" , 3 },
new Object[] { STRING_LLONG, "ABCDEFGH" , 0 },
new Object[] { STRING_LLONG, "EFGH" , 4 },
new Object[] { STRING_LLONG, "EFGHI" , -1 },
new Object[] { STRING_U1, "\uFF21" , 0 },
new Object[] { STRING_U1, "\uFF21A" , -1 },
new Object[] { STRING_U2, "\uFF21\uFF22" , 0 },
new Object[] { STRING_U2, "\uFF22" , 1 },
new Object[] { STRING_U2, "A\uFF22" , -1 },
new Object[] { STRING_M12, "\uFF21A" , 0 },
new Object[] { STRING_M12, "A" , 1 },
new Object[] { STRING_M12, "\uFF21\uFF21" , -1 },
new Object[] { STRING_M11, "A\uFF21" , 0 },
new Object[] { STRING_M11, "\uFF21" , 1 },
new Object[] { STRING_M11, "A" , 0 },
new Object[] {
STRING_UDUPLICATE,
"\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22" ,
0 },
new Object[] { STRING_UDUPLICATE,
"\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21" , 1 },
new Object[] {
STRING_UDUPLICATE,
"\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21" ,
-1 }, };
}
@Test(dataProvider = "provider3" )
public void testIndexOf(String str, String anotherString, int expected) {
map.get(str)
.forEach(
(source, data) -> {
assertEquals(
data.indexOf(anotherString),
expected,
String.format(
"testing String(%s).indexOf(%s), source : %s, " ,
escapeNonASCIIs(data),
escapeNonASCIIs(anotherString),
source));
});
}
@DataProvider
public Object[][] provider4() {
return new Object[][] {
new Object[] { STRING_EMPTY, "A" , 0, -1 },
new Object[] { STRING_L1, "A" , 0, 0 },
new Object[] { STRING_L1, "A" , 1, -1 },
new Object[] { STRING_L1, "AB" , 0, -1 },
new Object[] { STRING_L2, "A" , 0, 0 },
new Object[] { STRING_L2, "B" , 0, 1 },
new Object[] { STRING_L2, "AB" , 0, 0 },
new Object[] { STRING_L2, "AB" , 1, -1 },
new Object[] { STRING_L4, "ABCD" , 0, 0 },
new Object[] { STRING_L4, "BC" , 0, 1 },
new Object[] { STRING_L4, "A" , 0, 0 },
new Object[] { STRING_L4, "CD" , 0, 2 },
new Object[] { STRING_L4, "A" , 2, -1 },
new Object[] { STRING_L4, "ABCDE" , 0, -1 },
new Object[] { STRING_LLONG, "ABCDEFGH" , 0, 0 },
new Object[] { STRING_LLONG, "DEFGH" , 0, 3 },
new Object[] { STRING_LLONG, "A" , 0, 0 },
new Object[] { STRING_LLONG, "GHI" , 0, -1 },
new Object[] { STRING_U1, "\uFF21" , 0, 0 },
new Object[] { STRING_U1, "\uFF21A" , 0, -1 },
new Object[] { STRING_U2, "\uFF21\uFF22" , 0, 0 },
new Object[] { STRING_U2, "\uFF22" , 0, 1 },
new Object[] { STRING_U2, "\uFF21" , 1, -1 },
new Object[] { STRING_M12, "\uFF21A" , 0, 0 },
new Object[] { STRING_M12, "A" , 1, 1 },
new Object[] { STRING_M12, "\uFF21A" , 1, -1 },
new Object[] { STRING_M12, "\uFF21" , 0, 0 },
new Object[] { STRING_M11, "A\uFF21" , 0, 0 },
new Object[] { STRING_M11, "\uFF21" , 1, 1 },
new Object[] { STRING_M11, "A\uFF21" , 1, -1 },
new Object[] { STRING_M11, "A\uFF21A" , 0, -1 },
new Object[] {
STRING_UDUPLICATE,
"\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22" ,
0, 0 },
new Object[] {
STRING_UDUPLICATE,
"\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22" ,
1, -1 },
new Object[] {
STRING_UDUPLICATE,
"\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22\uFF21\uFF22" ,
1, 1 },
new Object[] { STRING_UDUPLICATE, "\uFF21\uFF22\uFF21\uFF22" ,
4, 4 },
new Object[] { STRING_UDUPLICATE, "\uFF21\uFF22\uFF21\uFF22" ,
7, -1 }, };
}
@Test(dataProvider = "provider4" )
public void testIndexOf(String str, String anotherString, int fromIndex,
int expected) {
map.get(str)
.forEach(
(source, data) -> {
assertEquals(
data.indexOf(anotherString, fromIndex),
expected,
String.format(
"testing String(%s).indexOf(%s), source : %s, " ,
escapeNonASCIIs(data),
escapeNonASCIIs(anotherString),
fromIndex, source));
});
}
}
quality 89%
¤ Dauer der Verarbeitung: 0.12 Sekunden
(vorverarbeitet)
¤
*© Formatika GbR, Deutschland