// Copyright (c) 2012 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. // // Common utilities for Quic tests #ifndef NET_QUIC_TEST_TOOLS_QUIC_TEST_UTILS_H_ #define NET_QUIC_TEST_TOOLS_QUIC_TEST_UTILS_H_ #include #include #include #include #include "base/macros.h" #include "base/strings/string_piece.h" #include "net/quic/congestion_control/loss_detection_interface.h" #include "net/quic/congestion_control/send_algorithm_interface.h" #include "net/quic/quic_client_session_base.h" #include "net/quic/quic_connection.h" #include "net/quic/quic_framer.h" #include "net/quic/quic_protocol.h" #include "net/quic/quic_sent_packet_manager.h" #include "net/quic/quic_session.h" #include "net/quic/quic_simple_buffer_allocator.h" #include "net/quic/test_tools/mock_clock.h" #include "net/quic/test_tools/mock_random.h" #include "net/spdy/spdy_framer.h" #include "net/tools/quic/quic_dispatcher.h" #include "net/tools/quic/quic_per_connection_packet_writer.h" #include "net/tools/quic/quic_server_session.h" #include "net/tools/quic/test_tools/mock_quic_server_session_visitor.h" #include "testing/gmock/include/gmock/gmock.h" namespace net { namespace test { static const QuicConnectionId kTestConnectionId = 42; static const uint16_t kTestPort = 123; static const uint32_t kInitialStreamFlowControlWindowForTest = 1024 * 1024; // 1 MB static const uint32_t kInitialSessionFlowControlWindowForTest = 1536 * 1024; // 1.5 MB // Data stream IDs start at 5: the crypto stream is 1, headers stream is 3. static const QuicStreamId kClientDataStreamId1 = 5; static const QuicStreamId kClientDataStreamId2 = 7; static const QuicStreamId kClientDataStreamId3 = 9; // Returns the test peer IP address. IPAddressNumber TestPeerIPAddress(); // Upper limit on versions we support. QuicVersion QuicVersionMax(); // Lower limit on versions we support. QuicVersion QuicVersionMin(); // Returns an address for 127.0.0.1. IPAddressNumber Loopback4(); // Returns an address for ::1. IPAddressNumber Loopback6(); // Returns an address for 0.0.0.0. IPAddressNumber Any4(); void GenerateBody(std::string* body, int length); // Create an encrypted packet for testing. // If versions == nullptr, uses &QuicSupportedVersions(). // Note that the packet is encrypted with NullEncrypter, so to decrypt the // constructed packet, the framer must be set to use NullDecrypter. QuicEncryptedPacket* ConstructEncryptedPacket( QuicConnectionId connection_id, bool version_flag, bool reset_flag, QuicPacketNumber packet_number, const std::string& data, QuicConnectionIdLength connection_id_length, QuicPacketNumberLength packet_number_length, QuicVersionVector* versions); // This form assumes |versions| == nullptr. QuicEncryptedPacket* ConstructEncryptedPacket( QuicConnectionId connection_id, bool version_flag, bool reset_flag, QuicPacketNumber packet_number, const std::string& data, QuicConnectionIdLength connection_id_length, QuicPacketNumberLength packet_number_length); // This form assumes |connection_id_length| == PACKET_8BYTE_CONNECTION_ID, // |packet_number_length| == PACKET_6BYTE_PACKET_NUMBER and // |versions| == nullptr. QuicEncryptedPacket* ConstructEncryptedPacket(QuicConnectionId connection_id, bool version_flag, bool reset_flag, QuicPacketNumber packet_number, const std::string& data); // Create an encrypted packet for testing whose data portion erroneous. // The specific way the data portion is erroneous is not specified, but // it is an error that QuicFramer detects. // Note that the packet is encrypted with NullEncrypter, so to decrypt the // constructed packet, the framer must be set to use NullDecrypter. QuicEncryptedPacket* ConstructMisFramedEncryptedPacket( QuicConnectionId connection_id, bool version_flag, bool reset_flag, QuicPacketNumber packet_number, const std::string& data, QuicConnectionIdLength connection_id_length, QuicPacketNumberLength packet_number_length, QuicVersionVector* versions); void CompareCharArraysWithHexError(const std::string& description, const char* actual, const int actual_len, const char* expected, const int expected_len); bool DecodeHexString(const base::StringPiece& hex, std::string* bytes); // Returns the length of a QuicPacket that is capable of holding either a // stream frame or a minimal ack frame. Sets |*payload_length| to the number // of bytes of stream data that will fit in such a packet. size_t GetPacketLengthForOneStream(QuicVersion version, bool include_version, QuicConnectionIdLength connection_id_length, QuicPacketNumberLength packet_number_length, InFecGroup is_in_fec_group, size_t* payload_length); // Returns QuicConfig set to default values. QuicConfig DefaultQuicConfig(); // Returns a QuicConfig set to default values that supports stateless rejects. QuicConfig DefaultQuicConfigStatelessRejects(); // Returns a version vector consisting of |version|. QuicVersionVector SupportedVersions(QuicVersion version); // Testing convenience method to construct a QuicAckFrame with entropy_hash set // to 0 and largest_observed from peer set to |largest_observed|. QuicAckFrame MakeAckFrame(QuicPacketNumber largest_observed); // Testing convenience method to construct a QuicAckFrame with |num_nack_ranges| // nack ranges of width 1 packet, starting from |least_unacked|. QuicAckFrame MakeAckFrameWithNackRanges(size_t num_nack_ranges, QuicPacketNumber least_unacked); // Returns a QuicPacket that is owned by the caller, and // is populated with the fields in |header| and |frames|, or is nullptr if the // packet could not be created. QuicPacket* BuildUnsizedDataPacket(QuicFramer* framer, const QuicPacketHeader& header, const QuicFrames& frames); // Returns a QuicPacket that is owned by the caller, and of size |packet_size|. QuicPacket* BuildUnsizedDataPacket(QuicFramer* framer, const QuicPacketHeader& header, const QuicFrames& frames, size_t packet_size); template class ValueRestore { public: ValueRestore(SaveType* name, SaveType value) : name_(name), value_(*name) { *name_ = value; } ~ValueRestore() { *name_ = value_; } private: SaveType* name_; SaveType value_; DISALLOW_COPY_AND_ASSIGN(ValueRestore); }; // Simple random number generator used to compute random numbers suitable // for pseudo-randomly dropping packets in tests. It works by computing // the sha1 hash of the current seed, and using the first 64 bits as // the next random number, and the next seed. class SimpleRandom { public: SimpleRandom() : seed_(0) {} // Returns a random number in the range [0, kuint64max]. uint64_t RandUint64(); void set_seed(uint64_t seed) { seed_ = seed; } private: uint64_t seed_; DISALLOW_COPY_AND_ASSIGN(SimpleRandom); }; class MockFramerVisitor : public QuicFramerVisitorInterface { public: MockFramerVisitor(); ~MockFramerVisitor() override; MOCK_METHOD1(OnError, void(QuicFramer* framer)); // The constructor sets this up to return false by default. MOCK_METHOD1(OnProtocolVersionMismatch, bool(QuicVersion version)); MOCK_METHOD0(OnPacket, void()); MOCK_METHOD1(OnPublicResetPacket, void(const QuicPublicResetPacket& header)); MOCK_METHOD1(OnVersionNegotiationPacket, void(const QuicVersionNegotiationPacket& packet)); MOCK_METHOD0(OnRevivedPacket, void()); // The constructor sets this up to return true by default. MOCK_METHOD1(OnUnauthenticatedHeader, bool(const QuicPacketHeader& header)); // The constructor sets this up to return true by default. MOCK_METHOD1(OnUnauthenticatedPublicHeader, bool(const QuicPacketPublicHeader& header)); MOCK_METHOD1(OnDecryptedPacket, void(EncryptionLevel level)); MOCK_METHOD1(OnPacketHeader, bool(const QuicPacketHeader& header)); MOCK_METHOD1(OnFecProtectedPayload, void(base::StringPiece payload)); MOCK_METHOD1(OnStreamFrame, bool(const QuicStreamFrame& frame)); MOCK_METHOD1(OnAckFrame, bool(const QuicAckFrame& frame)); MOCK_METHOD1(OnStopWaitingFrame, bool(const QuicStopWaitingFrame& frame)); MOCK_METHOD1(OnPingFrame, bool(const QuicPingFrame& frame)); MOCK_METHOD1(OnFecData, void(StringPiece redundancy)); MOCK_METHOD1(OnRstStreamFrame, bool(const QuicRstStreamFrame& frame)); MOCK_METHOD1(OnConnectionCloseFrame, bool(const QuicConnectionCloseFrame& frame)); MOCK_METHOD1(OnGoAwayFrame, bool(const QuicGoAwayFrame& frame)); MOCK_METHOD1(OnWindowUpdateFrame, bool(const QuicWindowUpdateFrame& frame)); MOCK_METHOD1(OnBlockedFrame, bool(const QuicBlockedFrame& frame)); MOCK_METHOD0(OnPacketComplete, void()); private: DISALLOW_COPY_AND_ASSIGN(MockFramerVisitor); }; class NoOpFramerVisitor : public QuicFramerVisitorInterface { public: NoOpFramerVisitor() {} void OnError(QuicFramer* framer) override {} void OnPacket() override {} void OnPublicResetPacket(const QuicPublicResetPacket& packet) override {} void OnVersionNegotiationPacket( const QuicVersionNegotiationPacket& packet) override {} void OnRevivedPacket() override {} bool OnProtocolVersionMismatch(QuicVersion version) override; bool OnUnauthenticatedHeader(const QuicPacketHeader& header) override; bool OnUnauthenticatedPublicHeader( const QuicPacketPublicHeader& header) override; void OnDecryptedPacket(EncryptionLevel level) override {} bool OnPacketHeader(const QuicPacketHeader& header) override; void OnFecProtectedPayload(base::StringPiece payload) override {} bool OnStreamFrame(const QuicStreamFrame& frame) override; bool OnAckFrame(const QuicAckFrame& frame) override; bool OnStopWaitingFrame(const QuicStopWaitingFrame& frame) override; bool OnPingFrame(const QuicPingFrame& frame) override; void OnFecData(StringPiece redundancy) override {} bool OnRstStreamFrame(const QuicRstStreamFrame& frame) override; bool OnConnectionCloseFrame(const QuicConnectionCloseFrame& frame) override; bool OnGoAwayFrame(const QuicGoAwayFrame& frame) override; bool OnWindowUpdateFrame(const QuicWindowUpdateFrame& frame) override; bool OnBlockedFrame(const QuicBlockedFrame& frame) override; void OnPacketComplete() override {} private: DISALLOW_COPY_AND_ASSIGN(NoOpFramerVisitor); }; class MockConnectionVisitor : public QuicConnectionVisitorInterface { public: MockConnectionVisitor(); ~MockConnectionVisitor() override; MOCK_METHOD1(OnStreamFrame, void(const QuicStreamFrame& frame)); MOCK_METHOD1(OnWindowUpdateFrame, void(const QuicWindowUpdateFrame& frame)); MOCK_METHOD1(OnBlockedFrame, void(const QuicBlockedFrame& frame)); MOCK_METHOD1(OnRstStream, void(const QuicRstStreamFrame& frame)); MOCK_METHOD1(OnGoAway, void(const QuicGoAwayFrame& frame)); MOCK_METHOD2(OnConnectionClosed, void(QuicErrorCode error, bool from_peer)); MOCK_METHOD0(OnWriteBlocked, void()); MOCK_METHOD0(OnCanWrite, void()); MOCK_METHOD1(OnCongestionWindowChange, void(QuicTime now)); MOCK_METHOD0(OnConnectionMigration, void()); MOCK_CONST_METHOD0(WillingAndAbleToWrite, bool()); MOCK_CONST_METHOD0(HasPendingHandshake, bool()); MOCK_CONST_METHOD0(HasOpenDynamicStreams, bool()); MOCK_METHOD1(OnSuccessfulVersionNegotiation, void(const QuicVersion& version)); MOCK_METHOD0(OnConfigNegotiated, void()); private: DISALLOW_COPY_AND_ASSIGN(MockConnectionVisitor); }; class MockConnectionHelper : public QuicConnectionHelperInterface { public: MockConnectionHelper(); ~MockConnectionHelper() override; const QuicClock* GetClock() const override; QuicRandom* GetRandomGenerator() override; QuicAlarm* CreateAlarm(QuicAlarm::Delegate* delegate) override; QuicBufferAllocator* GetBufferAllocator() override; void AdvanceTime(QuicTime::Delta delta); private: MockClock clock_; MockRandom random_generator_; SimpleBufferAllocator buffer_allocator_; DISALLOW_COPY_AND_ASSIGN(MockConnectionHelper); }; class NiceMockPacketWriterFactory : public QuicConnection::PacketWriterFactory { public: NiceMockPacketWriterFactory() {} ~NiceMockPacketWriterFactory() override {} QuicPacketWriter* Create(QuicConnection* /*connection*/) const override; private: DISALLOW_COPY_AND_ASSIGN(NiceMockPacketWriterFactory); }; class MockConnection : public QuicConnection { public: // Uses a ConnectionId of 42 and 127.0.0.1:123. MockConnection(MockConnectionHelper* helper, Perspective perspective); // Uses a ConnectionId of 42. MockConnection(IPEndPoint address, MockConnectionHelper* helper, Perspective perspective); // Uses 127.0.0.1:123. MockConnection(QuicConnectionId connection_id, MockConnectionHelper* helper, Perspective perspective); // Uses a ConnectionId of 42, and 127.0.0.1:123. MockConnection(MockConnectionHelper* helper, Perspective perspective, const QuicVersionVector& supported_versions); MockConnection(QuicConnectionId connection_id, IPEndPoint address, MockConnectionHelper* helper, Perspective perspective, const QuicVersionVector& supported_versions); ~MockConnection() override; // If the constructor that uses a MockConnectionHelper has been used then // this method // will advance the time of the MockClock. void AdvanceTime(QuicTime::Delta delta); MOCK_METHOD3(ProcessUdpPacket, void(const IPEndPoint& self_address, const IPEndPoint& peer_address, const QuicEncryptedPacket& packet)); MOCK_METHOD1(SendConnectionClose, void(QuicErrorCode error)); MOCK_METHOD2(SendConnectionCloseWithDetails, void(QuicErrorCode error, const std::string& details)); MOCK_METHOD2(SendConnectionClosePacket, void(QuicErrorCode error, const std::string& details)); MOCK_METHOD3(SendRstStream, void(QuicStreamId id, QuicRstStreamErrorCode error, QuicStreamOffset bytes_written)); MOCK_METHOD3(SendGoAway, void(QuicErrorCode error, QuicStreamId last_good_stream_id, const std::string& reason)); MOCK_METHOD1(SendBlocked, void(QuicStreamId id)); MOCK_METHOD2(SendWindowUpdate, void(QuicStreamId id, QuicStreamOffset byte_offset)); MOCK_METHOD0(OnCanWrite, void()); MOCK_METHOD1(OnSendConnectionState, void(const CachedNetworkParameters&)); MOCK_METHOD2(ResumeConnectionState, void(const CachedNetworkParameters&, bool)); MOCK_METHOD1(OnError, void(QuicFramer* framer)); void QuicConnection_OnError(QuicFramer* framer) { QuicConnection::OnError(framer); } void ReallyProcessUdpPacket(const IPEndPoint& self_address, const IPEndPoint& peer_address, const QuicEncryptedPacket& packet) { QuicConnection::ProcessUdpPacket(self_address, peer_address, packet); } bool OnProtocolVersionMismatch(QuicVersion version) override { return false; } void ReallySendGoAway(QuicErrorCode error, QuicStreamId last_good_stream_id, const std::string& reason) { QuicConnection::SendGoAway(error, last_good_stream_id, reason); } private: DISALLOW_COPY_AND_ASSIGN(MockConnection); }; class PacketSavingConnection : public MockConnection { public: PacketSavingConnection(MockConnectionHelper* helper, Perspective perspective); PacketSavingConnection(MockConnectionHelper* helper, Perspective perspective, const QuicVersionVector& supported_versions); ~PacketSavingConnection() override; void SendOrQueuePacket(QueuedPacket packet) override; std::vector encrypted_packets_; private: DISALLOW_COPY_AND_ASSIGN(PacketSavingConnection); }; class MockQuicSpdySession : public QuicSpdySession { public: explicit MockQuicSpdySession(QuicConnection* connection); ~MockQuicSpdySession() override; QuicCryptoStream* GetCryptoStream() override { return crypto_stream_.get(); } // From QuicSession. MOCK_METHOD2(OnConnectionClosed, void(QuicErrorCode error, bool from_peer)); MOCK_METHOD1(CreateIncomingDynamicStream, QuicSpdyStream*(QuicStreamId id)); MOCK_METHOD1(CreateOutgoingDynamicStream, QuicSpdyStream*(SpdyPriority priority)); MOCK_METHOD6(WritevData, QuicConsumedData(QuicStreamId id, QuicIOVector data, QuicStreamOffset offset, bool fin, FecProtection fec_protection, QuicAckListenerInterface*)); MOCK_METHOD3(SendRstStream, void(QuicStreamId stream_id, QuicRstStreamErrorCode error, QuicStreamOffset bytes_written)); MOCK_METHOD2(OnStreamHeaders, void(QuicStreamId stream_id, base::StringPiece headers_data)); MOCK_METHOD2(OnStreamHeadersPriority, void(QuicStreamId stream_id, SpdyPriority priority)); MOCK_METHOD3(OnStreamHeadersComplete, void(QuicStreamId stream_id, bool fin, size_t frame_len)); MOCK_METHOD0(IsCryptoHandshakeConfirmed, bool()); MOCK_METHOD5(WriteHeaders, size_t(QuicStreamId id, const SpdyHeaderBlock& headers, bool fin, SpdyPriority priority, QuicAckListenerInterface* ack_notifier_delegate)); MOCK_METHOD1(OnHeadersHeadOfLineBlocking, void(QuicTime::Delta delta)); using QuicSession::ActivateStream; // Returns a QuicConsumedData that indicates all of |data| (and |fin| if set) // has been consumed. static QuicConsumedData ConsumeAllData( QuicStreamId id, const QuicIOVector& data, QuicStreamOffset offset, bool fin, FecProtection fec_protection, QuicAckListenerInterface* ack_notifier_delegate); private: scoped_ptr crypto_stream_; DISALLOW_COPY_AND_ASSIGN(MockQuicSpdySession); }; class TestQuicSpdyServerSession : public tools::QuicServerSession { public: TestQuicSpdyServerSession(QuicConnection* connection, const QuicConfig& config, const QuicCryptoServerConfig* crypto_config); ~TestQuicSpdyServerSession() override; MOCK_METHOD1(CreateIncomingDynamicStream, QuicSpdyStream*(QuicStreamId id)); MOCK_METHOD1(CreateOutgoingDynamicStream, QuicSpdyStream*(SpdyPriority priority)); QuicCryptoServerStream* GetCryptoStream() override; private: tools::test::MockQuicServerSessionVisitor visitor_; DISALLOW_COPY_AND_ASSIGN(TestQuicSpdyServerSession); }; class TestQuicSpdyClientSession : public QuicClientSessionBase { public: TestQuicSpdyClientSession(QuicConnection* connection, const QuicConfig& config, const QuicServerId& server_id, QuicCryptoClientConfig* crypto_config); ~TestQuicSpdyClientSession() override; // QuicClientSessionBase MOCK_METHOD1(OnProofValid, void(const QuicCryptoClientConfig::CachedState& cached)); MOCK_METHOD1(OnProofVerifyDetailsAvailable, void(const ProofVerifyDetails& verify_details)); // TestQuicSpdyClientSession MOCK_METHOD1(CreateIncomingDynamicStream, QuicSpdyStream*(QuicStreamId id)); MOCK_METHOD1(CreateOutgoingDynamicStream, QuicSpdyStream*(SpdyPriority priority)); QuicCryptoClientStream* GetCryptoStream() override; private: scoped_ptr crypto_stream_; DISALLOW_COPY_AND_ASSIGN(TestQuicSpdyClientSession); }; class MockPacketWriter : public QuicPacketWriter { public: MockPacketWriter(); ~MockPacketWriter() override; MOCK_METHOD4(WritePacket, WriteResult(const char* buffer, size_t buf_len, const IPAddressNumber& self_address, const IPEndPoint& peer_address)); MOCK_CONST_METHOD0(IsWriteBlockedDataBuffered, bool()); MOCK_CONST_METHOD0(IsWriteBlocked, bool()); MOCK_METHOD0(SetWritable, void()); MOCK_CONST_METHOD1(GetMaxPacketSize, QuicByteCount(const IPEndPoint& peer_address)); private: DISALLOW_COPY_AND_ASSIGN(MockPacketWriter); }; class MockSendAlgorithm : public SendAlgorithmInterface { public: MockSendAlgorithm(); ~MockSendAlgorithm() override; MOCK_METHOD2(SetFromConfig, void(const QuicConfig& config, Perspective perspective)); MOCK_METHOD1(SetNumEmulatedConnections, void(int num_connections)); MOCK_METHOD1(SetMaxCongestionWindow, void(QuicByteCount max_congestion_window)); MOCK_METHOD4(OnCongestionEvent, void(bool rtt_updated, QuicByteCount bytes_in_flight, const CongestionVector& acked_packets, const CongestionVector& lost_packets)); MOCK_METHOD5(OnPacketSent, bool(QuicTime, QuicByteCount, QuicPacketNumber, QuicByteCount, HasRetransmittableData)); MOCK_METHOD1(OnRetransmissionTimeout, void(bool)); MOCK_METHOD0(OnConnectionMigration, void()); MOCK_METHOD0(RevertRetransmissionTimeout, void()); MOCK_CONST_METHOD3(TimeUntilSend, QuicTime::Delta(QuicTime now, QuicByteCount bytes_in_flight, HasRetransmittableData)); MOCK_CONST_METHOD0(PacingRate, QuicBandwidth(void)); MOCK_CONST_METHOD0(BandwidthEstimate, QuicBandwidth(void)); MOCK_CONST_METHOD0(HasReliableBandwidthEstimate, bool()); MOCK_METHOD1(OnRttUpdated, void(QuicPacketNumber)); MOCK_CONST_METHOD0(RetransmissionDelay, QuicTime::Delta(void)); MOCK_CONST_METHOD0(GetCongestionWindow, QuicByteCount()); MOCK_CONST_METHOD0(InSlowStart, bool()); MOCK_CONST_METHOD0(InRecovery, bool()); MOCK_CONST_METHOD0(GetSlowStartThreshold, QuicByteCount()); MOCK_CONST_METHOD0(GetCongestionControlType, CongestionControlType()); MOCK_METHOD2(ResumeConnectionState, void(const CachedNetworkParameters&, bool)); private: DISALLOW_COPY_AND_ASSIGN(MockSendAlgorithm); }; class MockLossAlgorithm : public LossDetectionInterface { public: MockLossAlgorithm(); ~MockLossAlgorithm() override; MOCK_CONST_METHOD0(GetLossDetectionType, LossDetectionType()); MOCK_METHOD4(DetectLostPackets, PacketNumberSet(const QuicUnackedPacketMap& unacked_packets, const QuicTime& time, QuicPacketNumber largest_observed, const RttStats& rtt_stats)); MOCK_METHOD4(DetectLosses, void(const QuicUnackedPacketMap& unacked_packets, const QuicTime& time, const RttStats& rtt_stats, SendAlgorithmInterface::CongestionVector* packets_lost)); MOCK_CONST_METHOD0(GetLossTimeout, QuicTime()); private: DISALLOW_COPY_AND_ASSIGN(MockLossAlgorithm); }; class TestEntropyCalculator : public QuicReceivedEntropyHashCalculatorInterface { public: TestEntropyCalculator(); ~TestEntropyCalculator() override; QuicPacketEntropyHash EntropyHash( QuicPacketNumber packet_number) const override; private: DISALLOW_COPY_AND_ASSIGN(TestEntropyCalculator); }; class MockEntropyCalculator : public TestEntropyCalculator { public: MockEntropyCalculator(); ~MockEntropyCalculator() override; MOCK_CONST_METHOD1(EntropyHash, QuicPacketEntropyHash(QuicPacketNumber packet_number)); private: DISALLOW_COPY_AND_ASSIGN(MockEntropyCalculator); }; class MockAckListener : public QuicAckListenerInterface { public: MockAckListener(); MOCK_METHOD2(OnPacketAcked, void(int acked_bytes, QuicTime::Delta delta_largest_observed)); MOCK_METHOD1(OnPacketRetransmitted, void(int retransmitted_bytes)); protected: // Object is ref counted. ~MockAckListener() override; private: DISALLOW_COPY_AND_ASSIGN(MockAckListener); }; class MockNetworkChangeVisitor : public QuicSentPacketManager::NetworkChangeVisitor { public: MockNetworkChangeVisitor(); ~MockNetworkChangeVisitor() override; MOCK_METHOD0(OnCongestionWindowChange, void()); MOCK_METHOD0(OnRttChange, void()); private: DISALLOW_COPY_AND_ASSIGN(MockNetworkChangeVisitor); }; // Creates per-connection packet writers that register themselves with the // TestWriterFactory on each write so that TestWriterFactory::OnPacketSent can // be routed to the appropriate QuicConnection. class TestWriterFactory : public tools::QuicDispatcher::PacketWriterFactory { public: TestWriterFactory(); ~TestWriterFactory() override; QuicPacketWriter* Create(QuicPacketWriter* writer, QuicConnection* connection) override; // Calls OnPacketSent on the last QuicConnection to write through one of the // packet writers created by this factory. void OnPacketSent(WriteResult result); private: class PerConnectionPacketWriter : public tools::QuicPerConnectionPacketWriter { public: PerConnectionPacketWriter(TestWriterFactory* factory, QuicPacketWriter* writer, QuicConnection* connection); ~PerConnectionPacketWriter() override; WriteResult WritePacket(const char* buffer, size_t buf_len, const IPAddressNumber& self_address, const IPEndPoint& peer_address) override; private: TestWriterFactory* factory_; }; // If an asynchronous write is happening and |writer| gets deleted, this // clears the pointer to it to prevent use-after-free. void Unregister(PerConnectionPacketWriter* writer); PerConnectionPacketWriter* current_writer_; }; class MockQuicConnectionDebugVisitor : public QuicConnectionDebugVisitor { public: MockQuicConnectionDebugVisitor(); ~MockQuicConnectionDebugVisitor() override; MOCK_METHOD1(OnFrameAddedToPacket, void(const QuicFrame&)); MOCK_METHOD5(OnPacketSent, void(const SerializedPacket&, QuicPacketNumber, TransmissionType, size_t encrypted_length, QuicTime)); MOCK_METHOD3(OnPacketReceived, void(const IPEndPoint&, const IPEndPoint&, const QuicEncryptedPacket&)); MOCK_METHOD1(OnIncorrectConnectionId, void(QuicConnectionId)); MOCK_METHOD1(OnProtocolVersionMismatch, void(QuicVersion)); MOCK_METHOD1(OnPacketHeader, void(const QuicPacketHeader& header)); MOCK_METHOD1(OnSuccessfulVersionNegotiation, void(const QuicVersion&)); MOCK_METHOD1(OnStreamFrame, void(const QuicStreamFrame&)); MOCK_METHOD1(OnAckFrame, void(const QuicAckFrame& frame)); MOCK_METHOD1(OnStopWaitingFrame, void(const QuicStopWaitingFrame&)); MOCK_METHOD1(OnRstStreamFrame, void(const QuicRstStreamFrame&)); MOCK_METHOD1(OnConnectionCloseFrame, void(const QuicConnectionCloseFrame&)); MOCK_METHOD1(OnPublicResetPacket, void(const QuicPublicResetPacket&)); MOCK_METHOD1(OnVersionNegotiationPacket, void(const QuicVersionNegotiationPacket&)); MOCK_METHOD2(OnRevivedPacket, void(const QuicPacketHeader&, StringPiece payload)); }; class MockReceivedPacketManager : public QuicReceivedPacketManager { public: explicit MockReceivedPacketManager(QuicConnectionStats* stats); ~MockReceivedPacketManager() override; MOCK_METHOD3(RecordPacketReceived, void(QuicByteCount bytes, const QuicPacketHeader& header, QuicTime receipt_time)); MOCK_METHOD1(RecordPacketRevived, void(QuicPacketNumber packet_number)); MOCK_METHOD1(IsMissing, bool(QuicPacketNumber packet_number)); MOCK_METHOD1(IsAwaitingPacket, bool(QuicPacketNumber packet_number)); MOCK_METHOD1(UpdatePacketInformationSentByPeer, void(const QuicStopWaitingFrame& stop_waiting)); MOCK_CONST_METHOD0(HasNewMissingPackets, bool(void)); MOCK_CONST_METHOD0(ack_frame_updated, bool(void)); }; // Creates a client session for testing. // // server_id: The server id associated with this stream. // supports_stateless_rejects: Does this client support stateless rejects. // connection_start_time: The time to set for the connection clock. // Needed for strike-register nonce verification. The client // connection_start_time should be synchronized witht the server // start time, otherwise nonce verification will fail. // supported_versions: Set of QUIC versions this client supports. // helper: Pointer to the MockConnectionHelper to use for the session. // crypto_client_config: Pointer to the crypto client config. // client_connection: Pointer reference for newly created // connection. This object will be owned by the // client_session. // client_session: Pointer reference for the newly created client // session. The new object will be owned by the caller. void CreateClientSessionForTest(QuicServerId server_id, bool supports_stateless_rejects, QuicTime::Delta connection_start_time, QuicVersionVector supported_versions, MockConnectionHelper* helper, QuicCryptoClientConfig* crypto_client_config, PacketSavingConnection** client_connection, TestQuicSpdyClientSession** client_session); // Creates a server session for testing. // // server_id: The server id associated with this stream. // connection_start_time: The time to set for the connection clock. // Needed for strike-register nonce verification. The server // connection_start_time should be synchronized witht the client // start time, otherwise nonce verification will fail. // supported_versions: Set of QUIC versions this server supports. // helper: Pointer to the MockConnectionHelper to use for the session. // crypto_server_config: Pointer to the crypto server config. // server_connection: Pointer reference for newly created // connection. This object will be owned by the // server_session. // server_session: Pointer reference for the newly created server // session. The new object will be owned by the caller. void CreateServerSessionForTest(QuicServerId server_id, QuicTime::Delta connection_start_time, QuicVersionVector supported_versions, MockConnectionHelper* helper, QuicCryptoServerConfig* crypto_server_config, PacketSavingConnection** server_connection, TestQuicSpdyServerSession** server_session); // Helper to generate client side stream ids, generalizes // kClientDataStreamId1 etc. above. QuicStreamId QuicClientDataStreamId(int i); } // namespace test } // namespace net #endif // NET_QUIC_TEST_TOOLS_QUIC_TEST_UTILS_H_