test/jdk/java/nio/channels/SocketChannel/Connect.java
author mli
Fri, 16 Mar 2018 18:15:31 +0800
changeset 49255 acdb8531cc8b
parent 47216 71c04702a3d5
permissions -rw-r--r--
8199215: Re-examine getFreePort method in test infrastructure library Reviewed-by: alanb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
49255
acdb8531cc8b 8199215: Re-examine getFreePort method in test infrastructure library
mli
parents: 47216
diff changeset
     2
 * Copyright (c) 2002, 2018, Oracle and/or its affiliates. All rights reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    21
 * questions.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
/* @test
36963
1558f7600497 8037360: java/nio/channels/SocketChannel/Connect.java fails intermittently
alanb
parents: 14415
diff changeset
    25
 * @bug 4650679 8037360
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
 * @summary Unit test for socket channels
49255
acdb8531cc8b 8199215: Re-examine getFreePort method in test infrastructure library
mli
parents: 47216
diff changeset
    27
 * @library .. /test/lib
acdb8531cc8b 8199215: Re-examine getFreePort method in test infrastructure library
mli
parents: 47216
diff changeset
    28
 * @build jdk.test.lib.Utils TestServers
acdb8531cc8b 8199215: Re-examine getFreePort method in test infrastructure library
mli
parents: 47216
diff changeset
    29
 * @run main Connect
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
14415
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    32
import java.net.*;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
import java.nio.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
import java.nio.channels.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
import java.util.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
public class Connect {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
    private static final long INCREMENTAL_DELAY = 30L * 1000L;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
    public static void main(String args[]) throws Exception {
14415
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    42
        try (TestServers.EchoServer echoServer
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    43
                = TestServers.EchoServer.startNewServer(1000)) {
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    44
            test1(echoServer);
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    45
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
        try {
36963
1558f7600497 8037360: java/nio/channels/SocketChannel/Connect.java fails intermittently
alanb
parents: 14415
diff changeset
    47
            test1(TestServers.RefusingServer.newRefusingServer());
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
            throw new Exception("Refused connection throws no exception");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
        } catch (ConnectException ce) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
            // Correct result
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
14415
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    54
    static void test1(TestServers.AbstractServer server) throws Exception {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
        Selector selector;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
        SocketChannel sc;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
        SelectionKey sk;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
        InetSocketAddress isa = new InetSocketAddress(
14415
7a31b0e0cfaf 6720349: (ch) Channels tests depending on hosts inside Sun
dfuchs
parents: 5506
diff changeset
    59
            server.getAddress(), server.getPort());
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
        sc = SocketChannel.open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
        sc.configureBlocking(false);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
        selector = Selector.open();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
        sk = sc.register(selector, SelectionKey.OP_CONNECT);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
        if (sc.connect(isa)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
            System.err.println("Connected immediately!");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
            sc.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
            selector.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
            ByteBuffer buf = ByteBuffer.allocateDirect(100);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
            buf.asCharBuffer().put(new String(
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
                "The quick brown fox jumped over the lazy dog."
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
                ).toCharArray());
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
            buf.flip();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
            long startTime = System.currentTimeMillis();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
            while(true) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
                selector.select(INCREMENTAL_DELAY);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
                Set selectedKeys = selector.selectedKeys();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
                if(selectedKeys.isEmpty()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
                    System.err.println("Elapsed time without response: " +
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
                                       (System.currentTimeMillis() -
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
                                        startTime) / 1000L + " seconds.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
                else if(!selectedKeys.contains(sk))
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
                {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
                    System.err.println("Got wrong event about selection key.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
                } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
                    System.err.println("Got event for our selection key.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
                    if(sk.isConnectable()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
                        if(sc.finishConnect()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
                            if(sc.isConnected()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
                                System.err.println("Successful connect.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
                                sk.interestOps(SelectionKey.OP_WRITE);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
                                sc.write(buf);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
                            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
                                System.err.println(
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
                                      "Finish connect completed incorrectly.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
                            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
                        } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
                            System.err.println(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
                     "key incorrectly indicated socket channel connectable.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
                    if(sk.isWritable() && (buf.remaining() > 0)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
                        sc.write(buf);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
                    if(buf.remaining() == 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
                        System.err.println(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
                            "SUCCESS! buffer contents were sent.");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
                        sc.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
                        selector.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
                        return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
                selectedKeys.clear();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
}