From e2fb68680e28c68653110dfe6aa6f45dbe4acbff Mon Sep 17 00:00:00 2001 From: Erik Gahlin Date: Mon, 21 May 2018 14:46:12 +0200 Subject: [PATCH] 8198337: -XX:StartFlightRecording=dumponexit=true,disk=false doesn't work Reviewed-by: mgronlun --- .../share/classes/jdk/jfr/internal/PlatformRecorder.java | 8 ++++---- .../share/classes/jdk/jfr/internal/PlatformRecording.java | 2 +- test/jdk/jdk/jfr/startupargs/TestDumpOnExit.java | 7 +++++++ 3 files changed, 12 insertions(+), 5 deletions(-) diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java index fc782741648..084cd70c9b3 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java @@ -245,7 +245,7 @@ public final class PlatformRecorder { RequestEngine.doChunkBegin(); } - synchronized void stop(PlatformRecording recording) { + synchronized void stop(PlatformRecording recording, WriteableUserPath alternativePath) { RecordingState state = recording.getState(); if (Utils.isAfter(state, RecordingState.RUNNING)) { @@ -278,7 +278,7 @@ public final class PlatformRecorder { } } else { // last memory - dumpMemoryToDestination(recording); + dumpMemoryToDestination(recording, alternativePath); } jvm.endRecording_(); disableEvents(); @@ -314,8 +314,8 @@ public final class PlatformRecorder { } } - private void dumpMemoryToDestination(PlatformRecording recording) { - WriteableUserPath dest = recording.getDestination(); + private void dumpMemoryToDestination(PlatformRecording recording, WriteableUserPath alternativePath) { + WriteableUserPath dest = alternativePath != null ? alternativePath : recording.getDestination(); if (dest != null) { MetadataRepository.getInstance().setOutput(dest.getText()); recording.clearDestination(); diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java index 868b9c2c2d5..4128fd313ea 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecording.java @@ -161,7 +161,7 @@ public final class PlatformRecording implements AutoCloseable { stopTask.cancel(); stopTask = null; } - recorder.stop(this); + recorder.stop(this, alternativePath); String endTExt = reason == null ? "" : ". Reason \"" + reason + "\"."; Logger.log(LogTag.JFR, LogLevel.INFO, "Stopped recording \"" + recording.getName() + "\" (" + recording.getId()+ ")" + endTExt); this.stopTime = Instant.now(); diff --git a/test/jdk/jdk/jfr/startupargs/TestDumpOnExit.java b/test/jdk/jdk/jfr/startupargs/TestDumpOnExit.java index 8ca2a8b4f9e..239fcbdbce0 100644 --- a/test/jdk/jdk/jfr/startupargs/TestDumpOnExit.java +++ b/test/jdk/jdk/jfr/startupargs/TestDumpOnExit.java @@ -56,6 +56,13 @@ public class TestDumpOnExit { "-XX:StartFlightRecording=filename=./dumped.jfr,dumponexit=true,settings=profile", "jdk.jfr.startupargs.TestDumpOnExit$TestMain" ); + // Test a memory recording without a security manager + testDumponExit(() -> findJFRFileInCurrentDirectory(), + "-Xlog:jfr=trace", + "-XX:StartFlightRecording=dumponexit=true,disk=false", + "jdk.jfr.startupargs.TestDumpOnExit$TestMain" + ); + // Test with security manager and a file name relative to current directory testDumponExit(() -> dumpPath, "-Xlog:jfr=trace",