org.bouncycastle.crypto.tls.test.TlsTestSuite Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcprov-jdk14 Show documentation
Show all versions of bcprov-jdk14 Show documentation
The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms. This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.4.
package org.bouncycastle.crypto.tls.test;
import org.bouncycastle.crypto.tls.AlertDescription;
import org.bouncycastle.crypto.tls.ProtocolVersion;
import junit.framework.Test;
import junit.framework.TestSuite;
public class TlsTestSuite extends TestSuite
{
// Make the access to constants less verbose
static abstract class C extends TlsTestConfig {}
public static Test suite()
{
TlsTestSuite testSuite = new TlsTestSuite();
addVersionTests(testSuite, ProtocolVersion.TLSv10);
addVersionTests(testSuite, ProtocolVersion.TLSv11);
addVersionTests(testSuite, ProtocolVersion.TLSv12);
return testSuite;
}
private static void addVersionTests(TestSuite testSuite, ProtocolVersion version)
{
String prefix = version.toString().replaceAll("[ \\.]", "") + "_";
{
TlsTestConfig c = createTlsTestConfig(version);
testSuite.addTest(new TlsTestCase(c, prefix + "GoodDefault"));
}
{
TlsTestConfig c = createTlsTestConfig(version);
c.clientAuth = C.CLIENT_AUTH_INVALID_VERIFY;
c.expectServerFatalAlert(AlertDescription.decrypt_error);
testSuite.addTest(new TlsTestCase(c, prefix + "BadCertificateVerify"));
}
{
TlsTestConfig c = createTlsTestConfig(version);
c.clientAuth = C.CLIENT_AUTH_INVALID_CERT;
c.expectServerFatalAlert(AlertDescription.bad_certificate);
testSuite.addTest(new TlsTestCase(c, prefix + "BadClientCertificate"));
}
{
TlsTestConfig c = createTlsTestConfig(version);
c.clientAuth = C.CLIENT_AUTH_NONE;
c.serverCertReq = C.SERVER_CERT_REQ_MANDATORY;
c.expectServerFatalAlert(AlertDescription.handshake_failure);
testSuite.addTest(new TlsTestCase(c, prefix + "BadMandatoryCertReqDeclined"));
}
{
TlsTestConfig c = createTlsTestConfig(version);
c.serverCertReq = C.SERVER_CERT_REQ_NONE;
testSuite.addTest(new TlsTestCase(c, prefix + "GoodNoCertReq"));
}
{
TlsTestConfig c = createTlsTestConfig(version);
c.clientAuth = C.CLIENT_AUTH_NONE;
testSuite.addTest(new TlsTestCase(c, prefix + "GoodOptionalCertReqDeclined"));
}
}
private static TlsTestConfig createTlsTestConfig(ProtocolVersion version)
{
TlsTestConfig c = new TlsTestConfig();
c.clientMinimumVersion = ProtocolVersion.TLSv10;
c.clientOfferVersion = ProtocolVersion.TLSv12;
c.serverMaximumVersion = version;
c.serverMinimumVersion = ProtocolVersion.TLSv10;
return c;
}
}