1 /* 2 * Copyright (c) 2020, 2022, 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 package runtime.whitebox; 25 26 /* 27 * @test 28 * @bug 8246477 29 * @summary Test to verify that WB method deflateIdleMonitors works correctly. 30 * @library /test/lib 31 * @modules java.base/jdk.internal.misc 32 * java.management 33 * @build jdk.test.whitebox.WhiteBox 34 * @run driver jdk.test.lib.helpers.ClassFileInstaller jdk.test.whitebox.WhiteBox 35 * @run driver runtime.whitebox.TestWBDeflateIdleMonitors 36 */ 37 import jdk.test.lib.Asserts; 38 import jdk.test.lib.process.ProcessTools; 39 import jdk.test.lib.process.OutputAnalyzer; 40 import jdk.test.whitebox.WhiteBox; 41 42 public class TestWBDeflateIdleMonitors { 43 static final int N_DELAY = 1000; // delay between tries 44 static final int N_TRIES = 5; // number of times to try deflation 45 46 public static void main(String args[]) throws Exception { 47 ProcessBuilder pb = ProcessTools.createTestJvm( 48 "-Xbootclasspath/a:.", 49 "-XX:+UnlockDiagnosticVMOptions", 50 "-XX:+WhiteBoxAPI", 51 "-Xlog:monitorinflation=info", 52 InflateMonitorsTest.class.getName()); 53 54 OutputAnalyzer output = new OutputAnalyzer(pb.start()); 55 System.out.println(output.getStdout()); 56 output.shouldHaveExitValue(0); 57 output.shouldContain("WhiteBox initiated DeflateIdleMonitors"); 58 } 59 60 public static class InflateMonitorsTest { 61 static WhiteBox wb = WhiteBox.getWhiteBox(); 62 public static Object obj; 63 64 public static void main(String args[]) { 65 obj = new Object(); 66 synchronized (obj) { 67 // HotSpot implementation detail: asking for the hash code 68 // when the object is locked causes monitor inflation. 69 if (obj.hashCode() == 0xBAD) System.out.println("!"); 70 Asserts.assertEQ(wb.isMonitorInflated(obj), true, 71 "Monitor should be inflated."); 72 } 73 for (int cnt = 1; cnt <= N_TRIES; cnt++) { 74 System.out.println("Deflation try #" + cnt); 75 boolean did_deflation = wb.deflateIdleMonitors(); 76 Asserts.assertEQ(did_deflation, true, 77 "deflateIdleMonitors() should have worked."); 78 if (!wb.isMonitorInflated(obj)) { 79 // Deflation worked so no more retries needed. 80 break; 81 } 82 try { 83 System.out.println("Deflation try #" + cnt + " failed. " 84 + "Delaying before retry."); 85 Thread.sleep(N_DELAY); 86 } catch (InterruptedException ie) { 87 } 88 } 89 Asserts.assertEQ(wb.isMonitorInflated(obj), false, 90 "Monitor should be deflated."); 91 } 92 } 93 }