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[]) throws Exception {
65 obj = new Object();
66 synchronized (obj) {
67 // The current implementation of notify-wait requires inflation.
68 obj.wait(1);
69 Asserts.assertEQ(wb.isMonitorInflated(obj), true,
70 "Monitor should be inflated.");
71 }
72 for (int cnt = 1; cnt <= N_TRIES; cnt++) {
73 System.out.println("Deflation try #" + cnt);
74 boolean did_deflation = wb.deflateIdleMonitors();
75 Asserts.assertEQ(did_deflation, true,
76 "deflateIdleMonitors() should have worked.");
77 if (!wb.isMonitorInflated(obj)) {
78 // Deflation worked so no more retries needed.
79 break;
80 }
81 try {
82 System.out.println("Deflation try #" + cnt + " failed. "
83 + "Delaying before retry.");
84 Thread.sleep(N_DELAY);
85 } catch (InterruptedException ie) {
86 }
87 }
88 Asserts.assertEQ(wb.isMonitorInflated(obj), false,
89 "Monitor should be deflated.");
90 }
91 }
92 }