/* * Copyright (c) 2019, 2022, 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.
*/
/* Returns false if the attempt should be retried. */ publicstaticboolean printStackTraces(String file, boolean allowRetry) throws IOException { try {
String output = HprofReader.getStack(file, 0); // We only require JShellToolProvider to be in the output if we did the // short sleep. If we did not, the java process may not have executed far // enough along to even start the main thread. if (doSleep && !output.contains("JShellToolProvider")) { // This check will very rarely fail due to not be able to get the stack trace // of the main thread do to it actively executing. See JDK-8269556. We retry once // if that happens. This failure is so rare that this should be enough to make it // extremely unlikely that we ever see this test fail again for this reason. if (!allowRetry) { thrownew RuntimeException("'JShellToolProvider' missing from stdout/stderr");
} else {
System.out.println("'JShellToolProvider' missing. Allow one retry."); returntrue; // Allow one retry
}
}
} catch (Exception ex) { thrownew RuntimeException("Test ERROR " + ex, ex);
} returnfalse;
}
/* Returns false if the attempt should be retried. */ publicstaticboolean testHeapDump(boolean allowRetry) throws IOException {
File hprofFile = new File("jhsdb.jmap.heap." +
System.currentTimeMillis() + ".hprof"); if (hprofFile.exists()) {
hprofFile.delete();
}
launch("heap written to", "jmap", "--binaryheap", "--dumpfile=" + hprofFile.getAbsolutePath());
long elapsedTime = System.currentTimeMillis() - startTime;
System.out.println("Jshell Started in " + elapsedTime + "ms");
// Give jshell a chance to fully start up. This makes SA more stable for the jmap dump. try { if (doSleep) { Thread.sleep(4000);
}
} catch (Exception e) {
}
}
publicstaticvoid main(String[] args) throws Exception {
SATestUtils.skipIfCannotAttach(); // throws SkippedException if attach not expected to work. if (args.length == 1) { if (args[0].equals("nosleep")) {
doSleep = false;
} else { thrownew RuntimeException("Invalid arg: " + args[0]);
}
} elseif (args.length != 0) { thrownew RuntimeException("Too many args: " + args.length);
}
boolean retry = testHeapDump(true); // In case of rare failure to find 'JShellToolProvider' in the output, allow one retry. if (retry) {
testHeapDump(false);
}
// The test throws RuntimeException on error. // IOException is thrown if Jshell can't start because of some bad // environment condition
System.out.println("Test PASSED");
}
}
Messung V0.5
¤ Dauer der Verarbeitung: 0.12 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.