test/tools/javac/api/T6306137.java

Tue, 05 Feb 2013 18:55:13 +0000

author
jjh
date
Tue, 05 Feb 2013 18:55:13 +0000
changeset 1546
2480aec9a3f1
parent 554
9d9f26857129
child 1553
b386b8c45387
permissions
-rw-r--r--

8007504: Remove @ignore from tests that no longer need it
Reviewed-by: mcimadamore

duke@1 1 /*
ohair@554 2 * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved.
duke@1 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@1 4 *
duke@1 5 * This code is free software; you can redistribute it and/or modify it
duke@1 6 * under the terms of the GNU General Public License version 2 only, as
duke@1 7 * published by the Free Software Foundation.
duke@1 8 *
duke@1 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@1 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@1 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@1 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@1 13 * accompanied this code).
duke@1 14 *
duke@1 15 * You should have received a copy of the GNU General Public License version
duke@1 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@1 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@1 18 *
ohair@554 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
ohair@554 20 * or visit www.oracle.com if you need additional information or have any
ohair@554 21 * questions.
duke@1 22 */
duke@1 23
duke@1 24 /*
duke@1 25 * @test
duke@1 26 * @bug 6306137
duke@1 27 * @summary JSR 199: encoding option doesn't affect standard file manager
duke@1 28 * @author Peter von der Ahé
duke@1 29 */
duke@1 30
duke@1 31 import java.io.File;
duke@1 32 import java.util.Arrays;
duke@1 33 import javax.tools.*;
duke@1 34
duke@1 35 public class T6306137 {
duke@1 36 boolean error;
duke@1 37 final StandardJavaFileManager fm;
duke@1 38 final JavaCompiler compiler;
duke@1 39 Iterable<? extends JavaFileObject> files;
duke@1 40 DiagnosticListener<JavaFileObject> dl;
duke@1 41
duke@1 42 T6306137() {
duke@1 43 dl = new DiagnosticListener<JavaFileObject>() {
duke@1 44 public void report(Diagnostic<? extends JavaFileObject> message) {
duke@1 45 if (message.getKind() == Diagnostic.Kind.ERROR)
duke@1 46 error = true;
duke@1 47 System.out.println(message.getSource()
duke@1 48 +":"+message.getStartPosition()+":"
duke@1 49 +message.getStartPosition()+":"+message.getPosition());
duke@1 50 System.out.println(message.toString());
duke@1 51 System.out.format("Found problem: %s%n", message.getCode());
duke@1 52 System.out.flush();
duke@1 53 }
duke@1 54 };
duke@1 55 compiler = ToolProvider.getSystemJavaCompiler();
duke@1 56 fm = compiler.getStandardFileManager(dl, null, null);
duke@1 57 String srcdir = System.getProperty("test.src");
duke@1 58 files =
duke@1 59 fm.getJavaFileObjectsFromFiles(Arrays.asList(new File(srcdir, "T6306137.java")));
duke@1 60 }
duke@1 61
duke@1 62 void test(String encoding, boolean good) {
duke@1 63 error = false;
duke@1 64 Iterable<String> args = Arrays.asList("-source", "6", "-encoding", encoding, "-d", ".");
duke@1 65 compiler.getTask(null, fm, dl, args, null, files).call();
duke@1 66 if (error == good) {
duke@1 67 if (error) {
duke@1 68 throw new AssertionError("Error reported");
duke@1 69 } else {
duke@1 70 throw new AssertionError("No error reported");
duke@1 71 }
duke@1 72 }
duke@1 73 }
duke@1 74
duke@1 75 public static void main(String[] args) {
duke@1 76 T6306137 self = new T6306137();
duke@1 77 self.test("utf-8", true);
duke@1 78 self.test("ascii", false);
duke@1 79 self.test("utf-8", true);
duke@1 80 }
duke@1 81 }

mercurial