From 3ab53b61f03864d03f6955e9f8e927da12df9a8c Mon Sep 17 00:00:00 2001 From: Kumar Srinivasan Date: Wed, 26 Jun 2013 09:54:46 -0700 Subject: [PATCH] 8016908: TEST_BUG: removing non-ascii characters causes tests to fail Reviewed-by: jjg, vromero --- .../tools/javac/api/6437999/T6437999.java | 23 +++++++++++++--- .../test/tools/javac/api/6437999/Utf8.java | 27 ------------------- langtools/test/tools/javac/api/T6306137.java | 23 ++++++++++++---- 3 files changed, 38 insertions(+), 35 deletions(-) delete mode 100644 langtools/test/tools/javac/api/6437999/Utf8.java diff --git a/langtools/test/tools/javac/api/6437999/T6437999.java b/langtools/test/tools/javac/api/6437999/T6437999.java index db2f46a3e7a..2fbe3211fb9 100644 --- a/langtools/test/tools/javac/api/6437999/T6437999.java +++ b/langtools/test/tools/javac/api/6437999/T6437999.java @@ -33,11 +33,28 @@ */ import java.io.File; +import java.io.IOException; import java.nio.charset.Charset; +import java.nio.file.Files; +import java.util.ArrayList; import java.util.Collections; +import java.util.List; import javax.tools.*; +import static java.nio.file.StandardOpenOption.*; public class T6437999 extends ToolTester { + final File testFile = new File("Utf8.java"); + T6437999() throws IOException { + createTestFile(); + } + final void createTestFile() throws IOException { + List scratch = new ArrayList<>(); + scratch.add("// @author Peter von der Ah" + (char) 0xe9); + scratch.add("class Utf8{}"); + Files.write(testFile.toPath(), scratch, Charset.forName("UTF-8"), + CREATE, TRUNCATE_EXISTING); + } + static class MyDiagnosticListener implements DiagnosticListener { boolean error = false; public void report(Diagnostic diagnostic) { @@ -55,7 +72,7 @@ public class T6437999 extends ToolTester { dl.error = false; fm = getFileManager(tool, dl, Charset.forName("ASCII")); fm.handleOption("-source", sourceLevel.iterator()); - files = fm.getJavaFileObjects(new File(test_src, "Utf8.java")); + files = fm.getJavaFileObjects(testFile); tool.getTask(null, fm, null, null, null, files).call(); if (!dl.error) throw new AssertionError("No error in ASCII mode"); @@ -63,12 +80,12 @@ public class T6437999 extends ToolTester { dl.error = false; fm = getFileManager(tool, dl, Charset.forName("UTF-8")); fm.handleOption("-source", sourceLevel.iterator()); - files = fm.getJavaFileObjects(new File(test_src, "Utf8.java")); + files = fm.getJavaFileObjects(testFile); task = tool.getTask(null, fm, null, null, null, files); if (dl.error) throw new AssertionError("Error in UTF-8 mode"); } - public static void main(String... args) { + public static void main(String... args) throws IOException { new T6437999().test(args); } } diff --git a/langtools/test/tools/javac/api/6437999/Utf8.java b/langtools/test/tools/javac/api/6437999/Utf8.java deleted file mode 100644 index fc534d4c5e0..00000000000 --- a/langtools/test/tools/javac/api/6437999/Utf8.java +++ /dev/null @@ -1,27 +0,0 @@ -/* - * Copyright (c) 2006, 2013, 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. - */ - -/** - * @author Peter von der Ah\u00e9 - */ -class Utf8 {} diff --git a/langtools/test/tools/javac/api/T6306137.java b/langtools/test/tools/javac/api/T6306137.java index 826fe51fe96..c17283c99d8 100644 --- a/langtools/test/tools/javac/api/T6306137.java +++ b/langtools/test/tools/javac/api/T6306137.java @@ -31,8 +31,14 @@ */ import java.io.File; +import java.io.IOException; +import java.nio.charset.Charset; +import java.nio.file.Files; +import java.util.ArrayList; import java.util.Arrays; +import java.util.List; import javax.tools.*; +import static java.nio.file.StandardOpenOption.*; public class T6306137 { boolean error; @@ -40,8 +46,9 @@ public class T6306137 { final JavaCompiler compiler; Iterable files; DiagnosticListener dl; + final File testFile = new File("Utf8.java"); - T6306137() { + T6306137() throws IOException { dl = new DiagnosticListener() { public void report(Diagnostic message) { if (message.getKind() == Diagnostic.Kind.ERROR) @@ -56,11 +63,17 @@ public class T6306137 { }; compiler = ToolProvider.getSystemJavaCompiler(); fm = compiler.getStandardFileManager(dl, null, null); - String srcdir = System.getProperty("test.src"); files = - fm.getJavaFileObjectsFromFiles(Arrays.asList(new File(srcdir, "T6306137.java"))); + fm.getJavaFileObjectsFromFiles(Arrays.asList(testFile)); + createTestFile(); + } + final void createTestFile() throws IOException { + List scratch = new ArrayList<>(); + scratch.add("// @author Peter von der Ah" + (char)0xe9); + scratch.add("class Utf8{}"); + Files.write(testFile.toPath(), scratch, Charset.forName("UTF-8"), + CREATE, TRUNCATE_EXISTING); } - void test(String encoding, boolean good) { error = false; Iterable args = Arrays.asList("-source", "6", "-encoding", encoding, "-d", "."); @@ -74,7 +87,7 @@ public class T6306137 { } } - public static void main(String[] args) { + public static void main(String[] args) throws IOException { T6306137 self = new T6306137(); self.test("utf-8", true); self.test("ascii", false);