| // Copyright 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 QUICHE_QUIC_TEST_TOOLS_PACKET_REORDERING_WRITER_H_ | 
 | #define QUICHE_QUIC_TEST_TOOLS_PACKET_REORDERING_WRITER_H_ | 
 |  | 
 | #include "quic/core/quic_packet_writer_wrapper.h" | 
 |  | 
 | namespace quic { | 
 |  | 
 | namespace test { | 
 |  | 
 | // This packet writer allows delaying writing the next packet after | 
 | // SetDelay(num_packets_to_wait) | 
 | // is called and buffer this packet and write it after it writes next | 
 | // |num_packets_to_wait| packets. It doesn't support delaying a packet while | 
 | // there is already a packet delayed. | 
 | class PacketReorderingWriter : public QuicPacketWriterWrapper { | 
 |  public: | 
 |   PacketReorderingWriter(); | 
 |  | 
 |   ~PacketReorderingWriter() override; | 
 |  | 
 |   WriteResult WritePacket(const char* buffer, | 
 |                           size_t buf_len, | 
 |                           const QuicIpAddress& self_address, | 
 |                           const QuicSocketAddress& peer_address, | 
 |                           PerPacketOptions* options) override; | 
 |  | 
 |   void SetDelay(size_t num_packets_to_wait); | 
 |  | 
 |  private: | 
 |   bool delay_next_ = false; | 
 |   size_t num_packets_to_wait_ = 0; | 
 |   std::string delayed_data_; | 
 |   QuicIpAddress delayed_self_address_; | 
 |   QuicSocketAddress delayed_peer_address_; | 
 |   std::unique_ptr<PerPacketOptions> delayed_options_; | 
 | }; | 
 |  | 
 | }  // namespace test | 
 | }  // namespace quic | 
 |  | 
 | #endif  // QUICHE_QUIC_TEST_TOOLS_PACKET_REORDERING_WRITER_H_ |