// Copyright (c) 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_QUIC_MOCK_CRYPTO_CLIENT_STREAM_H_ #define NET_QUIC_MOCK_CRYPTO_CLIENT_STREAM_H_ #include #include "base/macros.h" #include "net/quic/crypto/proof_verifier_chromium.h" #include "net/third_party/quic/core/crypto/crypto_handshake.h" #include "net/third_party/quic/core/crypto/crypto_protocol.h" #include "net/third_party/quic/core/http/quic_spdy_client_session_base.h" #include "net/third_party/quic/core/quic_crypto_client_stream.h" #include "net/third_party/quic/core/quic_server_id.h" #include "net/third_party/quic/core/quic_session.h" namespace net { class MockCryptoClientStream : public quic::QuicCryptoClientStream, public quic::QuicCryptoHandshaker { public: // HandshakeMode enumerates the handshake mode MockCryptoClientStream should // mock in CryptoConnect. enum HandshakeMode { // CONFIRM_HANDSHAKE indicates that CryptoConnect will immediately confirm // the handshake and establish encryption. This behavior will never happen // in the field, but is convenient for higher level tests. CONFIRM_HANDSHAKE, // ZERO_RTT indicates that CryptoConnect will establish encryption but will // not confirm the handshake. ZERO_RTT, // COLD_START indicates that CryptoConnect will neither establish encryption // nor confirm the handshake. COLD_START, // COLD_START_WITH_CHLO_SENT indicates that CryptoConnection will attempt to // establish encryption by sending the initial CHLO packet on wire, which // contains an empty CryptoHandshakeMessage. It will not confirm the // hanshake though. COLD_START_WITH_CHLO_SENT, }; MockCryptoClientStream( const quic::QuicServerId& server_id, quic::QuicSpdyClientSessionBase* session, std::unique_ptr verify_context, const quic::QuicConfig& config, quic::QuicCryptoClientConfig* crypto_config, HandshakeMode handshake_mode, const net::ProofVerifyDetailsChromium* proof_verify_details_, bool use_mock_crypter); ~MockCryptoClientStream() override; // CryptoFramerVisitorInterface implementation. void OnHandshakeMessage(const quic::CryptoHandshakeMessage& message) override; // QuicCryptoClientStream implementation. bool CryptoConnect() override; bool encryption_established() const override; bool handshake_confirmed() const override; const quic::QuicCryptoNegotiatedParameters& crypto_negotiated_params() const override; quic::CryptoMessageParser* crypto_message_parser() override; // Invokes the sessions's CryptoHandshakeEvent method with the specified // event. void SendOnCryptoHandshakeEvent( quic::QuicSession::CryptoHandshakeEvent event); static quic::CryptoHandshakeMessage GetDummyCHLOMessage(); protected: using quic::QuicCryptoClientStream::session; private: void SetConfigNegotiated(); HandshakeMode handshake_mode_; bool encryption_established_; bool handshake_confirmed_; quic::QuicReferenceCountedPointer crypto_negotiated_params_; quic::CryptoFramer crypto_framer_; bool use_mock_crypter_; const quic::QuicServerId server_id_; const net::ProofVerifyDetailsChromium* proof_verify_details_; const quic::QuicConfig config_; DISALLOW_COPY_AND_ASSIGN(MockCryptoClientStream); }; } // namespace net #endif // NET_QUIC_MOCK_CRYPTO_CLIENT_STREAM_H_