# HG changeset patch # User prappo # Date 1521541140 0 # Node ID 195d2970d981686f23d79128ffa6bb81649f86ed # Parent 3edf200fff015520b006e19b0eb8c2ceb30abf5a http-client-branch: (WebSocket) split pending operations tests, otherwise it took them too long to run diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingBinaryPingClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingBinaryPingClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,82 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingBinaryPingClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingBinaryPingClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingBinaryPingClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + ByteBuffer data = ByteBuffer.allocate(65536); + CompletableFuture cfBinary; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfBinary = webSocket.sendBinary(data, last); + try { + cfBinary.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendText("", true)); + assertFails(ISE, webSocket.sendText("", false)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); + CompletableFuture cfPing = webSocket.sendPing(ByteBuffer.allocate(125)); + assertHangs(cfPing); + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfBinary); + assertFails(IOE, cfPing); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingBinaryPongClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingBinaryPongClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,82 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingBinaryPongClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingBinaryPongClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingBinaryPongClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + ByteBuffer data = ByteBuffer.allocate(65536); + CompletableFuture cfBinary; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfBinary = webSocket.sendBinary(data, last); + try { + cfBinary.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendText("", true)); + assertFails(ISE, webSocket.sendText("", false)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); + CompletableFuture cfPong = webSocket.sendPong(ByteBuffer.allocate(125)); + assertHangs(cfPong); + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfBinary); + assertFails(IOE, cfPong); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingOperations.java --- a/test/jdk/java/net/httpclient/websocket/PendingOperations.java Tue Mar 20 00:30:20 2018 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingOperations.java Tue Mar 20 10:19:00 2018 +0000 @@ -21,36 +21,21 @@ * questions. */ -/* - * @test - * @build DummyWebSocketServer - * @run testng/othervm/timeout=300 - * -Djdk.internal.httpclient.websocket.debug=true - * PendingOperations - */ - import org.testng.annotations.AfterTest; import org.testng.annotations.DataProvider; -import org.testng.annotations.Test; import java.io.IOException; import java.net.http.WebSocket; -import java.nio.ByteBuffer; -import java.nio.CharBuffer; -import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; -import java.util.concurrent.TimeUnit; -import java.util.concurrent.TimeoutException; -import static java.net.http.HttpClient.newHttpClient; - +/* Common infrastructure for tests that check pending operations */ public class PendingOperations { - private static final Class ISE = IllegalStateException.class; - private static final Class IOE = IOException.class; + static final Class ISE = IllegalStateException.class; + static final Class IOE = IOException.class; - private DummyWebSocketServer server; - private WebSocket webSocket; + DummyWebSocketServer server; + WebSocket webSocket; @AfterTest public void cleanup() { @@ -58,320 +43,17 @@ webSocket.abort(); } - @Test(dataProvider = "booleans") - public void pendingTextPingClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - CharBuffer data = CharBuffer.allocate(65536); - CompletableFuture cfText; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfText = webSocket.sendText(data, last); - try { - cfText.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendText("", true)); - assertFails(ISE, webSocket.sendText("", false)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); - CompletableFuture cfPing = webSocket.sendPing(ByteBuffer.allocate(125)); - assertHangs(cfPing); - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfText); - assertFails(IOE, cfPing); - assertFails(IOE, cfClose); - } - /* shortcut */ - public static void assertHangs(CompletionStage stage) { + static void assertHangs(CompletionStage stage) { Support.assertHangs(stage); } /* shortcut */ - private static void assertFails(Class clazz, - CompletionStage stage) { + static void assertFails(Class clazz, + CompletionStage stage) { Support.assertCompletesExceptionally(clazz, stage); } - @Test(dataProvider = "booleans") - public void pendingTextPongClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - CharBuffer data = CharBuffer.allocate(65536); - CompletableFuture cfText; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfText = webSocket.sendText(data, last); - try { - cfText.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendText("", true)); - assertFails(ISE, webSocket.sendText("", false)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); - CompletableFuture cfPong = webSocket.sendPong(ByteBuffer.allocate(125)); - assertHangs(cfPong); - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfText); - assertFails(IOE, cfPong); - assertFails(IOE, cfClose); - } - - @Test(dataProvider = "booleans") - public void pendingBinaryPingClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - ByteBuffer data = ByteBuffer.allocate(65536); - CompletableFuture cfBinary; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfBinary = webSocket.sendBinary(data, last); - try { - cfBinary.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendText("", true)); - assertFails(ISE, webSocket.sendText("", false)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); - CompletableFuture cfPing = webSocket.sendPing(ByteBuffer.allocate(125)); - assertHangs(cfPing); - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfBinary); - assertFails(IOE, cfPing); - assertFails(IOE, cfClose); - } - - @Test(dataProvider = "booleans") - public void pendingBinaryPongClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - ByteBuffer data = ByteBuffer.allocate(65536); - CompletableFuture cfBinary; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfBinary = webSocket.sendBinary(data, last); - try { - cfBinary.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendText("", true)); - assertFails(ISE, webSocket.sendText("", false)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); - assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); - CompletableFuture cfPong = webSocket.sendPong(ByteBuffer.allocate(125)); - assertHangs(cfPong); - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfBinary); - assertFails(IOE, cfPong); - assertFails(IOE, cfClose); - } - - @Test(dataProvider = "booleans") - public void pendingPingTextClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - ByteBuffer data = ByteBuffer.allocate(125); - CompletableFuture cfPing; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfPing = webSocket.sendPing(data); - try { - cfPing.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfText = webSocket.sendText("hello", last); - assertHangs(cfText); - CompletableFuture cfClose - = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfPing); - assertFails(IOE, cfText); - assertFails(IOE, cfClose); - } - - @Test(dataProvider = "booleans") - public void pendingPingBinaryClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - ByteBuffer data = ByteBuffer.allocate(125); - CompletableFuture cfPing; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfPing = webSocket.sendPing(data); - try { - cfPing.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfBinary - = webSocket.sendBinary(ByteBuffer.allocate(4), last); - assertHangs(cfBinary); - CompletableFuture cfClose - = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfPing); - assertFails(IOE, cfBinary); - assertFails(IOE, cfClose); - } - - @Test(dataProvider = "booleans") - public void pendingPongTextClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - ByteBuffer data = ByteBuffer.allocate(125); - CompletableFuture cfPong; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfPong = webSocket.sendPong(data); - try { - cfPong.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfText = webSocket.sendText("hello", last); - assertHangs(cfText); - CompletableFuture cfClose - = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfPong); - assertFails(IOE, cfText); - assertFails(IOE, cfClose); - } - - @Test(dataProvider = "booleans") - public void pendingPongBinaryClose(boolean last) throws Exception { - server = Support.notReadingServer(); - server.open(); - webSocket = newHttpClient().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - - ByteBuffer data = ByteBuffer.allocate(125); - CompletableFuture cfPong; - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfPong = webSocket.sendPong(data); - try { - cfPong.get(5, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); - } - } - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - CompletableFuture cfBinary - = webSocket.sendBinary(ByteBuffer.allocate(4), last); - assertHangs(cfBinary); - CompletableFuture cfClose - = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - webSocket.abort(); - assertFails(IOE, cfPong); - assertFails(IOE, cfBinary); - assertFails(IOE, cfClose); - } - @DataProvider(name = "booleans") public Object[][] booleans() { return new Object[][]{{Boolean.TRUE}, {Boolean.FALSE}}; diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingPingBinaryClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingPingBinaryClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,80 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingPingBinaryClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingPingBinaryClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingPingBinaryClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + ByteBuffer data = ByteBuffer.allocate(125); + CompletableFuture cfPing; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfPing = webSocket.sendPing(data); + try { + cfPing.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfBinary + = webSocket.sendBinary(ByteBuffer.allocate(4), last); + assertHangs(cfBinary); + CompletableFuture cfClose + = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfPing); + assertFails(IOE, cfBinary); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingPingTextClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingPingTextClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,79 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingPingTextClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingPingTextClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingPingTextClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + ByteBuffer data = ByteBuffer.allocate(125); + CompletableFuture cfPing; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfPing = webSocket.sendPing(data); + try { + cfPing.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfText = webSocket.sendText("hello", last); + assertHangs(cfText); + CompletableFuture cfClose + = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfPing); + assertFails(IOE, cfText); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingPongBinaryClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingPongBinaryClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,81 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingPongBinaryClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingPongBinaryClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingPongBinaryClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + + ByteBuffer data = ByteBuffer.allocate(125); + CompletableFuture cfPong; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfPong = webSocket.sendPong(data); + try { + cfPong.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfBinary + = webSocket.sendBinary(ByteBuffer.allocate(4), last); + assertHangs(cfBinary); + CompletableFuture cfClose + = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfPong); + assertFails(IOE, cfBinary); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingPongTextClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingPongTextClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,79 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingPongTextClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingPongTextClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingPongTextClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + ByteBuffer data = ByteBuffer.allocate(125); + CompletableFuture cfPong; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfPong = webSocket.sendPong(data); + try { + cfPong.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfText = webSocket.sendText("hello", last); + assertHangs(cfText); + CompletableFuture cfClose + = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfPong); + assertFails(IOE, cfText); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingTextPingClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingTextPingClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,83 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingTextPingClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.nio.CharBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingTextPingClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingTextPingClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + CharBuffer data = CharBuffer.allocate(65536); + CompletableFuture cfText; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfText = webSocket.sendText(data, last); + try { + cfText.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendText("", true)); + assertFails(ISE, webSocket.sendText("", false)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); + CompletableFuture cfPing = webSocket.sendPing(ByteBuffer.allocate(125)); + assertHangs(cfPing); + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfText); + assertFails(IOE, cfPing); + assertFails(IOE, cfClose); + } +} diff -r 3edf200fff01 -r 195d2970d981 test/jdk/java/net/httpclient/websocket/PendingTextPongClose.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/jdk/java/net/httpclient/websocket/PendingTextPongClose.java Tue Mar 20 10:19:00 2018 +0000 @@ -0,0 +1,83 @@ +/* + * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @build DummyWebSocketServer + * @run testng/othervm + * -Djdk.internal.httpclient.websocket.debug=true + * PendingTextPongClose + */ + +import org.testng.annotations.Test; + +import java.net.http.WebSocket; +import java.nio.ByteBuffer; +import java.nio.CharBuffer; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; + +import static java.net.http.HttpClient.newHttpClient; + +public class PendingTextPongClose extends PendingOperations { + + @Test(dataProvider = "booleans") + public void pendingTextPongClose(boolean last) throws Exception { + server = Support.notReadingServer(); + server.open(); + webSocket = newHttpClient().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { }) + .join(); + CharBuffer data = CharBuffer.allocate(65536); + CompletableFuture cfText; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + System.out.printf("begin cycle #%s at %s%n", i, start); + cfText = webSocket.sendText(data, last); + try { + cfText.get(5, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + break; + } finally { + long stop = System.currentTimeMillis(); + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } + } + assertFails(ISE, webSocket.sendText("", true)); + assertFails(ISE, webSocket.sendText("", false)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), true)); + assertFails(ISE, webSocket.sendBinary(ByteBuffer.allocate(0), false)); + CompletableFuture cfPong = webSocket.sendPong(ByteBuffer.allocate(125)); + assertHangs(cfPong); + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + CompletableFuture cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + webSocket.abort(); + assertFails(IOE, cfText); + assertFails(IOE, cfPong); + assertFails(IOE, cfClose); + } +}