From 4ca3a232d1905e95e0a176295b82b7c771e1d70b Mon Sep 17 00:00:00 2001 From: Sonali Goel Date: Tue, 4 Nov 2014 13:21:25 -0800 Subject: [PATCH] 8062314: Update tools/javac/plugin/showtype/Test.java to use ToolBox.java Reviewed-by: jjg --- .../tools/javac/plugin/showtype/Test.java | 78 +++++++------------ langtools/test/tools/lib/ToolBox.java | 2 +- 2 files changed, 30 insertions(+), 50 deletions(-) diff --git a/langtools/test/tools/javac/plugin/showtype/Test.java b/langtools/test/tools/javac/plugin/showtype/Test.java index 177eb394d2e..d8a2a2c5568 100644 --- a/langtools/test/tools/javac/plugin/showtype/Test.java +++ b/langtools/test/tools/javac/plugin/showtype/Test.java @@ -24,6 +24,9 @@ /** * @test * @bug 8001098 8004961 8004082 + * @library /tools/lib + * @build ToolBox + * @run main Test * @summary Provide a simple light-weight "plug-in" mechanism for javac */ @@ -58,14 +61,16 @@ public class Test { final List ref2; final JavaCompiler compiler; final StandardJavaFileManager fm; + ToolBox tb = new ToolBox(); Test() throws Exception { - testSrc = new File(System.getProperty("test.src")); + testSrc = new File(tb.testSrc); pluginSrc = new File(testSrc, "ShowTypePlugin.java"); pluginClasses = new File("plugin"); + tb.createDirectories(pluginClasses.toPath()); pluginJar = new File("plugin.jar"); - ref1 = readFile(testSrc, "Identifiers.out"); - ref2 = readFile(testSrc, "Identifiers_PI.out"); + ref1 = tb.readAllLines((new File(testSrc,"Identifiers.out")).toPath()); + ref2 = tb.readAllLines((new File(testSrc,"Identifiers_PI.out")).toPath()); compiler = ToolProvider.getSystemJavaCompiler(); fm = compiler.getStandardFileManager(null, null, null); } @@ -74,11 +79,15 @@ public class Test { try { // compile the plugin explicitly, to a non-standard directory // so that we don't find it on the wrong path by accident - pluginClasses.mkdirs(); - compile("-d", pluginClasses.getPath(), pluginSrc.getPath()); - writeFile(new File(pluginClasses, "META-INF/services/com.sun.source.util.Plugin"), - "ShowTypePlugin\n"); - jar("cf", pluginJar.getPath(), "-C", pluginClasses.getPath(), "."); + tb.new JavacTask() + .options("-d", pluginClasses.getPath()) + .files(pluginSrc.getPath()) + .run(); + + File plugin = new File(pluginClasses.getPath(), "META-INF/services/com.sun.source.util.Plugin"); + tb.writeFile(plugin.getPath(),"ShowTypePlugin"); + tb.new JarTask() + .run("cf", pluginJar.getPath(),"-C", pluginClasses.getPath(), "."); testCommandLine("-Xplugin:showtype", ref1); testCommandLine("-Xplugin:showtype PI", ref2); @@ -100,14 +109,13 @@ public class Test { Iterable files = fm.getJavaFileObjects(identifiers); System.err.println("test api: " + options + " " + files); - - StringWriter sw = new StringWriter(); - PrintWriter pw = new PrintWriter(sw); - boolean ok = compiler.getTask(pw, fm, null, options, null, files).call(); - String out = sw.toString(); - System.err.println(out); - if (!ok) - error("testCommandLine: compilation failed"); + ToolBox.Result result = tb.new JavacTask(ToolBox.Mode.API) + .fileManager(fm) + .options(opt) + .files(identifiers.toPath()) + .run(ToolBox.Expect.SUCCESS) + .writeAll(); + String out = result.getOutput(ToolBox.OutputKind.DIRECT); checkOutput(out, ref); } @@ -120,14 +128,11 @@ public class Test { identifiers.getPath() }; System.err.println("test command line: " + Arrays.asList(args)); - - StringWriter sw = new StringWriter(); - PrintWriter pw = new PrintWriter(sw); - int rc = com.sun.tools.javac.Main.compile(args, pw); - String out = sw.toString(); - System.err.println(out); - if (rc != 0) - error("testCommandLine: compilation failed"); + ToolBox.Result result = tb.new JavacTask(ToolBox.Mode.CMDLINE) + .options(args) + .run(ToolBox.Expect.SUCCESS) + .writeAll(); + String out = result.getOutput(ToolBox.OutputKind.DIRECT); checkOutput(out, ref); } @@ -140,31 +145,6 @@ public class Test { } } - private void compile(String... args) throws Exception { - System.err.println("compile: " + Arrays.asList(args)); - int rc = com.sun.tools.javac.Main.compile(args); - if (rc != 0) - throw new Exception("compiled failed, rc=" + rc); - } - - private void jar(String... args) throws Exception { - System.err.println("jar: " + Arrays.asList(args)); - boolean ok = new sun.tools.jar.Main(System.out, System.err, "jar").run(args); - if (!ok) - throw new Exception("jar failed"); - } - - private List readFile(File dir, String name) throws IOException { - return Files.readAllLines(new File(dir, name).toPath(), Charset.defaultCharset()); - } - - private void writeFile(File f, String body) throws IOException { - f.getParentFile().mkdirs(); - try (FileWriter out = new FileWriter(f)) { - out.write(body); - } - } - private void error(String msg) { System.err.println(msg); errors++; diff --git a/langtools/test/tools/lib/ToolBox.java b/langtools/test/tools/lib/ToolBox.java index 1ccc8e3e6a9..9d17cf4ff4e 100644 --- a/langtools/test/tools/lib/ToolBox.java +++ b/langtools/test/tools/lib/ToolBox.java @@ -1475,7 +1475,7 @@ public class ToolBox { @Override public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) { try { - JarEntry e = new JarEntry(base.relativize(file).toString()); + JarEntry e = new JarEntry(base.relativize(file).normalize().toString()); jos.putNextEntry(e); jos.write(Files.readAllBytes(file)); jos.closeEntry();