1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker * Copyright 2017 The WebRTC Project Authors. All rights reserved.
3*d9f75844SAndroid Build Coastguard Worker *
4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker */
10*d9f75844SAndroid Build Coastguard Worker
11*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/openssl_adapter.h"
12*d9f75844SAndroid Build Coastguard Worker
13*d9f75844SAndroid Build Coastguard Worker #include <sstream>
14*d9f75844SAndroid Build Coastguard Worker #include <string>
15*d9f75844SAndroid Build Coastguard Worker #include <vector>
16*d9f75844SAndroid Build Coastguard Worker
17*d9f75844SAndroid Build Coastguard Worker #include "absl/memory/memory.h"
18*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/gunit.h"
19*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/socket.h"
20*d9f75844SAndroid Build Coastguard Worker #include "test/gmock.h"
21*d9f75844SAndroid Build Coastguard Worker
22*d9f75844SAndroid Build Coastguard Worker namespace rtc {
23*d9f75844SAndroid Build Coastguard Worker namespace {
24*d9f75844SAndroid Build Coastguard Worker
25*d9f75844SAndroid Build Coastguard Worker class MockAsyncSocket : public Socket {
26*d9f75844SAndroid Build Coastguard Worker public:
27*d9f75844SAndroid Build Coastguard Worker virtual ~MockAsyncSocket() = default;
28*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(Socket*, Accept, (SocketAddress*), (override));
29*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(SocketAddress, GetLocalAddress, (), (const, override));
30*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(SocketAddress, GetRemoteAddress, (), (const, override));
31*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, Bind, (const SocketAddress&), (override));
32*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, Connect, (const SocketAddress&), (override));
33*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, Send, (const void*, size_t), (override));
34*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int,
35*d9f75844SAndroid Build Coastguard Worker SendTo,
36*d9f75844SAndroid Build Coastguard Worker (const void*, size_t, const SocketAddress&),
37*d9f75844SAndroid Build Coastguard Worker (override));
38*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, Recv, (void*, size_t, int64_t*), (override));
39*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int,
40*d9f75844SAndroid Build Coastguard Worker RecvFrom,
41*d9f75844SAndroid Build Coastguard Worker (void*, size_t, SocketAddress*, int64_t*),
42*d9f75844SAndroid Build Coastguard Worker (override));
43*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, Listen, (int), (override));
44*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, Close, (), (override));
45*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, GetError, (), (const, override));
46*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(void, SetError, (int), (override));
47*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(ConnState, GetState, (), (const, override));
48*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, GetOption, (Option, int*), (override));
49*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(int, SetOption, (Option, int), (override));
50*d9f75844SAndroid Build Coastguard Worker };
51*d9f75844SAndroid Build Coastguard Worker
52*d9f75844SAndroid Build Coastguard Worker class MockCertVerifier : public SSLCertificateVerifier {
53*d9f75844SAndroid Build Coastguard Worker public:
54*d9f75844SAndroid Build Coastguard Worker virtual ~MockCertVerifier() = default;
55*d9f75844SAndroid Build Coastguard Worker MOCK_METHOD(bool, Verify, (const SSLCertificate&), (override));
56*d9f75844SAndroid Build Coastguard Worker };
57*d9f75844SAndroid Build Coastguard Worker
58*d9f75844SAndroid Build Coastguard Worker } // namespace
59*d9f75844SAndroid Build Coastguard Worker
60*d9f75844SAndroid Build Coastguard Worker using ::testing::_;
61*d9f75844SAndroid Build Coastguard Worker using ::testing::Return;
62*d9f75844SAndroid Build Coastguard Worker
TEST(OpenSSLAdapterTest,TestTransformAlpnProtocols)63*d9f75844SAndroid Build Coastguard Worker TEST(OpenSSLAdapterTest, TestTransformAlpnProtocols) {
64*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ("", TransformAlpnProtocols(std::vector<std::string>()));
65*d9f75844SAndroid Build Coastguard Worker
66*d9f75844SAndroid Build Coastguard Worker // Protocols larger than 255 characters (whose size can't be fit in a byte),
67*d9f75844SAndroid Build Coastguard Worker // can't be converted, and an empty string will be returned.
68*d9f75844SAndroid Build Coastguard Worker std::string large_protocol(256, 'a');
69*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ("",
70*d9f75844SAndroid Build Coastguard Worker TransformAlpnProtocols(std::vector<std::string>{large_protocol}));
71*d9f75844SAndroid Build Coastguard Worker
72*d9f75844SAndroid Build Coastguard Worker // One protocol test.
73*d9f75844SAndroid Build Coastguard Worker std::vector<std::string> alpn_protos{"h2"};
74*d9f75844SAndroid Build Coastguard Worker std::stringstream expected_response;
75*d9f75844SAndroid Build Coastguard Worker expected_response << static_cast<char>(2) << "h2";
76*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ(expected_response.str(), TransformAlpnProtocols(alpn_protos));
77*d9f75844SAndroid Build Coastguard Worker
78*d9f75844SAndroid Build Coastguard Worker // Standard protocols test (h2,http/1.1).
79*d9f75844SAndroid Build Coastguard Worker alpn_protos.push_back("http/1.1");
80*d9f75844SAndroid Build Coastguard Worker expected_response << static_cast<char>(8) << "http/1.1";
81*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ(expected_response.str(), TransformAlpnProtocols(alpn_protos));
82*d9f75844SAndroid Build Coastguard Worker }
83*d9f75844SAndroid Build Coastguard Worker
84*d9f75844SAndroid Build Coastguard Worker // Verifies that SSLStart works when OpenSSLAdapter is started in standalone
85*d9f75844SAndroid Build Coastguard Worker // mode.
TEST(OpenSSLAdapterTest,TestBeginSSLBeforeConnection)86*d9f75844SAndroid Build Coastguard Worker TEST(OpenSSLAdapterTest, TestBeginSSLBeforeConnection) {
87*d9f75844SAndroid Build Coastguard Worker rtc::AutoThread main_thread;
88*d9f75844SAndroid Build Coastguard Worker Socket* async_socket = new MockAsyncSocket();
89*d9f75844SAndroid Build Coastguard Worker OpenSSLAdapter adapter(async_socket);
90*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ(adapter.StartSSL("webrtc.org"), 0);
91*d9f75844SAndroid Build Coastguard Worker }
92*d9f75844SAndroid Build Coastguard Worker
93*d9f75844SAndroid Build Coastguard Worker // Verifies that the adapter factory can create new adapters.
TEST(OpenSSLAdapterFactoryTest,CreateSingleOpenSSLAdapter)94*d9f75844SAndroid Build Coastguard Worker TEST(OpenSSLAdapterFactoryTest, CreateSingleOpenSSLAdapter) {
95*d9f75844SAndroid Build Coastguard Worker rtc::AutoThread main_thread;
96*d9f75844SAndroid Build Coastguard Worker OpenSSLAdapterFactory adapter_factory;
97*d9f75844SAndroid Build Coastguard Worker Socket* async_socket = new MockAsyncSocket();
98*d9f75844SAndroid Build Coastguard Worker auto simple_adapter = std::unique_ptr<OpenSSLAdapter>(
99*d9f75844SAndroid Build Coastguard Worker adapter_factory.CreateAdapter(async_socket));
100*d9f75844SAndroid Build Coastguard Worker EXPECT_NE(simple_adapter, nullptr);
101*d9f75844SAndroid Build Coastguard Worker }
102*d9f75844SAndroid Build Coastguard Worker
103*d9f75844SAndroid Build Coastguard Worker // Verifies that setting a custom verifier still allows for adapters to be
104*d9f75844SAndroid Build Coastguard Worker // created.
TEST(OpenSSLAdapterFactoryTest,CreateWorksWithCustomVerifier)105*d9f75844SAndroid Build Coastguard Worker TEST(OpenSSLAdapterFactoryTest, CreateWorksWithCustomVerifier) {
106*d9f75844SAndroid Build Coastguard Worker rtc::AutoThread main_thread;
107*d9f75844SAndroid Build Coastguard Worker MockCertVerifier* mock_verifier = new MockCertVerifier();
108*d9f75844SAndroid Build Coastguard Worker EXPECT_CALL(*mock_verifier, Verify(_)).WillRepeatedly(Return(true));
109*d9f75844SAndroid Build Coastguard Worker auto cert_verifier = std::unique_ptr<SSLCertificateVerifier>(mock_verifier);
110*d9f75844SAndroid Build Coastguard Worker
111*d9f75844SAndroid Build Coastguard Worker OpenSSLAdapterFactory adapter_factory;
112*d9f75844SAndroid Build Coastguard Worker adapter_factory.SetCertVerifier(cert_verifier.get());
113*d9f75844SAndroid Build Coastguard Worker Socket* async_socket = new MockAsyncSocket();
114*d9f75844SAndroid Build Coastguard Worker auto simple_adapter = std::unique_ptr<OpenSSLAdapter>(
115*d9f75844SAndroid Build Coastguard Worker adapter_factory.CreateAdapter(async_socket));
116*d9f75844SAndroid Build Coastguard Worker EXPECT_NE(simple_adapter, nullptr);
117*d9f75844SAndroid Build Coastguard Worker }
118*d9f75844SAndroid Build Coastguard Worker
TEST(StrJoinTest,SingleElement)119*d9f75844SAndroid Build Coastguard Worker TEST(StrJoinTest, SingleElement) {
120*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ(webrtc_openssl_adapter_internal::StrJoin({"a"}, ','), "a");
121*d9f75844SAndroid Build Coastguard Worker }
122*d9f75844SAndroid Build Coastguard Worker
TEST(StrJoinTest,TwoElements)123*d9f75844SAndroid Build Coastguard Worker TEST(StrJoinTest, TwoElements) {
124*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ(webrtc_openssl_adapter_internal::StrJoin({"first", "second"}, ':'),
125*d9f75844SAndroid Build Coastguard Worker "first:second");
126*d9f75844SAndroid Build Coastguard Worker }
127*d9f75844SAndroid Build Coastguard Worker
TEST(StrJoinTest,WithEmptyElement)128*d9f75844SAndroid Build Coastguard Worker TEST(StrJoinTest, WithEmptyElement) {
129*d9f75844SAndroid Build Coastguard Worker EXPECT_EQ(
130*d9f75844SAndroid Build Coastguard Worker webrtc_openssl_adapter_internal::StrJoin({"first", "", "second"}, ':'),
131*d9f75844SAndroid Build Coastguard Worker "first::second");
132*d9f75844SAndroid Build Coastguard Worker }
133*d9f75844SAndroid Build Coastguard Worker
134*d9f75844SAndroid Build Coastguard Worker } // namespace rtc
135