test/jdk/java/net/Socket/Timeouts.java
author alanb
Sun, 24 Feb 2019 07:59:46 +0000
branchniosocketimpl-branch
changeset 57210 a67ea4f53e56
parent 57207 30695f27d7ea
child 57226 4d57d18f0ca5
permissions -rw-r--r--
Test improvements
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     1
/*
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     4
 *
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     7
 * published by the Free Software Foundation.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     8
 *
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    13
 * accompanied this code).
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    14
 *
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    18
 *
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    21
 * questions.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    22
 */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    23
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    24
/**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    25
 * @test
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    26
 * @library /test/lib
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    27
 * @build jdk.test.lib.Utils
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    28
 * @run testng Timeouts
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    29
 * @run testng/othervm -Djdk.net.usePlainSocketImpl Timeouts
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    30
 * @summary Test Socket timeouts
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    31
 */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    32
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    33
import java.io.Closeable;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    34
import java.io.IOException;
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    35
import java.io.InputStream;
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    36
import java.io.OutputStream;
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    37
import java.net.ConnectException;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    38
import java.net.ServerSocket;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    39
import java.net.Socket;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    40
import java.net.SocketAddress;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    41
import java.net.SocketException;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    42
import java.net.SocketTimeoutException;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    43
import java.util.concurrent.Executors;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    44
import java.util.concurrent.ScheduledExecutorService;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    45
import java.util.concurrent.TimeUnit;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    46
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    47
import org.testng.annotations.Test;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    48
import static org.testng.Assert.*;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    49
import jdk.test.lib.Utils;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    50
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    51
@Test
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    52
public class Timeouts {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    53
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    54
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    55
     * Test timed connect where connection is established
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    56
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    57
    public void testTimedConnect1() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    58
        try (ServerSocket ss = new ServerSocket(0)) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    59
            try (Socket s = new Socket()) {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    60
                s.connect(ss.getLocalSocketAddress(), 2000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    61
            }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    62
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    63
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    64
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    65
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    66
     * Test timed connect where connection is refused
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    67
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    68
    public void testTimedConnect2() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    69
        try (Socket s = new Socket()) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    70
            SocketAddress remote = Utils.refusingEndpoint();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    71
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    72
                s.connect(remote, 2000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    73
            } catch (ConnectException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    74
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    75
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    76
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    77
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    78
     * Test timed read where the read succeeds immediately
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    79
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    80
    public void testTimedRead1() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    81
        withConnection((s1, s2) -> {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    82
            s1.getOutputStream().write(99);
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    83
            s2.setSoTimeout(30*1000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    84
            int b = s2.getInputStream().read();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    85
            assertTrue(b == 99);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    86
        });
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    87
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    88
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    89
    /**
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    90
     * Test timed read where the read succeeds after a delay
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    91
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    92
    public void testTimedRead2() throws IOException {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    93
        withConnection((s1, s2) -> {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    94
            scheduleWrite(s1.getOutputStream(), 99, 2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
    95
            s2.setSoTimeout(30*1000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    96
            int b = s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    97
            assertTrue(b == 99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    98
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
    99
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   100
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   101
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   102
     * Test timed read where the read times out
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   103
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   104
    public void testTimedRead3() throws IOException {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   105
        withConnection((s1, s2) -> {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   106
            s2.setSoTimeout(2000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   107
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   108
                s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   109
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   110
            } catch (SocketTimeoutException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   111
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   112
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   113
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   114
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   115
     * Test timed read that succeeds after a previous read has timed out
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   116
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   117
    public void testTimedRead4() throws IOException {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   118
        withConnection((s1, s2) -> {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   119
            s2.setSoTimeout(2000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   120
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   121
                s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   122
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   123
            } catch (SocketTimeoutException e) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   124
            s1.getOutputStream().write(99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   125
            int b = s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   126
            assertTrue(b == 99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   127
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   128
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   129
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   130
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   131
     * Test timed read that succeeds after a previous read has timed out and
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   132
     * after a short delay
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   133
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   134
    public void testTimedRead5() throws IOException {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   135
        withConnection((s1, s2) -> {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   136
            s2.setSoTimeout(2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   137
            try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   138
                s2.getInputStream().read();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   139
                assertTrue(false);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   140
            } catch (SocketTimeoutException e) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   141
            s2.setSoTimeout(30*3000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   142
            scheduleWrite(s1.getOutputStream(), 99, 2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   143
            int b = s2.getInputStream().read();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   144
            assertTrue(b == 99);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   145
        });
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   146
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   147
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   148
    /**
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   149
     * Test untimed read that succeeds after a previous read has timed out
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   150
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   151
    public void testTimedRead6() throws IOException {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   152
        withConnection((s1, s2) -> {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   153
            s2.setSoTimeout(2000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   154
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   155
                s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   156
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   157
            } catch (SocketTimeoutException e) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   158
            s1.getOutputStream().write(99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   159
            s2.setSoTimeout(0);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   160
            int b = s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   161
            assertTrue(b == 99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   162
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   163
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   164
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   165
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   166
     * Test untimed read that succeeds after a previous read has timed out and
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   167
     * after a short delay
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   168
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   169
    public void testTimedRead7() throws IOException {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   170
        withConnection((s1, s2) -> {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   171
            s2.setSoTimeout(2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   172
            try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   173
                s2.getInputStream().read();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   174
                assertTrue(false);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   175
            } catch (SocketTimeoutException e) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   176
            scheduleWrite(s1.getOutputStream(), 99, 2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   177
            s2.setSoTimeout(0);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   178
            int b = s2.getInputStream().read();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   179
            assertTrue(b == 99);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   180
        });
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   181
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   182
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   183
    /**
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   184
     * Test async close of timed read
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   185
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   186
    public void testTimedRead8() throws IOException {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   187
        withConnection((s1, s2) -> {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   188
            s2.setSoTimeout(30*1000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   189
            scheduleClose(s2, 2000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   190
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   191
                s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   192
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   193
            } catch (SocketException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   194
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   195
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   196
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   197
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   198
     * Test writing after a timed read. The timed read changes the underlying
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   199
     * socket to non-blocking.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   200
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   201
    public void testTimedWrite1() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   202
        withConnection((s1, s2) -> {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   203
            s1.getOutputStream().write(99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   204
            s2.setSoTimeout(3000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   205
            int b = s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   206
            assertTrue(b == 99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   208
            // schedule thread to read s1 to EOF
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   209
            scheduleReadToEOF(s1.getInputStream(), 3000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   210
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   211
            // write a lot so that write blocks
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   212
            byte[] data = new byte[128*1024];
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   213
            for (int i = 0; i < 100; i++) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   214
                s2.getOutputStream().write(data);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   215
            }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   216
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   217
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   218
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   219
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   220
     * Test async close of writer (after a timed read). The timed read changes
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   221
     * the underlying socket to non-blocking.
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   222
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   223
    public void testTimedWrite2() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   224
        withConnection((s1, s2) -> {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   225
            s1.getOutputStream().write(99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   226
            s2.setSoTimeout(3000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   227
            int b = s2.getInputStream().read();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   228
            assertTrue(b == 99);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   229
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   230
            // schedule s2 to be be closed
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   231
            scheduleClose(s2, 3000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   232
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   233
            // write a lot so that write blocks
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   234
            byte[] data = new byte[128*1024];
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   235
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   236
                while (true) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   237
                    s2.getOutputStream().write(data);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   238
                }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   239
            } catch (SocketException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   240
        });
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   241
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   242
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   243
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   244
     * Test timed accept where a connection is established immediately
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   245
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   246
    public void testTimedAccept1() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   247
        Socket s1 = null;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   248
        Socket s2 = null;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   249
        try (ServerSocket ss = new ServerSocket(0)) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   250
            s1 = new Socket();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   251
            s1.connect(ss.getLocalSocketAddress());
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   252
            ss.setSoTimeout(30*1000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   253
            s2 = ss.accept();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   254
        } finally {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   255
            if (s1 != null) s1.close();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   256
            if (s2 != null) s2.close();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   257
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   258
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   259
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   260
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   261
     * Test timed accept where a connection is established after a short delay
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   262
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   263
    public void testTimedAccept2() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   264
        try (ServerSocket ss = new ServerSocket(0)) {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   265
            ss.setSoTimeout(30*1000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   266
            scheduleConnect(ss.getLocalSocketAddress(), 2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   267
            Socket s = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   268
            s.close();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   269
        }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   270
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   271
    
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   272
    /**
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   273
     * Test timed accept where the accept times out
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   274
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   275
    public void testTimedAccept3() throws IOException {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   276
        try (ServerSocket ss = new ServerSocket(0)) {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   277
            ss.setSoTimeout(2000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   278
            try {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   279
                Socket s = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   280
                s.close();
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   281
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   282
            } catch (SocketTimeoutException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   283
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   284
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   285
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   286
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   287
     * Test timed accept where a connection is established immediately after a
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   288
     * previous accept timed out.
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   289
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   290
    public void testTimedAccept4() throws IOException {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   291
        try (ServerSocket ss = new ServerSocket(0)) {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   292
            ss.setSoTimeout(2000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   293
            try {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   294
                Socket s = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   295
                s.close();
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   296
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   297
            } catch (SocketTimeoutException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   298
            try (Socket s1 = new Socket()) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   299
                s1.connect(ss.getLocalSocketAddress());
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   300
                Socket s2 = ss.accept();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   301
                s2.close();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   302
            }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   303
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   304
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   305
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   306
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   307
     * Test untimed accept where a connection is established after a previous
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   308
     * accept timed out
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   309
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   310
    public void testTimedAccept5() throws IOException {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   311
        try (ServerSocket ss = new ServerSocket(0)) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   312
            ss.setSoTimeout(2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   313
            try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   314
                Socket s = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   315
                s.close();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   316
                assertTrue(false);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   317
            } catch (SocketTimeoutException expected) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   318
            ss.setSoTimeout(0);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   319
            try (Socket s1 = new Socket()) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   320
                s1.connect(ss.getLocalSocketAddress());
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   321
                Socket s2 = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   322
                s2.close();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   323
            }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   324
        }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   325
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   326
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   327
    /**
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   328
     * Test untimed accept where a connection is established after a previous
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   329
     * accept timed out and after a short delay
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   330
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   331
    public void testTimedAccept6() throws IOException {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   332
        try (ServerSocket ss = new ServerSocket(0)) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   333
            ss.setSoTimeout(2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   334
            try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   335
                Socket s = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   336
                s.close();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   337
                assertTrue(false);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   338
            } catch (SocketTimeoutException expected) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   339
            ss.setSoTimeout(0);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   340
            scheduleConnect(ss.getLocalSocketAddress(), 2000);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   341
            Socket s = ss.accept();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   342
            s.close();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   343
        }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   344
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   345
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   346
    /**
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   347
     * Test async close of a timed accept
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   348
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   349
    public void testTimedAccept7() throws IOException {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   350
        try (ServerSocket ss = new ServerSocket(0)) {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   351
            ss.setSoTimeout(30*1000);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   352
            scheduleClose(ss, 2000);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   353
            try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   354
                ss.accept().close();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   355
                assertTrue(false);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   356
            } catch (SocketException expected) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   357
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   358
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   359
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   360
    @Test(expectedExceptions = { IllegalArgumentException.class })
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   361
    public void testBadTimeout1() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   362
        try (Socket s = new Socket()) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   363
            s.setSoTimeout(-1);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   364
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   365
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   366
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   367
    @Test(expectedExceptions = { IllegalArgumentException.class })
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   368
    public void testBadTimeout2() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   369
        try (ServerSocket ss = new ServerSocket(0)) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   370
            try (Socket s = new Socket()) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   371
                s.connect(ss.getLocalSocketAddress(), -1);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   372
            }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   373
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   374
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   375
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   376
    @Test(expectedExceptions = { IllegalArgumentException.class })
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   377
    public void testBadTimeout3() throws IOException {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   378
        try (ServerSocket ss = new ServerSocket()) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   379
            ss.setSoTimeout(-1);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   380
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   381
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   382
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   383
    interface ThrowingBiConsumer<T, U> {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   384
        void accept(T t, U u) throws IOException;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   385
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   386
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   387
    /**
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   388
     * Invokes the consumer with a connected pair of sockets
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   389
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   390
    static void withConnection(ThrowingBiConsumer<Socket, Socket> consumer)
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   391
        throws IOException
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   392
    {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   393
        Socket s1 = null;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   394
        Socket s2 = null;
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   395
        try (ServerSocket ss = new ServerSocket(0)) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   396
            s1 = new Socket();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   397
            s1.connect(ss.getLocalSocketAddress());
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   398
            s2 = ss.accept();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   399
            consumer.accept(s1, s2);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   400
        } finally {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   401
            if (s1 != null) s1.close();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   402
            if (s2 != null) s2.close();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   403
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   404
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   405
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   406
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   407
     * Schedule c to be closed after a delay
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   408
     */
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   409
    static void scheduleClose(Closeable c, long delay) {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   410
        ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   411
        try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   412
            Runnable task = () -> { try { c.close(); } catch (IOException ioe) { } };
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   413
            executor.schedule(task, delay, TimeUnit.MILLISECONDS);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   414
        } finally {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   415
            executor.shutdown();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   416
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   417
    }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   418
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   419
    /**
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   420
     * Schedule a thread to connect to the given end point after a delay
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   421
     */
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   422
    static void scheduleConnect(SocketAddress remote, long delay) {
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   423
        ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   424
        try {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   425
            Runnable task = () -> {
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   426
                try (Socket s = new Socket()) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   427
                    s.connect(remote);
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   428
                } catch (IOException ioe) { }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   429
            };
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   430
            executor.schedule(task, delay, TimeUnit.MILLISECONDS);
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   431
        } finally {
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   432
            executor.shutdown();
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   433
        }
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   434
    }
57210
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   435
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   436
    /**
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   437
     * Schedule a thread to read to EOF after a delay
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   438
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   439
    static void scheduleReadToEOF(InputStream in, long delay) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   440
        ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   441
        try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   442
            Runnable task = () -> {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   443
                byte[] bytes = new byte[8192];
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   444
                try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   445
                    while (in.read(bytes) != -1) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   446
                } catch (IOException ioe) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   447
            };
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   448
            executor.schedule(task, delay, TimeUnit.MILLISECONDS);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   449
        } finally {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   450
            executor.shutdown();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   451
        }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   452
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   453
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   454
    /**
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   455
     * Schedule a thread to write after a delay
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   456
     */
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   457
    static void scheduleWrite(OutputStream out, byte[] data, long delay) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   458
        ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   459
        try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   460
            Runnable task = () -> {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   461
                try {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   462
                    out.write(data);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   463
                } catch (IOException ioe) { }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   464
            };
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   465
            executor.schedule(task, delay, TimeUnit.MILLISECONDS);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   466
        } finally {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   467
            executor.shutdown();
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   468
        }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   469
    }
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   470
    static void scheduleWrite(OutputStream out, int b, long delay) {
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   471
        scheduleWrite(out, new byte[] { (byte)b }, delay);
a67ea4f53e56 Test improvements
alanb
parents: 57207
diff changeset
   472
    }
57207
30695f27d7ea More cleanup and tests
alanb
parents:
diff changeset
   473
}