jdk-24/test/hotspot/jtreg/runtime/ErrorHandling/ErrorFileOverwriteTest.java
Coleen Phillimore 819d2df8b0 8274794: Print all owned locks in hs_err file
Reviewed-by: stuefe, dholmes
2021-10-21 11:28:22 +00:00

124 lines
4.5 KiB
Java

/*
* Copyright (c) 2019, 2021, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2019, SAP. 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.
*/
/*
* @test
* @bug 8221738
* @summary Test that subsequent crashes will overwrite the file given to -XX:ErrorFile (unless %a is specified
* in the error file name)
* @library /test/lib
* @modules java.base/jdk.internal.misc
* @requires (vm.debug == true)
* @run driver ErrorFileOverwriteTest
*/
import jdk.test.lib.process.OutputAnalyzer;
import jdk.test.lib.process.ProcessTools;
import java.io.*;
import java.util.regex.Pattern;
public class ErrorFileOverwriteTest {
public static void do_test(boolean with_percent_p) throws Exception {
// Crash twice.
//
// Second crash should, given an error file Without %p,
// overwrite the first file. With %p it should not.
String errorFileStem = "hs_err_pid_test";
String errorFileName = errorFileStem + (with_percent_p ? "%p" : "") + ".log";
System.out.println("Testing with error file name " + errorFileName + "...");
System.out.println("First crash...");
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
"-Xmx64M",
"-XX:-CreateCoredumpOnCrash",
"-XX:ErrorHandlerTest=1",
"-XX:ErrorFile=" + errorFileName,
"-version");
OutputAnalyzer output_detail = new OutputAnalyzer(pb.start());
output_detail.shouldMatch("# A fatal error has been detected by the Java Runtime Environment:.*");
output_detail.shouldMatch("# An error report file with more information is saved as:.*");
output_detail.shouldMatch("# " + errorFileStem + ".*");
System.out.println("First crash: Found expected output on tty. Ok.");
File f = ErrorFileScanner.findHsErrorFileInOutput(output_detail);
System.out.println("First crash: Found hs error file at " + f.getAbsolutePath());
ErrorFileScanner.scanHsErrorFileForContent(f, new Pattern[] {
Pattern.compile("# *Internal Error.*"),
Pattern.compile("Command Line:.*-XX:ErrorHandlerTest=1.*-XX:ErrorFile=" + errorFileStem + ".*")
});
System.out.println("First crash: hs error content as expected. Ok.");
System.out.println("Second crash...");
pb = ProcessTools.createJavaProcessBuilder(
"-Xmx64M",
"-XX:-CreateCoredumpOnCrash",
"-XX:ErrorHandlerTest=2", // << now 2
"-XX:ErrorFile=" + errorFileName,
"-version");
output_detail = new OutputAnalyzer(pb.start());
output_detail.shouldMatch("# A fatal error has been detected by the Java Runtime Environment:.*");
output_detail.shouldMatch("# An error report file with more information is saved as:.*");
output_detail.shouldMatch("# " + errorFileStem + ".*");
System.out.println("Second crash: Found expected output on tty. Ok.");
File f2 = ErrorFileScanner.findHsErrorFileInOutput(output_detail);
System.out.println("Second crash: Found hs error file at " + f2.getAbsolutePath());
if (with_percent_p) {
if (f2.getAbsolutePath() == f.getAbsolutePath()) {
throw new RuntimeException("Unexpected overwriting of error file");
}
}
ErrorFileScanner.scanHsErrorFileForContent(f2, new Pattern[] {
Pattern.compile("# *Internal Error.*"),
Pattern.compile("Command Line:.*-XX:ErrorHandlerTest=2.*-XX:ErrorFile=" + errorFileStem + ".*")
});
System.out.println("Second crash: hs error content as expected. Ok.");
}
public static void main(String[] args) throws Exception {
do_test(false);
do_test(true);
}
}