2018-04-05 15:39:06 -07:00
|
|
|
/*
|
|
|
|
|
* Copyright 2018 The WebRTC Project Authors. All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
*/
|
|
|
|
|
|
2019-01-11 09:11:00 -08:00
|
|
|
#include "rtc_base/openssl_session_cache.h"
|
2019-07-05 19:08:33 +02:00
|
|
|
|
2018-04-05 15:39:06 -07:00
|
|
|
#include <openssl/ssl.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
|
|
#include "rtc_base/gunit.h"
|
|
|
|
|
#include "rtc_base/openssl.h"
|
|
|
|
|
|
2020-12-10 16:23:03 -08:00
|
|
|
namespace {
|
|
|
|
|
// Use methods that avoid X509 objects if possible.
|
|
|
|
|
SSL_CTX* NewDtlsContext() {
|
|
|
|
|
#ifdef OPENSSL_IS_BORINGSSL
|
|
|
|
|
return SSL_CTX_new(DTLS_with_buffers_method());
|
|
|
|
|
#else
|
|
|
|
|
return SSL_CTX_new(DTLS_method());
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
SSL_CTX* NewTlsContext() {
|
|
|
|
|
#ifdef OPENSSL_IS_BORINGSSL
|
|
|
|
|
return SSL_CTX_new(TLS_with_buffers_method());
|
|
|
|
|
#else
|
|
|
|
|
return SSL_CTX_new(TLS_method());
|
|
|
|
|
#endif
|
|
|
|
|
}
|
2024-08-01 13:20:06 +00:00
|
|
|
|
|
|
|
|
SSL_SESSION* NewSslSession(SSL_CTX* ssl_ctx) {
|
|
|
|
|
#ifdef OPENSSL_IS_BORINGSSL
|
|
|
|
|
return SSL_SESSION_new(ssl_ctx);
|
|
|
|
|
#else
|
|
|
|
|
return SSL_SESSION_new();
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-10 16:23:03 -08:00
|
|
|
} // namespace
|
|
|
|
|
|
2018-04-05 15:39:06 -07:00
|
|
|
namespace rtc {
|
|
|
|
|
|
|
|
|
|
TEST(OpenSSLSessionCache, DTLSModeSetCorrectly) {
|
2020-12-10 16:23:03 -08:00
|
|
|
SSL_CTX* ssl_ctx = NewDtlsContext();
|
2018-04-05 15:39:06 -07:00
|
|
|
|
|
|
|
|
OpenSSLSessionCache session_cache(SSL_MODE_DTLS, ssl_ctx);
|
|
|
|
|
EXPECT_EQ(session_cache.GetSSLMode(), SSL_MODE_DTLS);
|
|
|
|
|
|
|
|
|
|
SSL_CTX_free(ssl_ctx);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(OpenSSLSessionCache, TLSModeSetCorrectly) {
|
2020-12-10 16:23:03 -08:00
|
|
|
SSL_CTX* ssl_ctx = NewTlsContext();
|
2018-04-05 15:39:06 -07:00
|
|
|
|
|
|
|
|
OpenSSLSessionCache session_cache(SSL_MODE_TLS, ssl_ctx);
|
|
|
|
|
EXPECT_EQ(session_cache.GetSSLMode(), SSL_MODE_TLS);
|
|
|
|
|
|
|
|
|
|
SSL_CTX_free(ssl_ctx);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(OpenSSLSessionCache, SSLContextSetCorrectly) {
|
2020-12-10 16:23:03 -08:00
|
|
|
SSL_CTX* ssl_ctx = NewDtlsContext();
|
2018-04-05 15:39:06 -07:00
|
|
|
|
|
|
|
|
OpenSSLSessionCache session_cache(SSL_MODE_DTLS, ssl_ctx);
|
|
|
|
|
EXPECT_EQ(session_cache.GetSSLContext(), ssl_ctx);
|
|
|
|
|
|
|
|
|
|
SSL_CTX_free(ssl_ctx);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(OpenSSLSessionCache, InvalidLookupReturnsNullptr) {
|
2020-12-10 16:23:03 -08:00
|
|
|
SSL_CTX* ssl_ctx = NewDtlsContext();
|
2018-04-05 15:39:06 -07:00
|
|
|
|
|
|
|
|
OpenSSLSessionCache session_cache(SSL_MODE_DTLS, ssl_ctx);
|
|
|
|
|
EXPECT_EQ(session_cache.LookupSession("Invalid"), nullptr);
|
|
|
|
|
EXPECT_EQ(session_cache.LookupSession(""), nullptr);
|
|
|
|
|
EXPECT_EQ(session_cache.LookupSession("."), nullptr);
|
|
|
|
|
|
|
|
|
|
SSL_CTX_free(ssl_ctx);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(OpenSSLSessionCache, SimpleValidSessionLookup) {
|
2020-12-10 16:23:03 -08:00
|
|
|
SSL_CTX* ssl_ctx = NewDtlsContext();
|
2024-08-01 13:20:06 +00:00
|
|
|
SSL_SESSION* ssl_session = NewSslSession(ssl_ctx);
|
2018-04-05 15:39:06 -07:00
|
|
|
|
|
|
|
|
OpenSSLSessionCache session_cache(SSL_MODE_DTLS, ssl_ctx);
|
|
|
|
|
session_cache.AddSession("webrtc.org", ssl_session);
|
|
|
|
|
EXPECT_EQ(session_cache.LookupSession("webrtc.org"), ssl_session);
|
|
|
|
|
|
|
|
|
|
SSL_CTX_free(ssl_ctx);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(OpenSSLSessionCache, AddToExistingReplacesPrevious) {
|
2020-12-10 16:23:03 -08:00
|
|
|
SSL_CTX* ssl_ctx = NewDtlsContext();
|
2024-08-01 13:20:06 +00:00
|
|
|
SSL_SESSION* ssl_session_1 = NewSslSession(ssl_ctx);
|
|
|
|
|
SSL_SESSION* ssl_session_2 = NewSslSession(ssl_ctx);
|
2018-04-05 15:39:06 -07:00
|
|
|
|
|
|
|
|
OpenSSLSessionCache session_cache(SSL_MODE_DTLS, ssl_ctx);
|
|
|
|
|
session_cache.AddSession("webrtc.org", ssl_session_1);
|
|
|
|
|
session_cache.AddSession("webrtc.org", ssl_session_2);
|
|
|
|
|
EXPECT_EQ(session_cache.LookupSession("webrtc.org"), ssl_session_2);
|
|
|
|
|
|
|
|
|
|
SSL_CTX_free(ssl_ctx);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace rtc
|