103 lines
3.7 KiB
Java
103 lines
3.7 KiB
Java
|
/*
|
||
|
* Copyright (c) 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.
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* @test
|
||
|
* @summary Checks that -XX:CompileCommand=PrintMemStat,... works
|
||
|
* @library /test/lib
|
||
|
* @run driver compiler.print.CompileCommandPrintMemStat
|
||
|
*/
|
||
|
|
||
|
package compiler.print;
|
||
|
|
||
|
import jdk.test.lib.process.OutputAnalyzer;
|
||
|
import jdk.test.lib.process.ProcessTools;
|
||
|
|
||
|
import java.util.ArrayList;
|
||
|
import java.util.List;
|
||
|
|
||
|
public class CompileCommandPrintMemStat {
|
||
|
|
||
|
final static String METHOD1 = "method1";
|
||
|
final static String METHOD2 = "method2";
|
||
|
|
||
|
public static void main(String[] args) throws Exception {
|
||
|
test(METHOD1, METHOD2);
|
||
|
test(METHOD2, METHOD1);
|
||
|
}
|
||
|
|
||
|
private static void test(String include, String exclude) throws Exception {
|
||
|
List<String> options = new ArrayList<String>();
|
||
|
options.add("-Xcomp");
|
||
|
options.add("-XX:-Inline");
|
||
|
options.add("-XX:CompileCommand=compileonly," + getTestClass() + "::*");
|
||
|
options.add("-XX:CompileCommand=MemStat," + getTestMethod(include) + ",print");
|
||
|
options.add(getTestClass());
|
||
|
|
||
|
OutputAnalyzer oa = ProcessTools.executeTestJvm(options);
|
||
|
|
||
|
// We expect two printouts for "PrintMemStat". A line at compilation time, and a line in a summary report
|
||
|
// that is printed when we exit. Both use the typical <class>::name format but use / as separator and also
|
||
|
// print the signature.
|
||
|
String expectedNameIncl = getTestMethod(include)
|
||
|
.replace('.', '/')
|
||
|
.replace("$", "\\$");
|
||
|
String expectedNameExcl = getTestMethod(exclude)
|
||
|
.replace('.', '/')
|
||
|
.replace("$", "\\$");
|
||
|
|
||
|
// Should see trace output when methods are compiled
|
||
|
oa.shouldHaveExitValue(0)
|
||
|
.shouldMatch(".*" + expectedNameIncl + ".*")
|
||
|
.shouldNotMatch(".*" + expectedNameExcl + ".*");
|
||
|
|
||
|
// Should see final report
|
||
|
// Looks like this:
|
||
|
// total NA RA #nodes time type #rc thread method
|
||
|
// 621832 0 589104 0 0,025 c1 1 0x00007f5ccc1951a0 java/util/zip/ZipFile$Source::checkAndAddEntry((II)I)
|
||
|
oa.shouldMatch("total.*method");
|
||
|
oa.shouldMatch("\\d+ +\\d+ +\\d+ +\\d+.*" + expectedNameIncl + ".*");
|
||
|
oa.shouldNotMatch("\\d+ +\\d+ +\\d+ +\\d+.*" + expectedNameExcl + ".*");
|
||
|
}
|
||
|
|
||
|
// Test class that is invoked by the sub process
|
||
|
public static String getTestClass() {
|
||
|
return TestMain.class.getName();
|
||
|
}
|
||
|
|
||
|
public static String getTestMethod(String method) {
|
||
|
return getTestClass() + "::" + method;
|
||
|
}
|
||
|
|
||
|
public static class TestMain {
|
||
|
public static void main(String[] args) {
|
||
|
method1();
|
||
|
method2();
|
||
|
}
|
||
|
|
||
|
static void method1() {}
|
||
|
static void method2() {}
|
||
|
}
|
||
|
}
|
||
|
|