annotate test/gc/TestGCLogRotationViaJcmd.java @ 20543:e7d0505c8a30

8059758: Footprint regressions with JDK-8038423 Summary: Changes in JDK-8038423 always initialize (zero out) virtual memory used for auxiliary data structures. This causes a footprint regression for G1 in startup benchmarks. This is because they do not touch that memory at all, so the operating system does not actually commit these pages. The fix is to, if the initialization value of the data structures matches the default value of just committed memory (=0), do not do anything. Reviewed-by: jwilhelm, brutisso
author tschatzl
date Fri, 10 Oct 2014 15:51:58 +0200
parents f42c10a3d4b1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
17827
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
1 /*
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
2 * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
4 *
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
7 * published by the Free Software Foundation.
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
8 *
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
13 * accompanied this code).
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
14 *
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
18 *
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
21 * questions.
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
22 */
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
23
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
24 /*
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
25 * @test TestGCLogRotationViaJcmd.java
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
26 * @bug 7090324
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
27 * @summary test for gc log rotation via jcmd
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
28 * @library /testlibrary
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
29 * @run main/othervm -Xloggc:test.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=3 TestGCLogRotationViaJcmd
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
30 *
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
31 */
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
32 import com.oracle.java.testlibrary.*;
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
33 import java.io.File;
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
34 import java.io.FilenameFilter;
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
35
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
36 public class TestGCLogRotationViaJcmd {
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
37
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
38 static final File currentDirectory = new File(".");
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
39 static final String LOG_FILE_NAME = "test.log";
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
40 static final int NUM_LOGS = 3;
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
41
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
42 static FilenameFilter logFilter = new FilenameFilter() {
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
43 @Override
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
44 public boolean accept(File dir, String name) {
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
45 return name.startsWith(LOG_FILE_NAME);
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
46 }
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
47 };
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
48
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
49 public static void main(String[] args) throws Exception {
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
50 // Grab the pid from the current java process
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
51 String pid = Integer.toString(ProcessTools.getProcessId());
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
52
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
53 // Create a JDKToolLauncher
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
54 JDKToolLauncher jcmd = JDKToolLauncher.create("jcmd")
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
55 .addToolArg(pid)
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
56 .addToolArg("GC.rotate_log");
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
57
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
58 for (int times = 1; times < NUM_LOGS; times++) {
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
59 // Run jcmd <pid> GC.rotate_log
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
60 ProcessBuilder pb = new ProcessBuilder(jcmd.getCommand());
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
61
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
62 // Make sure we didn't crash
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
63 OutputAnalyzer output = new OutputAnalyzer(pb.start());
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
64 output.shouldHaveExitValue(0);
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
65 }
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
66
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
67 // GC log check
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
68 File[] logs = currentDirectory.listFiles(logFilter);
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
69 if (logs.length != NUM_LOGS) {
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
70 throw new Error("There are only " + logs.length
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
71 + " logs instead " + NUM_LOGS);
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
72 }
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
73
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
74 }
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
75
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
76 }
f42c10a3d4b1 7090324: gclog rotation via external tool
minqi
parents:
diff changeset
77