Path: blob/master/test/jdk/java/net/Socket/asyncClose/Race.java
41153 views
/*1* Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* @test25* @bug 8006395 801224426* @summary Tests racing code that reads and closes a Socket27*/2829import java.io.InputStream;30import java.net.InetAddress;31import java.net.InetSocketAddress;32import java.net.ServerSocket;33import java.net.Socket;34import java.net.ConnectException;35import java.net.SocketException;36import java.util.concurrent.Phaser;3738// Racey test, will not always fail, but if it does then we have a problem.3940public class Race {41final static int THREADS = 100;4243public static void main(String[] args) throws Exception {44try (ServerSocket ss = new ServerSocket()) {45InetAddress loopback = InetAddress.getLoopbackAddress();46ss.bind(new InetSocketAddress(loopback, 0));47final int port = ss.getLocalPort();48final Phaser phaser = new Phaser(THREADS + 1);49for (int i=0; i<100; i++) {50try {51final Socket s = new Socket(loopback, port);52s.setSoLinger(false, 0);53try (Socket sa = ss.accept()) {54sa.setSoLinger(false, 0);55final InputStream is = s.getInputStream();56Thread[] threads = new Thread[THREADS];57for (int j=0; j<THREADS; j++) {58threads[j] = new Thread() {59public void run() {60try {61phaser.arriveAndAwaitAdvance();62while (is.read() != -1)63Thread.sleep(50);64} catch (Exception x) {65if (!(x instanceof SocketException66&& x.getMessage().equalsIgnoreCase("socket closed")))67x.printStackTrace();68// ok, expect Socket closed69}70}};71}72for (int j=0; j<100; j++)73threads[j].start();74phaser.arriveAndAwaitAdvance();75s.close();76for (int j=0; j<100; j++)77threads[j].join();78}79} catch (ConnectException e) {80System.err.println("Exception " + e + " Port: " + port);81}82}83}84}85}868788