test/jdk/java/net/Socket/asyncClose/ServerSocket_accept.java
author chegar
Thu, 17 Oct 2019 20:53:35 +0100
branchdatagramsocketimpl-branch
changeset 58678 9cf78a70fa4f
parent 54809 351da897f409
permissions -rw-r--r--
datagramsocketimpl-branch: update to default
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
54809
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
     2
 * Copyright (c) 2001, 2019, 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
/*
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
 * Tests that a thread blocked in ServerSocket.accept
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
 * throws a SocketException if the socket is asynchronously closed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
 */
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    28
import java.io.IOException;
54809
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    29
import java.net.InetAddress;
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    30
import java.net.ServerSocket;
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    31
import java.net.Socket;
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    32
import java.net.SocketException;
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    33
import java.util.concurrent.CountDownLatch;
54809
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    34
import java.util.concurrent.atomic.AtomicBoolean;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
public class ServerSocket_accept extends AsyncCloseTest implements Runnable {
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    37
    private final ServerSocket ss;
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    38
    private final int timeout;
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    39
    private final CountDownLatch latch;
54809
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    40
    private final AtomicBoolean readyToClose = new AtomicBoolean(false);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    42
    public ServerSocket_accept() throws IOException {
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    43
       this(0);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    46
    public ServerSocket_accept(int timeout) throws IOException {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
        this.timeout = timeout;
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    48
        latch = new CountDownLatch(1);
52614
2d612914f10b 8129310: java/net/Socket/asyncClose/AsyncClose.java fails intermittently
xyin
parents: 47216
diff changeset
    49
        ss = new ServerSocket(0, 0, InetAddress.getLoopbackAddress());
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
    public String description() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
        String s = "ServerSocket.accept()";
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
        if (timeout > 0) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
            s += " (with timeout)";
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
        return s;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
    public void run() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
        try {
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    62
            latch.countDown();
54809
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    63
            Socket s;
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    64
            // if readyToClose is still false it means some other
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    65
            // process on the system attempted to connect: just
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    66
            // ignore it, and go back to accept again.
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    67
            do {
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    68
                s = ss.accept();
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    69
            } while (!readyToClose.get());
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    70
            failed("ServerSocket.accept() returned unexpectedly!!" + " - " + s);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
        } catch (SocketException se) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
            closed();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
        } catch (Exception e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
            failed(e.getMessage());
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    78
    public AsyncCloseTest go(){
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    79
        try {
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    80
            Thread thr = new Thread(this);
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    81
            thr.start();
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    82
            latch.await();
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    83
            Thread.sleep(5000); //sleep, so ServerSocket.accept() can block
54809
351da897f409 8223465: Replace wildcard address with loopback or local host in tests - part 3
aefimov
parents: 52614
diff changeset
    84
            readyToClose.set(true);
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    85
            ss.close();
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    86
            thr.join();
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
23604
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    88
            if (isClosed()) {
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    89
                return passed();
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    90
            } else {
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    91
                return failed("ServerSocket.accept() wasn't preempted");
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    92
            }
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    93
        } catch (Exception x) {
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    94
            failed(x.getMessage());
5c29c65ae465 8025209: Intermittent test failure java/net/Socket/asyncClose/AsyncClose.java
chegar
parents: 5506
diff changeset
    95
            throw new RuntimeException(x);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
}