blob: 30e358f4bc65b189e7e307f134c000e83d4fc625 [file] [log] [blame]
QUICHE teama6ef0a62019-03-07 20:34:33 -05001// Copyright (c) 2012 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_
6#define QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_
7
8#include <cstdint>
9#include <map>
10#include <memory>
11
QUICHE teama6ef0a62019-03-07 20:34:33 -050012#include "net/third_party/quiche/src/quic/core/quic_packets.h"
13#include "net/third_party/quiche/src/quic/core/quic_session.h"
14#include "net/third_party/quiche/src/quic/core/quic_write_blocked_list.h"
15#include "net/third_party/quiche/src/quic/platform/api/quic_containers.h"
16
17namespace quic {
18
19class QuicCryptoStream;
20class QuicSession;
21class QuicStream;
22
23namespace test {
24
25class QuicSessionPeer {
26 public:
27 QuicSessionPeer() = delete;
28
29 static QuicStreamId GetNextOutgoingBidirectionalStreamId(
30 QuicSession* session);
31 static QuicStreamId GetNextOutgoingUnidirectionalStreamId(
32 QuicSession* session);
33 static void SetNextOutgoingBidirectionalStreamId(QuicSession* session,
34 QuicStreamId id);
35 static void SetMaxOpenIncomingStreams(QuicSession* session,
36 uint32_t max_streams);
37 static void SetMaxOpenOutgoingStreams(QuicSession* session,
38 uint32_t max_streams);
39 static QuicCryptoStream* GetMutableCryptoStream(QuicSession* session);
40 static QuicWriteBlockedList* GetWriteBlockedStreams(QuicSession* session);
41 static QuicStream* GetOrCreateDynamicStream(QuicSession* session,
42 QuicStreamId stream_id);
43 static std::map<QuicStreamId, QuicStreamOffset>&
44 GetLocallyClosedStreamsHighestOffset(QuicSession* session);
45 static QuicSession::StaticStreamMap& static_streams(QuicSession* session);
46 static QuicSession::DynamicStreamMap& dynamic_streams(QuicSession* session);
47 static const QuicSession::ClosedStreams& closed_streams(QuicSession* session);
48 static QuicSession::ZombieStreamMap& zombie_streams(QuicSession* session);
49 static QuicUnorderedSet<QuicStreamId>* GetDrainingStreams(
50 QuicSession* session);
51 static void ActivateStream(QuicSession* session,
52 std::unique_ptr<QuicStream> stream);
53
54 // Discern the state of a stream. Exactly one of these should be true at a
55 // time for any stream id > 0 (other than the special streams 1 and 3).
56 static bool IsStreamClosed(QuicSession* session, QuicStreamId id);
57 static bool IsStreamCreated(QuicSession* session, QuicStreamId id);
58 static bool IsStreamAvailable(QuicSession* session, QuicStreamId id);
59
60 static QuicStream* GetStream(QuicSession* session, QuicStreamId id);
61 static bool IsStreamWriteBlocked(QuicSession* session, QuicStreamId id);
62 static QuicAlarm* GetCleanUpClosedStreamsAlarm(QuicSession* session);
63 static LegacyQuicStreamIdManager* GetStreamIdManager(QuicSession* session);
64 static UberQuicStreamIdManager* v99_streamid_manager(QuicSession* session);
65 static QuicStreamIdManager* v99_bidirectional_stream_id_manager(
66 QuicSession* session);
67 static QuicStreamIdManager* v99_unidirectional_stream_id_manager(
68 QuicSession* session);
69 static void SendRstStreamInner(QuicSession* session,
70 QuicStreamId id,
71 QuicRstStreamErrorCode error,
72 QuicStreamOffset bytes_written,
73 bool close_write_side_only);
74};
75
76} // namespace test
77
78} // namespace quic
79
80#endif // QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_