Re-enable running openssl (shared) tests on CI (#11197)

Motivation:

It turned out we didnt run the openssl tests on the CI when we used the non-static version of netty-tcnative.

Modifications:

- Upgrade netty-tcnative to fix segfault when using shared openssl
- Adjust tests to only run session cache tests when openssl supports it
- Fix some more tests to only depend on KeyManager if the underlying openssl version supports it

Result:

Run all openssl test on the CI even when shared library is used
This commit is contained in:
Norman Maurer 2021-04-27 13:49:06 +02:00
parent 636244c287
commit c919b385e2
11 changed files with 146 additions and 17 deletions

View File

@ -70,8 +70,10 @@ jobs:
# Compile native code and the modules it depend on and run NativeLoadingTest. This is enough to ensure # Compile native code and the modules it depend on and run NativeLoadingTest. This is enough to ensure
# we can load the native module on aarch64 # we can load the native module on aarch64
#
# Use tcnative.classifier that is empty as we don't support using the shared lib version on ubuntu.
run: | run: |
JAVA_HOME=/usr/lib/jvm/java-11-openjdk-arm64 mvn -pl testsuite-native -am clean package -DskipTests=true -Dcheckstyle.skip=true -DskipNativeTestsuite=false JAVA_HOME=/usr/lib/jvm/java-11-openjdk-arm64 mvn -pl testsuite-native -am clean package -DskipTests=true -Dcheckstyle.skip=true -DskipNativeTestsuite=false -Dtcnative.classifier=
build-pr: build-pr:
runs-on: ubuntu-latest runs-on: ubuntu-latest

View File

@ -358,6 +358,10 @@ public final class OpenSsl {
} }
} }
static boolean isSessionCacheSupported() {
return version() >= 0x10100000L;
}
/** /**
* Returns a self-signed {@link X509Certificate} for {@code netty.io}. * Returns a self-signed {@link X509Certificate} for {@code netty.io}.
*/ */

View File

@ -82,6 +82,10 @@ public class CloseNotifyTest {
public void eventsOrder() throws Exception { public void eventsOrder() throws Exception {
assumeTrue("OpenSSL is not available", provider != SslProvider.OPENSSL || OpenSsl.isAvailable()); assumeTrue("OpenSSL is not available", provider != SslProvider.OPENSSL || OpenSsl.isAvailable());
if (PROTOCOL_TLS_V1_3.equals(protocol)) {
// Ensure we support TLSv1.3
assumeTrue(SslProvider.isTlsv13Supported(provider));
}
BlockingQueue<Object> clientEventQueue = new LinkedBlockingQueue<Object>(); BlockingQueue<Object> clientEventQueue = new LinkedBlockingQueue<Object>();
BlockingQueue<Object> serverEventQueue = new LinkedBlockingQueue<Object>(); BlockingQueue<Object> serverEventQueue = new LinkedBlockingQueue<Object>();

View File

@ -151,11 +151,40 @@ public class ConscryptOpenSslEngineInteropTest extends ConscryptSslEngineTest {
super.testSessionLocalWhenNonMutualWithKeyManager(); super.testSessionLocalWhenNonMutualWithKeyManager();
} }
@Override
public void testSessionLocalWhenNonMutualWithoutKeyManager() throws Exception {
// This only really works when the KeyManagerFactory is supported as otherwise we not really know when
// we need to provide a cert.
assumeTrue(OpenSsl.supportsKeyManagerFactory());
super.testSessionLocalWhenNonMutualWithoutKeyManager();
}
@Override @Override
protected void invalidateSessionsAndAssert(SSLSessionContext context) { protected void invalidateSessionsAndAssert(SSLSessionContext context) {
// Not supported by conscrypt // Not supported by conscrypt
} }
@Override
@Test
public void testSessionCache() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCache();
}
@Override
@Test
public void testSessionCacheTimeout() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheTimeout();
}
@Override
@Test
public void testSessionCacheSize() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheSize();
}
@Override @Override
protected SSLEngine wrapEngine(SSLEngine engine) { protected SSLEngine wrapEngine(SSLEngine engine) {
return Java8SslTestUtils.wrapSSLEngineForTesting(engine); return Java8SslTestUtils.wrapSSLEngineForTesting(engine);

View File

@ -157,6 +157,35 @@ public class JdkOpenSslEngineInteroptTest extends SSLEngineTest {
super.testSessionLocalWhenNonMutualWithKeyManager(); super.testSessionLocalWhenNonMutualWithKeyManager();
} }
@Override
public void testSessionLocalWhenNonMutualWithoutKeyManager() throws Exception {
// This only really works when the KeyManagerFactory is supported as otherwise we not really know when
// we need to provide a cert.
assumeTrue(OpenSsl.supportsKeyManagerFactory());
super.testSessionLocalWhenNonMutualWithoutKeyManager();
}
@Override
@Test
public void testSessionCache() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCache();
}
@Override
@Test
public void testSessionCacheTimeout() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheTimeout();
}
@Override
@Test
public void testSessionCacheSize() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheSize();
}
@Override @Override
protected SSLEngine wrapEngine(SSLEngine engine) { protected SSLEngine wrapEngine(SSLEngine engine) {
return Java8SslTestUtils.wrapSSLEngineForTesting(engine); return Java8SslTestUtils.wrapSSLEngineForTesting(engine);

View File

@ -143,6 +143,27 @@ public class OpenSslConscryptSslEngineInteropTest extends ConscryptSslEngineTest
super.testSessionLocalWhenNonMutualWithKeyManager(); super.testSessionLocalWhenNonMutualWithKeyManager();
} }
@Override
@Test
public void testSessionCache() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCache();
}
@Override
@Test
public void testSessionCacheTimeout() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheTimeout();
}
@Override
@Test
public void testSessionCacheSize() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheSize();
}
@Override @Override
protected void invalidateSessionsAndAssert(SSLSessionContext context) { protected void invalidateSessionsAndAssert(SSLSessionContext context) {
// Not supported by conscrypt // Not supported by conscrypt

View File

@ -1380,6 +1380,14 @@ public class OpenSslEngineTest extends SSLEngineTest {
super.testSessionLocalWhenNonMutualWithKeyManager(); super.testSessionLocalWhenNonMutualWithKeyManager();
} }
@Override
public void testSessionLocalWhenNonMutualWithoutKeyManager() throws Exception {
// This only really works when the KeyManagerFactory is supported as otherwise we not really know when
// we need to provide a cert.
assumeTrue(OpenSsl.supportsKeyManagerFactory());
super.testSessionLocalWhenNonMutualWithoutKeyManager();
}
@Override @Override
protected SslProvider sslClientProvider() { protected SslProvider sslClientProvider() {
return SslProvider.OPENSSL; return SslProvider.OPENSSL;
@ -1421,14 +1429,29 @@ public class OpenSslEngineTest extends SSLEngineTest {
return context; return context;
} }
@Test
@Override @Override
@Test
public void testSessionCache() throws Exception { public void testSessionCache() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCache(); super.testSessionCache();
assertSessionContext(clientSslCtx); assertSessionContext(clientSslCtx);
assertSessionContext(serverSslCtx); assertSessionContext(serverSslCtx);
} }
@Override
@Test
public void testSessionCacheTimeout() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheTimeout();
}
@Override
@Test
public void testSessionCacheSize() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheSize();
}
private static void assertSessionContext(SslContext context) { private static void assertSessionContext(SslContext context) {
if (context == null) { if (context == null) {
return; return;

View File

@ -142,6 +142,35 @@ public class OpenSslJdkSslEngineInteroptTest extends SSLEngineTest {
super.testSessionLocalWhenNonMutualWithKeyManager(); super.testSessionLocalWhenNonMutualWithKeyManager();
} }
@Override
public void testSessionLocalWhenNonMutualWithoutKeyManager() throws Exception {
// This only really works when the KeyManagerFactory is supported as otherwise we not really know when
// we need to provide a cert.
assumeTrue(OpenSsl.supportsKeyManagerFactory());
super.testSessionLocalWhenNonMutualWithoutKeyManager();
}
@Override
@Test
public void testSessionCache() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCache();
}
@Override
@Test
public void testSessionCacheTimeout() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheTimeout();
}
@Override
@Test
public void testSessionCacheSize() throws Exception {
assumeTrue(OpenSsl.isSessionCacheSupported());
super.testSessionCacheSize();
}
@Override @Override
protected SSLEngine wrapEngine(SSLEngine engine) { protected SSLEngine wrapEngine(SSLEngine engine) {
return Java8SslTestUtils.wrapSSLEngineForTesting(engine); return Java8SslTestUtils.wrapSSLEngineForTesting(engine);

View File

@ -536,6 +536,7 @@ public abstract class SSLEngineTest {
@Test(expected = SSLHandshakeException.class) @Test(expected = SSLHandshakeException.class)
public void testIncompatibleCiphers() throws Exception { public void testIncompatibleCiphers() throws Exception {
assumeTrue(SslProvider.isTlsv13Supported(sslClientProvider())); assumeTrue(SslProvider.isTlsv13Supported(sslClientProvider()));
assumeTrue(SslProvider.isTlsv13Supported(sslServerProvider()));
SelfSignedCertificate ssc = new SelfSignedCertificate(); SelfSignedCertificate ssc = new SelfSignedCertificate();
// Select a mandatory cipher from the TLSv1.2 RFC https://www.ietf.org/rfc/rfc5246.txt so handshakes won't fail // Select a mandatory cipher from the TLSv1.2 RFC https://www.ietf.org/rfc/rfc5246.txt so handshakes won't fail

View File

@ -102,6 +102,7 @@ public class SslContextBuilderTest {
@Test @Test
public void testContextFromManagersOpenssl() throws Exception { public void testContextFromManagersOpenssl() throws Exception {
Assume.assumeTrue(OpenSsl.isAvailable()); Assume.assumeTrue(OpenSsl.isAvailable());
Assume.assumeTrue(OpenSsl.supportsKeyManagerFactory());
testContextFromManagers(SslProvider.OPENSSL); testContextFromManagers(SslProvider.OPENSSL);
} }

16
pom.xml
View File

@ -68,20 +68,6 @@
</developers> </developers>
<profiles> <profiles>
<profile>
<id>not_x86_64</id>
<activation>
<os>
<arch>!x86_64</arch>
</os>
</activation>
<properties>
<!-- Use no classifier as we only support x86_64 atm-->
<tcnative.classifier />
<skipShadingTestsuite>true</skipShadingTestsuite>
</properties>
</profile>
<!-- Detect if we use GraalVM and if so enable the native image testsuite --> <!-- Detect if we use GraalVM and if so enable the native image testsuite -->
<profile> <profile>
<id>graal</id> <id>graal</id>
@ -333,7 +319,7 @@
<!-- keep in sync with PlatformDependent#ALLOWED_LINUX_OS_CLASSIFIERS --> <!-- keep in sync with PlatformDependent#ALLOWED_LINUX_OS_CLASSIFIERS -->
<os.detection.classifierWithLikes>fedora,suse,arch</os.detection.classifierWithLikes> <os.detection.classifierWithLikes>fedora,suse,arch</os.detection.classifierWithLikes>
<tcnative.artifactId>netty-tcnative</tcnative.artifactId> <tcnative.artifactId>netty-tcnative</tcnative.artifactId>
<tcnative.version>2.0.38.Final</tcnative.version> <tcnative.version>2.0.39.Final</tcnative.version>
<tcnative.classifier>${os.detected.classifier}</tcnative.classifier> <tcnative.classifier>${os.detected.classifier}</tcnative.classifier>
<conscrypt.groupId>org.conscrypt</conscrypt.groupId> <conscrypt.groupId>org.conscrypt</conscrypt.groupId>
<conscrypt.artifactId>conscrypt-openjdk-uber</conscrypt.artifactId> <conscrypt.artifactId>conscrypt-openjdk-uber</conscrypt.artifactId>