Patrick Concannon 11d43732bc 8217825: Verify @AfterTest is used correctly in WebSocket tests
Remove @AfterTest tags; added in explicit closing of resources e.g. httpServer, webSocket, etc

Reviewed-by: dfuchs, prappo
2019-09-23 16:53:16 +01:00

102 lines
4.0 KiB
Java

/*
* Copyright (c) 2018, 2019, 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
* SendTest
*/
import org.testng.annotations.Test;
import java.io.IOException;
import java.net.http.WebSocket;
import static java.net.http.HttpClient.Builder.NO_PROXY;
import static java.net.http.HttpClient.newBuilder;
import static java.net.http.WebSocket.NORMAL_CLOSURE;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertThrows;
import static org.testng.Assert.assertTrue;
public class SendTest {
private static final Class<NullPointerException> NPE = NullPointerException.class;
@Test
public void sendMethodsThrowNPE() throws IOException {
try (var server = new DummyWebSocketServer()) {
server.open();
var webSocket = newBuilder().proxy(NO_PROXY).build().newWebSocketBuilder()
.buildAsync(server.getURI(), new WebSocket.Listener() { })
.join();
try {
assertThrows(NPE, () -> webSocket.sendText(null, false));
assertThrows(NPE, () -> webSocket.sendText(null, true));
assertThrows(NPE, () -> webSocket.sendBinary(null, false));
assertThrows(NPE, () -> webSocket.sendBinary(null, true));
assertThrows(NPE, () -> webSocket.sendPing(null));
assertThrows(NPE, () -> webSocket.sendPong(null));
assertThrows(NPE, () -> webSocket.sendClose(NORMAL_CLOSURE, null));
webSocket.abort();
assertThrows(NPE, () -> webSocket.sendText(null, false));
assertThrows(NPE, () -> webSocket.sendText(null, true));
assertThrows(NPE, () -> webSocket.sendBinary(null, false));
assertThrows(NPE, () -> webSocket.sendBinary(null, true));
assertThrows(NPE, () -> webSocket.sendPing(null));
assertThrows(NPE, () -> webSocket.sendPong(null));
assertThrows(NPE, () -> webSocket.sendClose(NORMAL_CLOSURE, null));
} finally {
webSocket.abort();
}
}
}
// TODO: request in onClose/onError
// TODO: throw exception in onClose/onError
// TODO: exception is thrown from request()
@Test
public void sendCloseCompleted() throws IOException {
try (var server = new DummyWebSocketServer()) {
server.open();
var webSocket = newBuilder().proxy(NO_PROXY).build().newWebSocketBuilder()
.buildAsync(server.getURI(), new WebSocket.Listener() { })
.join();
try {
webSocket.sendClose(NORMAL_CLOSURE, "").join();
assertTrue(webSocket.isOutputClosed());
assertEquals(webSocket.getSubprotocol(), "");
webSocket.request(1); // No exceptions must be thrown
} finally {
webSocket.abort();
}
}
}
}