1 /*
  2  * Copyright (c) 2021, Red Hat, Inc. All rights reserved.
  3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  4  *
  5  * This code is free software; you can redistribute it and/or modify it
  6  * under the terms of the GNU General Public License version 2 only, as
  7  * published by the Free Software Foundation.
  8  *
  9  * This code is distributed in the hope that it will be useful, but WITHOUT
 10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 12  * version 2 for more details (a copy is included in the LICENSE file that
 13  * accompanied this code).
 14  *
 15  * You should have received a copy of the GNU General Public License version
 16  * 2 along with this work; if not, write to the Free Software Foundation,
 17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 18  *
 19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 20  * or visit www.oracle.com if you need additional information or have any
 21  * questions.
 22  *
 23  */
 24 
 25 /*
 26  * @test id=passive
 27  * @library /test/lib
 28  * @modules jdk.attach/com.sun.tools.attach
 29  * @requires vm.gc.Shenandoah
 30  *
 31  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 32  *      -XX:+UseShenandoahGC -XX:ShenandoahGCMode=passive
 33  *      -XX:+ShenandoahDegeneratedGC
 34  *      TestJcmdHeapDump
 35  *
 36  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 37  *      -XX:+UseShenandoahGC -XX:ShenandoahGCMode=passive
 38  *      -XX:-ShenandoahDegeneratedGC
 39  *      TestJcmdHeapDump
 40  */
 41 
 42 /*
 43  * @test id=aggressive
 44  * @library /test/lib
 45  * @modules jdk.attach/com.sun.tools.attach
 46  * @requires vm.gc.Shenandoah
 47  *
 48  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 49  *      -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive
 50  *      -XX:+ShenandoahOOMDuringEvacALot
 51  *      TestJcmdHeapDump
 52  *
 53  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 54  *      -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive
 55  *      -XX:+ShenandoahAllocFailureALot
 56  *      TestJcmdHeapDump
 57  *
 58  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 59  *      -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=aggressive
 60  *      TestJcmdHeapDump
 61  */
 62 
 63 /*
 64  * @test id=adaptive
 65  * @library /test/lib
 66  * @modules jdk.attach/com.sun.tools.attach
 67  * @requires vm.gc.Shenandoah
 68  *
 69  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 70  *      -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=adaptive
 71  *      -Dtarget=10000
 72  *      TestJcmdHeapDump
 73  */
 74 
 75 /*
 76  * @test id=static
 77  * @library /test/lib
 78  * @modules jdk.attach/com.sun.tools.attach
 79  * @requires vm.gc.Shenandoah
 80  *
 81  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 82  *      -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=static
 83  *      TestJcmdHeapDump
 84  */
 85 
 86 /*
 87  * @test id=compact
 88  * @library /test/lib
 89  * @modules jdk.attach/com.sun.tools.attach
 90  * @requires vm.gc.Shenandoah
 91  *
 92  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
 93  *      -XX:+UseShenandoahGC -XX:ShenandoahGCHeuristics=compact
 94  *     TestJcmdHeapDump
 95  */
 96 
 97 /*
 98  * @test id=iu-aggressive
 99  * @library /test/lib
100  * @modules jdk.attach/com.sun.tools.attach
101  * @requires vm.gc.Shenandoah
102  *
103  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
104  *      -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive
105  *      -XX:+ShenandoahOOMDuringEvacALot
106  *      TestJcmdHeapDump
107  *
108  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
109  *      -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive
110  *      -XX:+ShenandoahAllocFailureALot
111  *      TestJcmdHeapDump
112  *
113  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
114  *      -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu -XX:ShenandoahGCHeuristics=aggressive
115  *      TestJcmdHeapDump
116  */
117 
118 /*
119  * @test id=iu
120  * @requires vm.gc.Shenandoah
121  * @library /test/lib
122  * @modules jdk.attach/com.sun.tools.attach
123  *
124  * @run main/othervm/timeout=480 -Xmx16m -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
125  *      -XX:+UseShenandoahGC -XX:ShenandoahGCMode=iu
126  *      TestJcmdHeapDump
127  */
128 
129 import jdk.test.lib.JDKToolLauncher;
130 import jdk.test.lib.process.ProcessTools;
131 import jdk.test.lib.process.OutputAnalyzer;
132 
133 import java.io.File;
134 
135 public class TestJcmdHeapDump {
136     public static void main(String[] args) {
137         long pid = ProcessHandle.current().pid();
138         JDKToolLauncher jcmd = JDKToolLauncher.createUsingTestJDK("jcmd");
139         jcmd.addToolArg(String.valueOf(pid));
140         jcmd.addToolArg("GC.heap_dump");
141         String dumpFileName = "myheapdump" + String.valueOf(pid);
142         jcmd.addToolArg(dumpFileName);
143 
144         try {
145             OutputAnalyzer output = ProcessTools.executeProcess(jcmd.getCommand());
146             output.shouldHaveExitValue(0);
147         } catch (Exception e) {
148             throw new RuntimeException("Test failed: " + e);
149         }
150 
151         File f = new File(dumpFileName);
152         if (f.exists()) {
153             f.delete();
154         } else {
155             throw new RuntimeException("Dump file not created");
156         }
157     }
158 }