/* * Copyright (c) 2015, 2017, 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.
*/
static File inputFile = new File(System.getProperty("test.src", "."), "input.txt");
@DataProvider(name = "Tokens") publicstatic Object[][] makeTokensTestData() { // each inner array is [String description, String input, String delimiter] // delimiter may be null
List<Object[]> data = new ArrayList<>();
/* * Creates a scanner over the input, applying a delimiter if non-null.
*/
Scanner makeScanner(String input, String delimiter) {
Scanner sc = new Scanner(input); if (delimiter != null) {
sc.useDelimiter(delimiter);
} return sc;
}
/* * Given input and a delimiter, tests that tokens() returns the same * results that would be provided by a Scanner hasNext/next loop.
*/
@Test(dataProvider = "Tokens") publicvoid tokensTest(String description, String input, String delimiter) { // derive expected result by using conventional loop
Scanner sc = makeScanner(input, delimiter);
List<String> expected = new ArrayList<>(); while (sc.hasNext()) {
expected.add(sc.next());
}
/* * Creates a Scanner over the given input file.
*/
Scanner makeFileScanner(File file) { try { returnnew Scanner(file, "UTF-8");
} catch (IOException ioe) { thrownew UncheckedIOException(ioe);
}
}
/* * Tests that the matches produced by findAll(pat) are the same * as what are returned by findWithinHorizon(pat, 0). This tests * a single pattern against a single input file.
*/ publicvoid findAllFileTest() { // derive expected result by using conventional loop
Pattern pat = Pattern.compile("[A-Z]{7,}");
List<String> expected = new ArrayList<>();
/* * Tests findAll() using a pattern against an input string. * The results from findAll() should equal the results obtained * using a loop around Matcher.find(). * * The provided regexes should allow zero-length matches. * This primarily tests the auto-advance feature of findAll() that * occurs if the regex match is of zero length to see if it has the * same behavior as Matcher.find()'s auto-advance (JDK-8150488). * Without auto-advance, findAll() would return an infinite stream * of zero-length matches. Apply a limit to the stream so * that an infinite stream will be truncated. The limit must be * high enough that the resulting truncated stream won't be * mistaken for a correct expected result.
*/
@Test(dataProvider = "FindAllZero") publicvoid findAllZeroTest(String input, String patternString) {
Pattern pattern = Pattern.compile(patternString);
// generate expected result using Matcher.find()
Matcher m = pattern.matcher(input);
List<String> expected = new ArrayList<>(); while (m.find()) {
expected.add(m.group());
}
Supplier<Stream<String>> ss = () -> new Scanner(input).findAll(pattern)
.limit(100)
.map(MatchResult::group);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.