jdk-24/test/jdk/sun/security/ssl/SSLEngineImpl/CloseEngineException.java

178 lines
5.5 KiB
Java
Raw Normal View History

2007-12-01 00:00:00 +00:00
/*
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
2007-12-01 00:00:00 +00:00
* 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.
2007-12-01 00:00:00 +00:00
*/
//
// SunJSSE does not support dynamic system properties, no way to re-use
// system properties in samevm/agentvm mode.
//
2007-12-01 00:00:00 +00:00
/*
* @test
* @bug 4969799
* @summary javax.net.ssl.SSLSocket.SSLSocket(InetAddress,int) shouldn't
* throw exception
* @library /javax/net/ssl/templates
* @run main/othervm CloseEngineException
2007-12-01 00:00:00 +00:00
*/
//
// This is making sure that starting a new handshake throws the right
// exception. There is a similar test for SSLSocket.
//
2007-12-01 00:00:00 +00:00
import javax.net.ssl.*;
// Note that this test case depends on JSSE provider implementation details.
public class CloseEngineException extends SSLEngineTemplate {
2007-12-01 00:00:00 +00:00
private static boolean debug = true;
2007-12-01 00:00:00 +00:00
private void runTest() throws Exception {
boolean dataDone = false;
SSLEngineResult result1; // clientEngine's results from last operation
2007-12-01 00:00:00 +00:00
SSLEngineResult result2; // ssle2's results from last operation
while (!isEngineClosed(clientEngine) && !isEngineClosed(serverEngine)) {
2007-12-01 00:00:00 +00:00
log("================");
if (!isEngineClosed(clientEngine)) {
result1 = clientEngine.wrap(clientOut, cTOs);
runDelegatedTasks(clientEngine);
2007-12-01 00:00:00 +00:00
log("wrap1: " + result1);
log("oneToTwo = " + cTOs);
log("");
2007-12-01 00:00:00 +00:00
cTOs.flip();
}
if (!isEngineClosed(serverEngine)) {
result2 = serverEngine.wrap(serverOut, sTOc);
runDelegatedTasks(serverEngine);
2007-12-01 00:00:00 +00:00
log("wrap2: " + result2);
log("twoToOne = " + sTOc);
2007-12-01 00:00:00 +00:00
sTOc.flip();
}
2007-12-01 00:00:00 +00:00
log("----");
if (!isEngineClosed(clientEngine) && !dataDone) {
log("--");
result1 = clientEngine.unwrap(sTOc, clientIn);
runDelegatedTasks(clientEngine);
2007-12-01 00:00:00 +00:00
log("unwrap1: " + result1);
log("twoToOne = " + sTOc);
log("");
2007-12-01 00:00:00 +00:00
sTOc.compact();
}
if (!isEngineClosed(serverEngine)) {
log("---");
result2 = serverEngine.unwrap(cTOs, serverIn);
runDelegatedTasks(serverEngine);
2007-12-01 00:00:00 +00:00
log("unwrap2: " + result2);
log("oneToTwo = " + cTOs);
2007-12-01 00:00:00 +00:00
cTOs.compact();
}
2007-12-01 00:00:00 +00:00
/*
* If we've transfered all the data between app1 and app2,
* we try to close and see what that gets us.
*/
if (!dataDone && (clientOut.limit() == serverIn.position()) &&
(serverOut.limit() == clientIn.position())) {
2007-12-01 00:00:00 +00:00
checkTransfer(clientOut, serverIn);
checkTransfer(serverOut, clientIn);
2007-12-01 00:00:00 +00:00
log("Closing clientEngine's *OUTBOUND*...");
clientEngine.closeOutbound();
2007-12-01 00:00:00 +00:00
dataDone = true;
try {
/*
* Check that closed Outbound generates.
*/
clientEngine.beginHandshake();
2007-12-01 00:00:00 +00:00
throw new Exception(
"TEST FAILED: didn't throw Exception");
} catch (SSLException e) {
System.err.println("PARTIAL PASS");
2007-12-01 00:00:00 +00:00
}
}
}
try {
/*
* Check that closed Inbound generates.
*/
serverEngine.beginHandshake();
2007-12-01 00:00:00 +00:00
throw new Exception(
"TEST FAILED: didn't throw Exception");
} catch (SSLException e) {
System.err.println("TEST PASSED");
2007-12-01 00:00:00 +00:00
}
}
public static void main(String args[]) throws Exception {
CloseEngineException test = new CloseEngineException();
2007-12-01 00:00:00 +00:00
test.runTest();
System.err.println("Test Passed.");
2007-12-01 00:00:00 +00:00
}
/*
* **********************************************************
* Majority of the test case is above, below is just setup stuff
* **********************************************************
*/
public CloseEngineException() throws Exception {
super();
2007-12-01 00:00:00 +00:00
}
@Override
protected SSLEngine configureServerEngine(SSLEngine engine) {
engine.setUseClientMode(false);
engine.setNeedClientAuth(true);
return engine;
2007-12-01 00:00:00 +00:00
}
private static boolean isEngineClosed(SSLEngine engine) {
return (engine.isOutboundDone() && engine.isInboundDone());
}
private static void log(String str) {
if (debug) {
System.err.println(str);
2007-12-01 00:00:00 +00:00
}
}
}