/* * Copyright (c) 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.
*/
/** * @test * @bug 8183743 * @summary Test to verify the new overload method with Charset functions the same * as the existing method that takes a charset name. * @run testng EncodingTest
*/ publicclass EncodingTest { static String USER_DIR = System.getProperty("user.dir", "."); staticboolean AUTOFLUSH = true; publicstaticenum ConstructorType {
STRING,
FILE,
OUTPUTSTREAM
}
/* * DataProvider fields: * Type of the constructor, a file to be written with a charset name, * a file to be written with a charset, charset name, charset.
*/
@DataProvider(name = "parameters") public Object[][] getParameters() throws IOException {
String csn = StandardCharsets.UTF_8.name();
Charset charset = StandardCharsets.UTF_8;
File file1 = new File(USER_DIR, "PSCharsetTest1.txt");
File file2 = new File(USER_DIR, "PSCharsetTest2.txt");
/** * Verifies that the overloading constructor behaves the same as the existing * one. * @param type the type of the constructor * @param file1 file1 written with the name of a charset * @param file2 file2 written with a charset * @param csn the charset name * @param charset the charset * @throws IOException
*/
@Test(dataProvider = "parameters") publicvoid test(ConstructorType type, File file1, File file2, String csn, Charset charset) throws Exception {
createFile(getPrintStream(type, file1.getPath(), csn, null));
createFile(getPrintStream(type, file2.getPath(), null, charset));
PrintStream getPrintStream(ConstructorType type, String path, String csn, Charset charset) throws IOException {
PrintStream out = null; if (csn != null) { switch (type) { case STRING:
out = new PrintStream(path, csn); break; case FILE:
out = new PrintStream(new File(path), csn); break; case OUTPUTSTREAM:
FileOutputStream fout = new FileOutputStream(path);
out = new PrintStream(fout, AUTOFLUSH, csn); break;
}
} else { switch (type) { case STRING:
out = new PrintStream(path, charset); break; case FILE:
out = new PrintStream(new File(path), charset); break; case OUTPUTSTREAM:
FileOutputStream fout = new FileOutputStream(path);
out = new PrintStream(fout, AUTOFLUSH, charset); break;
}
}
return out;
}
}
¤ Dauer der Verarbeitung: 0.0 Sekunden
(vorverarbeitet)
¤
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.