Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/test/sun/management/HotspotRuntimeMBean/GetSafepointSyncTime.java
38841 views
/*1* Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* @test25* @bug 485852226* @summary Basic unit test of HotspotRuntimeMBean.getSafepointSyncTime()27* @author Steve Bohne28*/2930/*31* This test is just a sanity check and does not check for the correct value.32*/3334import sun.management.*;3536public class GetSafepointSyncTime {3738private static HotspotRuntimeMBean mbean =39(HotspotRuntimeMBean)ManagementFactoryHelper.getHotspotRuntimeMBean();4041private static final long NUM_THREAD_DUMPS = 300;4243// Careful with these values.44private static final long MIN_VALUE_FOR_PASS = 1;45private static final long MAX_VALUE_FOR_PASS = Long.MAX_VALUE;4647public static void main(String args[]) throws Exception {48long count = mbean.getSafepointCount();49long value = mbean.getSafepointSyncTime();5051// Thread.getAllStackTraces() should cause safepoints.52// If this test is failing because it doesn't,53// MIN_VALUE_FOR_PASS should be reset to 054for (int i = 0; i < NUM_THREAD_DUMPS; i++) {55Thread.getAllStackTraces();56}5758long count1 = mbean.getSafepointCount();59long value1 = mbean.getSafepointSyncTime();6061System.out.format("Safepoint count=%d (diff=%d), sync time=%d ms (diff=%d)%n",62count1, count1-count, value1, value1-value);6364if (value1 < MIN_VALUE_FOR_PASS || value1 > MAX_VALUE_FOR_PASS) {65throw new RuntimeException("Safepoint sync time " +66"illegal value: " + value1 + " ms " +67"(MIN = " + MIN_VALUE_FOR_PASS + "; " +68"MAX = " + MAX_VALUE_FOR_PASS + ")");69}7071for (int i = 0; i < NUM_THREAD_DUMPS; i++) {72Thread.getAllStackTraces();73}7475long count2 = mbean.getSafepointCount();76long value2 = mbean.getSafepointSyncTime();7778System.out.format("Safepoint count=%d (diff=%d), sync time=%d ms (diff=%d)%n",79count2, count2-count1, value2, value2-value1);8081if (value2 <= value1) {82throw new RuntimeException("Safepoint sync time " +83"did not increase " +84"(value1 = " + value1 + "; " +85"value2 = " + value2 + ")");86}8788System.out.println("Test passed.");89}90}919293