test/hotspot/jtreg/serviceability/sa/TestClhsdbJstackLock.java
author jgeorge
Fri, 01 Dec 2017 18:19:39 +0530
changeset 48181 61a14b5cb1c6
parent 48178 88ec5fca7726
child 50791 b1e90a8a876c
permissions -rw-r--r--
8191538: SA: tests for clhsdb commands: vmstructsdump, field, symboltable and symbol Summary: Create tests for the clhsdb commands: vmstructsdump, field, symboltable and symbol Reviewed-by: sspitsyn, sballal
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48113
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     1
/*
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     2
 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     4
 *
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     7
 * published by the Free Software Foundation.
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     8
 *
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    13
 * accompanied this code).
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    14
 *
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    18
 *
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    21
 * questions.
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    22
 */
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    23
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    24
import java.util.ArrayList;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    25
import java.util.Scanner;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    26
import java.util.List;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    27
import java.io.File;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    28
import java.io.IOException;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    29
import java.util.stream.Collectors;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    30
import java.io.OutputStream;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    31
import jdk.test.lib.apps.LingeredApp;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    32
import jdk.test.lib.JDKToolLauncher;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    33
import jdk.test.lib.Platform;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    34
import jdk.test.lib.process.ProcessTools;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    35
import jdk.test.lib.process.OutputAnalyzer;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    36
import jdk.test.lib.Utils;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    37
import jdk.test.lib.Asserts;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    38
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    39
/*
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    40
 * @test
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    41
 * @library /test/lib
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    42
 * @run main/othervm TestClhsdbJstackLock
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    43
 */
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    44
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    45
public class TestClhsdbJstackLock {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    46
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    47
    private static final String JSTACK_OUT_FILE = "jstack_out.txt";
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    48
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    49
    private static void verifyJStackOutput() throws Exception {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    50
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    51
        Exception unexpected = null;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    52
        File jstackFile = new File(JSTACK_OUT_FILE);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    53
        Asserts.assertTrue(jstackFile.exists() && jstackFile.isFile(),
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    54
                           "File with jstack output not created: " +
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    55
                           jstackFile.getAbsolutePath());
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    56
        try {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    57
            Scanner scanner = new Scanner(jstackFile);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    58
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    59
            boolean classLockOwnerFound = false;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    60
            boolean classLockWaiterFound = false;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    61
            boolean objectLockOwnerFound = false;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    62
            boolean primitiveLockOwnerFound = false;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    63
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    64
            while (scanner.hasNextLine()) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    65
                String line = scanner.nextLine();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    66
                System.out.println(line);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    67
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    68
                if (line.contains("missing reason for ")) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    69
                    unexpected = new RuntimeException("Unexpected msg: missing reason for ");
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    70
                    break;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    71
                }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    72
                if (line.matches("^\\s+- locked <0x[0-9a-f]+> \\(a java\\.lang\\.Class for LingeredAppWithLock\\)$")) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    73
                    classLockOwnerFound = true;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    74
                }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    75
                if (line.matches("^\\s+- waiting to lock <0x[0-9a-f]+> \\(a java\\.lang\\.Class for LingeredAppWithLock\\)$")) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    76
                    classLockWaiterFound = true;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    77
                }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    78
                if (line.matches("^\\s+- locked <0x[0-9a-f]+> \\(a java\\.lang\\.Thread\\)$")) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    79
                    objectLockOwnerFound = true;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    80
                }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    81
                if (line.matches("^\\s+- locked <0x[0-9a-f]+> \\(a java\\.lang\\.Class for int\\)$")) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    82
                    primitiveLockOwnerFound = true;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    83
                }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    84
            }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    85
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    86
            if (!classLockOwnerFound || !classLockWaiterFound ||
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    87
                !objectLockOwnerFound || !primitiveLockOwnerFound) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    88
                unexpected = new RuntimeException(
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    89
                      "classLockOwnerFound = " + classLockOwnerFound +
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    90
                      ", classLockWaiterFound = " + classLockWaiterFound +
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    91
                      ", objectLockOwnerFound = " + objectLockOwnerFound +
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    92
                      ", primitiveLockOwnerFound = " + primitiveLockOwnerFound);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    93
            }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    94
            if (unexpected != null) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    95
                throw unexpected;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    96
            }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    97
        } catch (Exception ex) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    98
            throw new RuntimeException("Test ERROR " + ex, ex);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
    99
        } finally {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   100
            jstackFile.delete();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   101
        }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   102
    }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   103
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   104
    private static void startClhsdbForLock(long lingeredAppPid) throws Exception {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   105
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   106
        Process p;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   107
        JDKToolLauncher launcher = JDKToolLauncher.createUsingTestJDK("jhsdb");
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   108
        launcher.addToolArg("clhsdb");
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   109
        launcher.addToolArg("--pid");
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   110
        launcher.addToolArg(Long.toString(lingeredAppPid));
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   111
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   112
        ProcessBuilder pb = new ProcessBuilder();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   113
        pb.command(launcher.getCommand());
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   114
        System.out.println(pb.command().stream().collect(Collectors.joining(" ")));
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   115
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   116
        try {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   117
            p = pb.start();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   118
        } catch (Exception attachE) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   119
            throw new Error("Couldn't start jhsdb or attach to LingeredApp : " + attachE);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   120
        }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   121
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   122
        // Issue the 'jstack' input at the clhsdb prompt.
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   123
        OutputStream input = p.getOutputStream();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   124
        String str = "jstack > " + JSTACK_OUT_FILE + "\nquit\n";
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   125
        try {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   126
            input.write(str.getBytes());
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   127
            input.flush();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   128
        } catch (IOException ioe) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   129
            throw new Error("Problem issuing the jstack command: " + str, ioe);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   130
        }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   131
48178
88ec5fca7726 8191914: New SA test timeout on windows
jgeorge
parents: 48113
diff changeset
   132
        OutputAnalyzer output = new OutputAnalyzer(p);
88ec5fca7726 8191914: New SA test timeout on windows
jgeorge
parents: 48113
diff changeset
   133
48113
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   134
        try {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   135
            p.waitFor();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   136
        } catch (InterruptedException ie) {
48178
88ec5fca7726 8191914: New SA test timeout on windows
jgeorge
parents: 48113
diff changeset
   137
            p.destroyForcibly();
48113
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   138
            throw new Error("Problem awaiting the child process: " + ie, ie);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   139
        }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   140
48178
88ec5fca7726 8191914: New SA test timeout on windows
jgeorge
parents: 48113
diff changeset
   141
        output.shouldHaveExitValue(0);
48113
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   142
    }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   143
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   144
    public static void main (String... args) throws Exception {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   145
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   146
        LingeredApp app = null;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   147
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   148
        if (!Platform.shouldSAAttach()) {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   149
            System.out.println("SA attach not expected to work - test skipped.");
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   150
            return;
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   151
        }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   152
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   153
        try {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   154
            List<String> vmArgs = new ArrayList<String>(Utils.getVmOptions());
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   155
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   156
            app = new LingeredAppWithLock();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   157
            LingeredApp.startApp(vmArgs, app);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   158
            System.out.println ("Started LingeredApp with pid " + app.getPid());
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   159
            startClhsdbForLock(app.getPid());
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   160
            verifyJStackOutput();
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   161
        } finally {
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   162
            LingeredApp.stopApp(app);
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   163
        }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   164
    }
af9e4669ca18 8185796: jstack and clhsdb jstack should show lock objects
ysuenaga
parents:
diff changeset
   165
}