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