blob: 94f0bf5379941bfc3f4fca7a38ed158cd49fcdf4 [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
vasilvv45a59fe2021-02-02 12:07:25 -080012#include "absl/container/flat_hash_map.h"
QUICHE team5be974e2020-12-29 18:35:24 -050013#include "quic/core/quic_packets.h"
14#include "quic/core/quic_session.h"
15#include "quic/core/quic_write_blocked_list.h"
16#include "quic/platform/api/quic_containers.h"
QUICHE teama6ef0a62019-03-07 20:34:33 -050017
18namespace quic {
19
20class QuicCryptoStream;
21class QuicSession;
22class QuicStream;
23
24namespace test {
25
26class QuicSessionPeer {
27 public:
28 QuicSessionPeer() = delete;
29
30 static QuicStreamId GetNextOutgoingBidirectionalStreamId(
31 QuicSession* session);
32 static QuicStreamId GetNextOutgoingUnidirectionalStreamId(
33 QuicSession* session);
34 static void SetNextOutgoingBidirectionalStreamId(QuicSession* session,
35 QuicStreamId id);
fkastenholzd3a1de92019-05-15 07:00:07 -070036 // Following is only for Google-QUIC, will QUIC_BUG if called for IETF
37 // QUIC.
QUICHE teama6ef0a62019-03-07 20:34:33 -050038 static void SetMaxOpenIncomingStreams(QuicSession* session,
39 uint32_t max_streams);
fkastenholzd3a1de92019-05-15 07:00:07 -070040 // Following two are only for IETF-QUIC, will QUIC_BUG if called for Google
41 // QUIC.
42 static void SetMaxOpenIncomingBidirectionalStreams(QuicSession* session,
43 uint32_t max_streams);
44 static void SetMaxOpenIncomingUnidirectionalStreams(QuicSession* session,
45 uint32_t max_streams);
46
QUICHE teama6ef0a62019-03-07 20:34:33 -050047 static void SetMaxOpenOutgoingStreams(QuicSession* session,
48 uint32_t max_streams);
fkastenholzd3a1de92019-05-15 07:00:07 -070049 static void SetMaxOpenOutgoingBidirectionalStreams(QuicSession* session,
50 uint32_t max_streams);
51 static void SetMaxOpenOutgoingUnidirectionalStreams(QuicSession* session,
52 uint32_t max_streams);
53
QUICHE teama6ef0a62019-03-07 20:34:33 -050054 static QuicCryptoStream* GetMutableCryptoStream(QuicSession* session);
55 static QuicWriteBlockedList* GetWriteBlockedStreams(QuicSession* session);
renjietang880d2432019-07-16 13:14:37 -070056 static QuicStream* GetOrCreateStream(QuicSession* session,
57 QuicStreamId stream_id);
vasilvv45a59fe2021-02-02 12:07:25 -080058 static absl::flat_hash_map<QuicStreamId, QuicStreamOffset>&
QUICHE teama6ef0a62019-03-07 20:34:33 -050059 GetLocallyClosedStreamsHighestOffset(QuicSession* session);
renjietang55d182a2019-07-12 10:26:25 -070060 static QuicSession::StreamMap& stream_map(QuicSession* session);
QUICHE teama6ef0a62019-03-07 20:34:33 -050061 static const QuicSession::ClosedStreams& closed_streams(QuicSession* session);
QUICHE teama6ef0a62019-03-07 20:34:33 -050062 static void ActivateStream(QuicSession* session,
63 std::unique_ptr<QuicStream> stream);
QUICHE teama6ef0a62019-03-07 20:34:33 -050064
65 // Discern the state of a stream. Exactly one of these should be true at a
66 // time for any stream id > 0 (other than the special streams 1 and 3).
67 static bool IsStreamClosed(QuicSession* session, QuicStreamId id);
68 static bool IsStreamCreated(QuicSession* session, QuicStreamId id);
69 static bool IsStreamAvailable(QuicSession* session, QuicStreamId id);
70
71 static QuicStream* GetStream(QuicSession* session, QuicStreamId id);
72 static bool IsStreamWriteBlocked(QuicSession* session, QuicStreamId id);
73 static QuicAlarm* GetCleanUpClosedStreamsAlarm(QuicSession* session);
74 static LegacyQuicStreamIdManager* GetStreamIdManager(QuicSession* session);
renjietangf8bde4b2020-10-02 13:25:08 -070075 static UberQuicStreamIdManager* ietf_streamid_manager(QuicSession* session);
76 static QuicStreamIdManager* ietf_bidirectional_stream_id_manager(
QUICHE teama6ef0a62019-03-07 20:34:33 -050077 QuicSession* session);
renjietangf8bde4b2020-10-02 13:25:08 -070078 static QuicStreamIdManager* ietf_unidirectional_stream_id_manager(
QUICHE teama6ef0a62019-03-07 20:34:33 -050079 QuicSession* session);
bnc092d8212019-08-07 11:53:20 -070080 static PendingStream* GetPendingStream(QuicSession* session,
81 QuicStreamId stream_id);
fkastenholz56055be2019-09-17 11:17:37 -070082 static void set_is_configured(QuicSession* session, bool value);
dschinazi31e94d42019-12-18 11:55:39 -080083 static void SetPerspective(QuicSession* session, Perspective perspective);
fayang01591ae2020-04-23 14:14:56 -070084 static size_t GetNumOpenDynamicStreams(QuicSession* session);
fayang116fa4c2020-06-02 08:10:49 -070085 static size_t GetNumDrainingStreams(QuicSession* session);
bncc03d2c22020-10-15 13:30:09 -070086 static QuicStreamId GetLargestPeerCreatedStreamId(QuicSession* session,
87 bool unidirectional) {
88 return session->GetLargestPeerCreatedStreamId(unidirectional);
89 }
QUICHE teama6ef0a62019-03-07 20:34:33 -050090};
91
92} // namespace test
93
94} // namespace quic
95
96#endif // QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_