1 /* 2 * Copyright (c) 2015, 2016, Oracle and/or its affiliates. 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 import org.testng.annotations.Test; 25 26 import java.util.regex.Pattern; 27 28 import jdk.test.lib.OutputAnalyzer; 29 import jdk.test.lib.dcmd.CommandExecutor; 30 import jdk.test.lib.dcmd.JMXExecutor; 31 32 /* 33 * @test 34 * @summary Test of diagnostic command GC.class_histogram 35 * @library /testlibrary 36 * @modules java.base/jdk.internal.misc 37 * java.compiler 38 * java.management 39 * jdk.jvmstat/sun.jvmstat.monitor 40 * @build jdk.test.lib.* 41 * @build jdk.test.lib.dcmd.* 42 * @run testng ClassHistogramTest 43 */ 44 public class ClassHistogramTest { 45 public static class TestClass {} 46 public static TestClass[] instances = new TestClass[1024]; 47 protected String classHistogramArgs = ""; 48 49 static { 50 for (int i = 0; i < instances.length; ++i) { 51 instances[i] = new TestClass(); 52 } 53 } 54 55 public void run(CommandExecutor executor) { 56 OutputAnalyzer output = executor.execute("GC.class_histogram " + classHistogramArgs); 57 58 /* 59 * example output: 60 * num #instances #bytes class name (module) 61 * ------------------------------------------------------- 62 * 1: 7991 757792 [B (java.base@9-internal) 63 * 2: 1811 217872 java.lang.Class (java.base@9-internal) 64 * 3: 6724 215168 java.util.HashMap$Node (java.base@9-internal) 65 * 4: 7852 188448 java.lang.String (java.base@9-internal) 66 * 5: 1378 105040 [Ljava.util.HashMap$Node; (java.base@9-internal) 67 * 6: 1863 95096 [Ljava.lang.Object; (java.base@9-internal) 68 69 * ... 70 */ 71 72 /* Require at least one java.lang.Class */ 73 output.shouldMatch("^\\s+\\d+:\\s+\\d+\\s+\\d+\\s+java.lang.Class \\(java.base@\\S*\\)\\s*$"); 74 75 /* Require at least one java.lang.String */ 76 output.shouldMatch("^\\s+\\d+:\\s+\\d+\\s+\\d+\\s+java.lang.String \\(java.base@\\S*\\)\\s*$"); 77 78 /* Require at least one java.lang.Object */ 79 output.shouldMatch("^\\s+\\d+:\\s+\\d+\\s+\\d+\\s+java.lang.Object \\(java.base@\\S*\\)\\s*$"); 80 81 /* Require at exactly one TestClass[] */ 82 output.shouldMatch("^\\s+\\d+:\\s+1\\s+\\d+\\s+" + 83 Pattern.quote(TestClass[].class.getName()) + "\\s*$"); 84 85 /* Require at exactly 1024 TestClass */ 86 output.shouldMatch("^\\s+\\d+:\\s+1024\\s+\\d+\\s+" + 87 Pattern.quote(TestClass.class.getName()) + "\\s*$"); 88 } 89 90 @Test 91 public void jmx() { 92 run(new JMXExecutor()); 93 } 94 }