test/jdk/sun/management/jdp/JdpJmxRemoteDynamicPortTestCase.java
author aefimov
Thu, 14 Nov 2019 23:16:40 +0000
branchaefimov-dns-client-branch
changeset 59101 258033faefc9
parent 47216 71c04702a3d5
permissions -rw-r--r--
aefimov-dns-client-branch: Fix timeouts, add platform specific file locations
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43534
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     1
/*
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     2
 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     4
 *
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     7
 * published by the Free Software Foundation.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     8
 *
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    13
 * accompanied this code).
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    14
 *
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    18
 *
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    21
 * questions.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    22
 */
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    23
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    24
import java.net.SocketTimeoutException;
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    25
import java.util.Map;
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    26
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    27
public class JdpJmxRemoteDynamicPortTestCase extends JdpTestCase {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    28
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    29
    private int receivedJDPpackets = 0;
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    30
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    31
    public JdpJmxRemoteDynamicPortTestCase(ClientConnection connection) {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    32
        super(connection);
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    33
    }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    34
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    35
    @Override
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    36
    protected String initialLogMessage() {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    37
        return "Starting test case JdpJmxRemoteDynamicPortTestCase";
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    38
    }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    39
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    40
    /**
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    41
     * This method is executed after a correct Jdp packet (coming from this VM) has been received.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    42
     *
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    43
     * @param payload A dictionary containing the Jdp packet data.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    44
     */
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    45
    protected void packetFromThisVMReceived(Map<String, String> payload) throws Exception {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    46
        receivedJDPpackets++;
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    47
        final String jmxServiceurl = payload.get("JMX_SERVICE_URL");
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    48
        int lastcolon = jmxServiceurl.lastIndexOf(':');
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    49
        int nextslash = jmxServiceurl.indexOf('/', lastcolon);
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    50
        int jmxRemotePort = Integer.parseInt(jmxServiceurl, lastcolon + 1, nextslash, 10);
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    51
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    52
        log.fine("Received #" + String.valueOf(receivedJDPpackets) +
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    53
                  ", jmxStringUrl=" + jmxServiceurl + ", jmxRemotePort=" + jmxRemotePort);
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    54
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    55
        if (0 == jmxRemotePort) {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    56
           throw new Exception("JmxRemotePort value is zero. Test case failed.");
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    57
        }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    58
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    59
        log.fine("Test case passed");
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    60
    }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    61
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    62
    /**
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    63
     * The socket should not timeout.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    64
     * It is set to wait for 10 times the defined pause between Jdp packet. See JdpOnTestCase.TIME_OUT_FACTOR.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    65
     */
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    66
    @Override
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    67
    protected void onSocketTimeOut(SocketTimeoutException e) throws Exception {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    68
        String message = "Timed out waiting for JDP packet. Should arrive within " +
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    69
                connection.pauseInSeconds + " seconds, but waited for " +
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    70
                timeOut + " seconds.";
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    71
        log.severe(message);
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    72
        throw new Exception(message, e);
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    73
    }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    74
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    75
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    76
    /**
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    77
     * After receiving one Jdp packets the test should end.
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    78
     */
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    79
    @Override
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    80
    protected boolean shouldContinue() {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    81
        return receivedJDPpackets < 1;
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    82
    }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    83
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    84
    /**
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    85
     * To run this test manually you might need the following VM options:
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    86
     * <p/>
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    87
     * -Dcom.sun.management.jmxremote.authenticate=false
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    88
     * -Dcom.sun.management.jmxremote.ssl=false
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    89
     * -Dcom.sun.management.jmxremote.port=0
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    90
     * -Dcom.sun.management.jmxremote=true
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    91
     * -Dcom.sun.management.jmxremote.autodiscovery=true
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    92
     * -Dcom.sun.management.jdp.pause=1
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    93
     * -Dcom.sun.management.jdp.name=alex  (or some other string to identify this VM)
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    94
     * <p/>
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    95
     * Recommended for nice output:
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    96
     * -Djava.util.logging.SimpleFormatter.format="%1$tF %1$tT %4$-7s %5$s %n"
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    97
     *
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    98
     * @param args
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
    99
     * @throws Exception
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   100
     */
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   101
    public static void main(String[] args) throws Exception {
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   102
        JdpTestCase client = new JdpJmxRemoteDynamicPortTestCase(new ClientConnection());
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   103
        client.run();
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   104
    }
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   105
170933978095 8167337: When jmxremote.port=0, JDP broadcasts "0" instead of assigned port
rraghavan
parents:
diff changeset
   106
}