From e18b3df11beddc20c45659508bfdda04ceb3a5a8 Mon Sep 17 00:00:00 2001 From: egahlin Date: Thu, 6 Dec 2018 23:38:22 +0100 Subject: [PATCH] 8214925: JFR tool fails to execute Reviewed-by: mgronlun, mseledtsov --- .../classes/jdk/jfr/internal/tool/Main.java | 2 +- test/jdk/jfr/tool/ExecuteHelper.java | 13 +++++++++++- test/jdk/jfr/tool/TestAssemble.java | 15 +++++++------ test/jdk/jfr/tool/TestDisassemble.java | 21 +++++++++---------- test/jdk/jfr/tool/TestHelp.java | 7 +++---- test/jdk/jfr/tool/TestMetadata.java | 7 +++---- test/jdk/jfr/tool/TestPrint.java | 7 +++---- test/jdk/jfr/tool/TestPrintDefault.java | 3 +-- test/jdk/jfr/tool/TestPrintJSON.java | 3 +-- test/jdk/jfr/tool/TestPrintXML.java | 3 +-- test/jdk/jfr/tool/TestSummary.java | 7 +++---- 11 files changed, 45 insertions(+), 43 deletions(-) diff --git a/src/share/classes/jdk/jfr/internal/tool/Main.java b/src/share/classes/jdk/jfr/internal/tool/Main.java index 5324bafb8..785ffda91 100644 --- a/src/share/classes/jdk/jfr/internal/tool/Main.java +++ b/src/share/classes/jdk/jfr/internal/tool/Main.java @@ -72,7 +72,7 @@ public final class Main { System.out.println(); System.out.println(" jfr summary recording.jfr"); System.out.println(); - System.out.println(" jfr metadata recoding.jfr"); + System.out.println(" jfr metadata recording.jfr"); System.out.println(); System.out.println("For more information about available commands, use 'jfr help'"); System.exit(EXIT_OK); diff --git a/test/jdk/jfr/tool/ExecuteHelper.java b/test/jdk/jfr/tool/ExecuteHelper.java index 1531398fe..51347af5b 100644 --- a/test/jdk/jfr/tool/ExecuteHelper.java +++ b/test/jdk/jfr/tool/ExecuteHelper.java @@ -32,7 +32,10 @@ import java.util.regex.Pattern; import jdk.jfr.Configuration; import jdk.jfr.Event; import jdk.jfr.Recording; -import jdk.test.lib.Utils;; +import jdk.test.lib.JDKToolLauncher; +import jdk.test.lib.Utils; +import jdk.test.lib.process.OutputAnalyzer; +import jdk.test.lib.process.ProcessTools;; final class ExecuteHelper { @@ -122,4 +125,12 @@ final class ExecuteHelper { Matcher m = p.matcher("aaaaab"); m.matches(); } + + public static OutputAnalyzer jfr(String... args) throws Throwable { + JDKToolLauncher l = JDKToolLauncher.createUsingTestJDK("jfr"); + for (String arg : args) { + l.addToolArg(arg); + } + return ProcessTools.executeCommand(l.getCommand()); + } } diff --git a/test/jdk/jfr/tool/TestAssemble.java b/test/jdk/jfr/tool/TestAssemble.java index ffe00a013..e1188c4b2 100644 --- a/test/jdk/jfr/tool/TestAssemble.java +++ b/test/jdk/jfr/tool/TestAssemble.java @@ -40,7 +40,6 @@ import jdk.jfr.internal.Repository; import jdk.jfr.internal.SecuritySupport.SafePath; import jdk.test.lib.Asserts; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -89,30 +88,30 @@ public class TestAssemble { String destination = destinationPath.toAbsolutePath().toString(); // Test failure - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "assemble"); + OutputAnalyzer output = ExecuteHelper.jfr("assemble"); output.shouldContain("too few arguments"); - output = ProcessTools.executeProcess("jfr", "assemble", directory); + output = ExecuteHelper.jfr("assemble", directory); output.shouldContain("too few arguments"); - output = ProcessTools.executeProcess("jfr", "assemble", "not-a-directory", destination); + output = ExecuteHelper.jfr("assemble", "not-a-directory", destination); output.shouldContain("directory does not exist, not-a-directory"); - output = ProcessTools.executeProcess("jfr", "assemble", directory, "not-a-destination"); + output = ExecuteHelper.jfr("assemble", directory, "not-a-destination"); output.shouldContain("filename must end with '.jfr'"); - output = ProcessTools.executeProcess("jfr","assemble", "--wrongOption", directory, destination); + output = ExecuteHelper.jfr("assemble", "--wrongOption", directory, destination); output.shouldContain("too many arguments"); FileWriter fw = new FileWriter(destination); fw.write('d'); fw.close(); - output = ProcessTools.executeProcess("jfr", "assemble", directory, destination); + output = ExecuteHelper.jfr("assemble", directory, destination); output.shouldContain("already exists"); Files.delete(destinationPath); // test success - output = ProcessTools.executeProcess("jfr", "assemble", directory, destination); + output = ExecuteHelper.jfr("assemble", directory, destination); System.out.println(output.getOutput()); output.shouldContain("Finished."); diff --git a/test/jdk/jfr/tool/TestDisassemble.java b/test/jdk/jfr/tool/TestDisassemble.java index 2727f0295..f749cd5f9 100644 --- a/test/jdk/jfr/tool/TestDisassemble.java +++ b/test/jdk/jfr/tool/TestDisassemble.java @@ -37,7 +37,6 @@ import jdk.jfr.Configuration; import jdk.jfr.Recording; import jdk.jfr.consumer.RecordingFile; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -63,40 +62,40 @@ public class TestDisassemble { String fileBText = recordingFileB.toAbsolutePath().toString(); String fileCText = recordingFileC.toAbsolutePath().toString(); - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "disassemble"); + OutputAnalyzer output = ExecuteHelper.jfr("disassemble"); output.shouldContain("missing file"); - output = ProcessTools.executeProcess("jfr","disassemble", "--wrongOption", fileAText); + output = ExecuteHelper.jfr("disassemble", "--wrongOption", fileAText); output.shouldContain("unknown option"); - output = ProcessTools.executeProcess("jfr","disassemble", "--wrongOption", "1", fileAText); + output = ExecuteHelper.jfr("disassemble", "--wrongOption", "1", fileAText); output.shouldContain("unknown option"); - output = ProcessTools.executeProcess("jfr","disassemble", "--max-chunks", "-3", fileAText); + output = ExecuteHelper.jfr("disassemble", "--max-chunks", "-3", fileAText); output.shouldContain("max chunks must be at least 1"); - output = ProcessTools.executeProcess("jfr","disassemble", "--max-chunks", "1000", fileAText); + output = ExecuteHelper.jfr("disassemble", "--max-chunks", "1000", fileAText); output.shouldContain("number of chunks in recording"); output.shouldContain("doesn't exceed max chunks"); - output = ProcessTools.executeProcess("jfr", "disassemble", fileAText); // maxchunks is 5 by + output = ExecuteHelper.jfr("disassemble", fileAText); // maxchunks is 5 by // default System.out.println(output.getOutput()); System.out.println(fileAText); verifyRecording(fileAText.substring(0, fileAText.length() - 4) + "_1.jfr"); verifyRecording(fileAText.substring(0, fileAText.length() - 4) + "_2.jfr"); - output = ProcessTools.executeProcess("jfr","disassemble", "--max-chunks", "2", fileBText); + output = ExecuteHelper.jfr("disassemble", "--max-chunks", "2", fileBText); verifyRecording(fileBText.substring(0, fileBText.length() - 4) + "_1.jfr"); verifyRecording(fileBText.substring(0, fileBText.length() - 4) + "_2.jfr"); verifyRecording(fileBText.substring(0, fileBText.length() - 4) + "_3.jfr"); - output = ProcessTools.executeProcess("jfr","disassemble", "--max-chunks", "2", fileBText); + output = ExecuteHelper.jfr("disassemble", "--max-chunks", "2", fileBText); output.shouldContain("file with that name already exist"); // sanity check - output = ProcessTools.executeProcess("jfr","disassemble", "--max-size", "500000", fileCText); - verifyRecording(fileCText.substring(0, fileCText.length() - 4) + "_1.jfr"); + output = ExecuteHelper.jfr("disassemble", "--max-size", "10000", fileCText); + verifyRecording(fileCText.substring(0, fileCText.length() - 4) + "_01.jfr"); } private static void verifyRecording(String name) throws IOException { diff --git a/test/jdk/jfr/tool/TestHelp.java b/test/jdk/jfr/tool/TestHelp.java index 7f0eddafb..ee5361ab1 100644 --- a/test/jdk/jfr/tool/TestHelp.java +++ b/test/jdk/jfr/tool/TestHelp.java @@ -26,7 +26,6 @@ package jdk.jfr.tool; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -38,7 +37,7 @@ import jdk.test.lib.process.ProcessTools; public class TestHelp { public static void main(String[] args) throws Throwable { - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "help"); + OutputAnalyzer output = ExecuteHelper.jfr("help"); output.shouldContain("print"); output.shouldContain("assemble"); output.shouldContain("disassemble"); @@ -46,11 +45,11 @@ public class TestHelp { output.shouldContain("summary"); output.shouldContain("help"); - output = ProcessTools.executeProcess("jfr", "help", "version"); + output = ExecuteHelper.jfr("help", "version"); output.shouldContain("Display version of the jfr tool"); output.shouldContain("jfr version"); - output = ProcessTools.executeProcess("jfr", "help", "wrongcommand"); + output = ExecuteHelper.jfr("help", "wrongcommand"); output.shouldContain("unknown command 'wrongcommand'"); } } diff --git a/test/jdk/jfr/tool/TestMetadata.java b/test/jdk/jfr/tool/TestMetadata.java index 9eaa53700..ee953e773 100644 --- a/test/jdk/jfr/tool/TestMetadata.java +++ b/test/jdk/jfr/tool/TestMetadata.java @@ -30,7 +30,6 @@ import java.nio.file.Path; import jdk.jfr.EventType; import jdk.jfr.consumer.RecordingFile; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -45,13 +44,13 @@ public class TestMetadata { Path f = ExecuteHelper.createProfilingRecording().toAbsolutePath(); String file = f.toAbsolutePath().toString(); - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "metadata"); + OutputAnalyzer output = ExecuteHelper.jfr("metadata"); output.shouldContain("missing file"); - output = ProcessTools.executeProcess("jfr", "metadata", "--wrongOption", file); + output = ExecuteHelper.jfr("metadata", "--wrongOption", file); output.shouldContain("unknown option --wrongOption"); - output = ProcessTools.executeProcess("jfr", "metadata", file); + output = ExecuteHelper.jfr("metadata", file); try (RecordingFile rf = new RecordingFile(f)) { for (EventType t : rf.readEventTypes()) { String name = t.getName(); diff --git a/test/jdk/jfr/tool/TestPrint.java b/test/jdk/jfr/tool/TestPrint.java index 8c0955267..9f632d248 100644 --- a/test/jdk/jfr/tool/TestPrint.java +++ b/test/jdk/jfr/tool/TestPrint.java @@ -31,7 +31,6 @@ import java.nio.file.Path; import jdk.test.lib.Utils; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -44,17 +43,17 @@ public class TestPrint { public static void main(String[] args) throws Throwable { - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "print"); + OutputAnalyzer output = ExecuteHelper.jfr("print"); output.shouldContain("missing file"); - output = ProcessTools.executeProcess("jfr", "print", "missing.jfr"); + output = ExecuteHelper.jfr("print", "missing.jfr"); output.shouldContain("could not find file "); Path file = Utils.createTempFile("faked-print-file", ".jfr"); FileWriter fw = new FileWriter(file.toFile()); fw.write('d'); fw.close(); - output = ProcessTools.executeProcess("jfr", "print", "--wrongOption", file.toAbsolutePath().toString()); + output = ExecuteHelper.jfr("print", "--wrongOption", file.toAbsolutePath().toString()); output.shouldContain("unknown option"); Files.delete(file); } diff --git a/test/jdk/jfr/tool/TestPrintDefault.java b/test/jdk/jfr/tool/TestPrintDefault.java index 792fb873d..98f6484c8 100644 --- a/test/jdk/jfr/tool/TestPrintDefault.java +++ b/test/jdk/jfr/tool/TestPrintDefault.java @@ -28,7 +28,6 @@ package jdk.jfr.tool; import java.nio.file.Path; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -47,7 +46,7 @@ public class TestPrintDefault { Path recordingFile = ExecuteHelper.createProfilingRecording().toAbsolutePath(); - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "print", recordingFile.toString()); + OutputAnalyzer output = ExecuteHelper.jfr("print", recordingFile.toString()); output.shouldContain("JVMInformation"); } } diff --git a/test/jdk/jfr/tool/TestPrintJSON.java b/test/jdk/jfr/tool/TestPrintJSON.java index a7e307e26..26f5e199a 100644 --- a/test/jdk/jfr/tool/TestPrintJSON.java +++ b/test/jdk/jfr/tool/TestPrintJSON.java @@ -43,7 +43,6 @@ import jdk.jfr.consumer.RecordingFile; import jdk.nashorn.api.scripting.JSObject; import jdk.test.lib.Asserts; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -62,7 +61,7 @@ public class TestPrintJSON { Path recordingFile = ExecuteHelper.createProfilingRecording().toAbsolutePath(); - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "print", "--json", "--stack-depth", "999", recordingFile.toString()); + OutputAnalyzer output = ExecuteHelper.jfr("print", "--json", "--stack-depth", "999", recordingFile.toString()); String json = output.getStdout(); // Parse JSON using Nashorn diff --git a/test/jdk/jfr/tool/TestPrintXML.java b/test/jdk/jfr/tool/TestPrintXML.java index 5ea4a3f93..589c8f4d6 100644 --- a/test/jdk/jfr/tool/TestPrintXML.java +++ b/test/jdk/jfr/tool/TestPrintXML.java @@ -58,7 +58,6 @@ import jdk.jfr.consumer.RecordedEvent; import jdk.jfr.consumer.RecordedObject; import jdk.jfr.consumer.RecordingFile; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -76,7 +75,7 @@ public class TestPrintXML { Path recordingFile = ExecuteHelper.createProfilingRecording().toAbsolutePath(); - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "print", "--xml", "--stack-depth", "9999", recordingFile.toString()); + OutputAnalyzer output = ExecuteHelper.jfr("print", "--xml", "--stack-depth", "9999", recordingFile.toString()); System.out.println(recordingFile); String xml = output.getStdout(); diff --git a/test/jdk/jfr/tool/TestSummary.java b/test/jdk/jfr/tool/TestSummary.java index 03daa5ee0..b9dc94f17 100644 --- a/test/jdk/jfr/tool/TestSummary.java +++ b/test/jdk/jfr/tool/TestSummary.java @@ -30,7 +30,6 @@ import java.nio.file.Path; import jdk.jfr.EventType; import jdk.jfr.consumer.RecordingFile; import jdk.test.lib.process.OutputAnalyzer; -import jdk.test.lib.process.ProcessTools; /** * @test @@ -45,13 +44,13 @@ public class TestSummary { Path f = ExecuteHelper.createProfilingRecording().toAbsolutePath(); String file = f.toAbsolutePath().toString(); - OutputAnalyzer output = ProcessTools.executeProcess("jfr", "summary"); + OutputAnalyzer output = ExecuteHelper.jfr("summary"); output.shouldContain("missing file"); - output = ProcessTools.executeProcess("jfr", "summary", "--wrongOption", file); + output = ExecuteHelper.jfr("summary", "--wrongOption", file); output.shouldContain("too many arguments"); - output = ProcessTools.executeProcess("jfr", "summary", file); + output = ExecuteHelper.jfr("summary", file); try (RecordingFile rf = new RecordingFile(f)) { for (EventType t : rf.readEventTypes()) { output.shouldContain(t.getName()); -- GitLab