test/jdk/java/net/MulticastSocket/UnreferencedMulticastSockets.java
author dfuchs
Tue, 01 Oct 2019 12:10:33 +0100
changeset 58423 54de0c861d32
parent 55047 3131927311ee
permissions -rw-r--r--
8231506: Fix some instabilities in a few networking tests Reviewed-by: alanb, chegar, msheppar
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     1
/*
55047
3131927311ee 8224761: Replace wildcard address with loopback or local host in tests - part 12
dfuchs
parents: 54811
diff changeset
     2
 * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved.
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     4
 *
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     7
 * published by the Free Software Foundation.
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     8
 *
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    13
 * accompanied this code).
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    14
 *
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    18
 *
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    21
 * questions.
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    22
 */
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    23
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    24
/**
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    25
 * @test
54770
62b6e7587b1f 8220673: Add test library support for determining platform IP support
aeubanks
parents: 51830
diff changeset
    26
 * @library /test/lib
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    27
 * @modules java.management java.base/java.io:+open java.base/java.net:+open
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    28
 * @run main/othervm -Djava.net.preferIPv4Stack=true UnreferencedMulticastSockets
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    29
 * @run main/othervm UnreferencedMulticastSockets
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    30
 * @summary Check that unreferenced multicast sockets are closed
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    31
 */
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    32
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    33
import java.io.FileDescriptor;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    34
import java.lang.management.ManagementFactory;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    35
import java.lang.management.OperatingSystemMXBean;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    36
import java.lang.ref.ReferenceQueue;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    37
import java.lang.ref.WeakReference;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    38
import java.lang.reflect.Field;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    39
import java.io.IOException;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    40
import java.net.DatagramPacket;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    41
import java.net.DatagramSocket;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    42
import java.net.DatagramSocketImpl;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    43
import java.net.InetAddress;
55047
3131927311ee 8224761: Replace wildcard address with loopback or local host in tests - part 12
dfuchs
parents: 54811
diff changeset
    44
import java.net.InetSocketAddress;
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    45
import java.net.MulticastSocket;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    46
import java.net.UnknownHostException;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    47
import java.nio.file.Files;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    48
import java.nio.file.Path;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    49
import java.nio.file.Paths;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    50
import java.util.ArrayDeque;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    51
import java.util.List;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    52
import java.util.Optional;
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    53
import java.util.concurrent.Phaser;
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    54
import java.util.concurrent.TimeUnit;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    55
54770
62b6e7587b1f 8220673: Add test library support for determining platform IP support
aeubanks
parents: 51830
diff changeset
    56
import jdk.test.lib.net.IPSupport;
62b6e7587b1f 8220673: Add test library support for determining platform IP support
aeubanks
parents: 51830
diff changeset
    57
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    58
import com.sun.management.UnixOperatingSystemMXBean;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    59
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    60
public class UnreferencedMulticastSockets {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    61
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    62
    /**
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    63
     * The set of sockets we have to check up on.
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    64
     */
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    65
    final static ArrayDeque<NamedWeak> pendingSockets = new ArrayDeque<>(5);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    66
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    67
    /**
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    68
     * Queued objects when they are unreferenced.
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    69
     */
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    70
    final static ReferenceQueue<Object> pendingQueue = new ReferenceQueue<>();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    71
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    72
    // Server to echo a datagram packet
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    73
    static class Server implements Runnable {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    74
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    75
        MulticastSocket ss;
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    76
        final int port;
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    77
        final Phaser phaser = new Phaser(2);
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    78
        Server() throws IOException {
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    79
            InetAddress loopback = InetAddress.getLoopbackAddress();
55047
3131927311ee 8224761: Replace wildcard address with loopback or local host in tests - part 12
dfuchs
parents: 54811
diff changeset
    80
            InetSocketAddress serverAddress =
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    81
                new InetSocketAddress(loopback, 0);
55047
3131927311ee 8224761: Replace wildcard address with loopback or local host in tests - part 12
dfuchs
parents: 54811
diff changeset
    82
            ss = new MulticastSocket(serverAddress);
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    83
            port = ss.getLocalPort();
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    84
            System.out.printf("  DatagramServer addr: %s: %d%n",
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    85
                    this.getHost(), this.getPort());
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    86
            pendingSockets.add(new NamedWeak(ss, pendingQueue, "serverMulticastSocket"));
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    87
            extractRefs(ss, "serverMulticastSocket");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    88
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    89
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    90
        InetAddress getHost() throws UnknownHostException {
55047
3131927311ee 8224761: Replace wildcard address with loopback or local host in tests - part 12
dfuchs
parents: 54811
diff changeset
    91
            InetAddress localhost = InetAddress.getLoopbackAddress();
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    92
            return localhost;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    93
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    94
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    95
        int getPort() {
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
    96
            return port;
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    97
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    98
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
    99
        // Receive a byte and send back a byte
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   100
        public void run() {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   101
            try {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   102
                byte[] buffer = new byte[50];
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   103
                DatagramPacket p = new DatagramPacket(buffer, buffer.length);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   104
                ss.receive(p);
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   105
                System.out.printf("Server: ping received from: %s%n", p.getSocketAddress());
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   106
                phaser.arriveAndAwaitAdvance(); // await the client...
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   107
                buffer[0] += 1;
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   108
                System.out.printf("Server: sending echo to: %s%n", p.getSocketAddress());
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   109
                ss.send(p);         // send back +1
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   110
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   111
                System.out.printf("Server: awaiting client%n");
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   112
                phaser.arriveAndAwaitAdvance(); // await the client...
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   113
                // do NOT close but 'forget' the socket reference
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   114
                System.out.printf("Server: forgetting socket...%n");
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   115
                ss = null;
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   116
            } catch (Throwable ioe) {
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   117
                ioe.printStackTrace();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   118
            }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   119
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   120
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   121
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   122
    public static void main(String args[]) throws Exception {
54811
9db7c0f561a6 8223652: Rename IPSupport.skipIfCurrentConfigurationIsInvalid() to IPSupport.throwSkippedExceptionIfNonOperational()
aeubanks
parents: 54770
diff changeset
   123
        IPSupport.throwSkippedExceptionIfNonOperational();
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   124
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   125
        InetSocketAddress clientAddress =
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   126
                new InetSocketAddress(InetAddress.getLoopbackAddress(), 0);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   127
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   128
        // Create and close a MulticastSocket to warm up the FD count for side effects.
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   129
        try (MulticastSocket s = new MulticastSocket(clientAddress)) {
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   130
            // no-op; close immediately
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   131
            s.getLocalPort();   // no-op
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   132
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   133
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   134
        long fdCount0 = getFdCount();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   135
        listProcFD();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   136
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   137
        // start a server
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   138
        Server svr = new Server();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   139
        Thread thr = new Thread(svr);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   140
        thr.start();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   141
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   142
        // It is possible under some circumstances that the client
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   143
        // might get bound to the same port than the server: this
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   144
        // would make the test fail - so if this happen we try to
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   145
        // bind to a specific port by incrementing the server port.
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   146
        MulticastSocket client = null;
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   147
        int serverPort = svr.getPort();
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   148
        int maxtries = 20;
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   149
        for (int i = 0; i < maxtries; i++) {
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   150
            try {
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   151
                System.out.printf("Trying to bind client to: %s%n", clientAddress);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   152
                client = new MulticastSocket(clientAddress);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   153
                if (client.getLocalPort() != svr.getPort()) break;
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   154
                client.close();
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   155
            } catch (IOException x) {
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   156
                System.out.printf("Couldn't create client after %d attempts: %s%n", i, x);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   157
                if (i == maxtries) throw x;
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   158
            }
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   159
            if (i == maxtries) {
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   160
                String msg = String.format("Couldn't create client after %d attempts", i);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   161
                System.out.println(msg);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   162
                throw new AssertionError(msg);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   163
            }
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   164
            clientAddress = new InetSocketAddress(clientAddress.getAddress(), serverPort + i);
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   165
        }
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   166
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   167
        System.out.printf("  client bound port: %s:%d%n",
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   168
                client.getLocalAddress(), client.getLocalPort());
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   169
        client.connect(svr.getHost(), svr.getPort());
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   170
        pendingSockets.add(new NamedWeak(client, pendingQueue, "clientMulticastSocket"));
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   171
        extractRefs(client, "clientMulticastSocket");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   172
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   173
        byte[] msg = new byte[1];
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   174
        msg[0] = 1;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   175
        DatagramPacket p = new DatagramPacket(msg, msg.length, svr.getHost(), svr.getPort());
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   176
        client.send(p);
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   177
        System.out.printf("  ping sent to: %s:%d%n", svr.getHost(), svr.getPort());
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   178
        svr.phaser.arriveAndAwaitAdvance(); // wait until the server has received its packet
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   179
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   180
        p = new DatagramPacket(msg, msg.length);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   181
        client.receive(p);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   182
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   183
        System.out.printf("  echo received from: %s%n", p.getSocketAddress());
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   184
        if (msg[0] != 2) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   185
            throw new AssertionError("incorrect data received: expected: 2, actual: " + msg[0]);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   186
        }
58423
54de0c861d32 8231506: Fix some instabilities in a few networking tests
dfuchs
parents: 55047
diff changeset
   187
        svr.phaser.arriveAndAwaitAdvance(); // let the server null out its socket
48737
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   188
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   189
        // Do NOT close the MulticastSocket; forget it
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   190
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   191
        Object ref;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   192
        int loops = 20;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   193
        while (!pendingSockets.isEmpty() && loops-- > 0) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   194
            ref = pendingQueue.remove(1000L);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   195
            if (ref != null) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   196
                pendingSockets.remove(ref);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   197
                System.out.printf("  ref freed: %s, remaining: %d%n", ref, pendingSockets.size());
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   198
            } else {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   199
                client = null;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   200
                p = null;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   201
                msg = null;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   202
                System.gc();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   203
            }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   204
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   205
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   206
        thr.join();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   207
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   208
        // List the open file descriptors
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   209
        long fdCount = getFdCount();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   210
        System.out.printf("Initial fdCount: %d, final fdCount: %d%n", fdCount0, fdCount);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   211
        listProcFD();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   212
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   213
        if (loops == 0) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   214
            throw new AssertionError("Not all references reclaimed");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   215
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   216
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   217
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   218
    // Get the count of open file descriptors, or -1 if not available
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   219
    private static long getFdCount() {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   220
        OperatingSystemMXBean mxBean = ManagementFactory.getOperatingSystemMXBean();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   221
        return (mxBean instanceof UnixOperatingSystemMXBean)
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   222
                ? ((UnixOperatingSystemMXBean) mxBean).getOpenFileDescriptorCount()
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   223
                : -1L;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   224
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   225
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   226
    // Reflect to find references in the socket implementation that will be gc'd
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   227
    private static void extractRefs(MulticastSocket s, String name) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   228
        try {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   229
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   230
            Field socketImplField = DatagramSocket.class.getDeclaredField("impl");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   231
            socketImplField.setAccessible(true);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   232
            Object socketImpl = socketImplField.get(s);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   233
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   234
            Field fileDescriptorField = DatagramSocketImpl.class.getDeclaredField("fd");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   235
            fileDescriptorField.setAccessible(true);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   236
            FileDescriptor fileDescriptor = (FileDescriptor) fileDescriptorField.get(socketImpl);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   237
            extractRefs(fileDescriptor, name);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   238
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   239
            Class<?> socketImplClass = socketImpl.getClass();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   240
            System.out.printf("socketImplClass: %s%n", socketImplClass);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   241
            if (socketImplClass.getName().equals("java.net.TwoStacksPlainDatagramSocketImpl")) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   242
                Field fileDescriptor1Field = socketImplClass.getDeclaredField("fd1");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   243
                fileDescriptor1Field.setAccessible(true);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   244
                FileDescriptor fileDescriptor1 = (FileDescriptor) fileDescriptor1Field.get(socketImpl);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   245
                extractRefs(fileDescriptor1, name + "::twoStacksFd1");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   246
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   247
            } else {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   248
                System.out.printf("socketImpl class name not matched: %s != %s%n",
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   249
                        socketImplClass.getName(), "java.net.TwoStacksPlainDatagramSocketImpl");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   250
            }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   251
        } catch (NoSuchFieldException | IllegalAccessException ex) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   252
            ex.printStackTrace();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   253
            throw new AssertionError("missing field", ex);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   254
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   255
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   256
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   257
    private static void extractRefs(FileDescriptor fileDescriptor, String name) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   258
        Object cleanup = null;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   259
        int rawfd = -1;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   260
        try {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   261
            if (fileDescriptor != null) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   262
                Field fd1Field = FileDescriptor.class.getDeclaredField("fd");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   263
                fd1Field.setAccessible(true);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   264
                rawfd = fd1Field.getInt(fileDescriptor);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   265
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   266
                Field cleanupfdField = FileDescriptor.class.getDeclaredField("cleanup");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   267
                cleanupfdField.setAccessible(true);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   268
                cleanup = cleanupfdField.get(fileDescriptor);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   269
                pendingSockets.add(new NamedWeak(fileDescriptor, pendingQueue,
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   270
                        name + "::fileDescriptor: " + rawfd));
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   271
                pendingSockets.add(new NamedWeak(cleanup, pendingQueue, name + "::fdCleanup: " + rawfd));
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   272
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   273
            }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   274
        } catch (NoSuchFieldException | IllegalAccessException ex) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   275
            ex.printStackTrace();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   276
            throw new AssertionError("missing field", ex);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   277
        } finally {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   278
            System.out.print(String.format("  %s:: fd: %s, fd: %d, cleanup: %s%n",
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   279
                    name, fileDescriptor, rawfd, cleanup));
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   280
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   281
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   282
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   283
    /**
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   284
     * Method to list the open file descriptors (if supported by the 'lsof' command).
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   285
     */
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   286
    static void listProcFD() {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   287
        List<String> lsofDirs = List.of("/usr/bin", "/usr/sbin");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   288
        Optional<Path> lsof = lsofDirs.stream()
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   289
                .map(s -> Paths.get(s, "lsof"))
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   290
                .filter(f -> Files.isExecutable(f))
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   291
                .findFirst();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   292
        lsof.ifPresent(exe -> {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   293
            try {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   294
                System.out.printf("Open File Descriptors:%n");
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   295
                long pid = ProcessHandle.current().pid();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   296
                ProcessBuilder pb = new ProcessBuilder(exe.toString(), "-p", Integer.toString((int) pid));
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   297
                pb.inheritIO();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   298
                Process p = pb.start();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   299
                p.waitFor(10, TimeUnit.SECONDS);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   300
            } catch (IOException | InterruptedException ie) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   301
                ie.printStackTrace();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   302
            }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   303
        });
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   304
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   305
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   306
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   307
    // Simple class to identify which refs have been queued
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   308
    static class NamedWeak extends WeakReference<Object> {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   309
        private final String name;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   310
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   311
        NamedWeak(Object o, ReferenceQueue<Object> queue, String name) {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   312
            super(o, queue);
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   313
            this.name = name;
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   314
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   315
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   316
        public String toString() {
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   317
            return name + "; " + super.toString();
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   318
        }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   319
    }
7c12219870fd 8195059: Update java.net Socket and DatagramSocket implementations to use Cleaner
rriggs
parents:
diff changeset
   320
}