blob: f027eb564a6abffc4abe6095137d52716b81239a [file] [log] [blame]
// 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.
#ifndef QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_
#define QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_
#include <cstdint>
#include <map>
#include <memory>
#include "net/third_party/quiche/src/quic/core/quic_packets.h"
#include "net/third_party/quiche/src/quic/core/quic_session.h"
#include "net/third_party/quiche/src/quic/core/quic_write_blocked_list.h"
#include "net/third_party/quiche/src/quic/platform/api/quic_containers.h"
namespace quic {
class QuicCryptoStream;
class QuicSession;
class QuicStream;
namespace test {
class QuicSessionPeer {
public:
QuicSessionPeer() = delete;
static QuicStreamId GetNextOutgoingBidirectionalStreamId(
QuicSession* session);
static QuicStreamId GetNextOutgoingUnidirectionalStreamId(
QuicSession* session);
static void SetNextOutgoingBidirectionalStreamId(QuicSession* session,
QuicStreamId id);
// Following is only for Google-QUIC, will QUIC_BUG if called for IETF
// QUIC.
static void SetMaxOpenIncomingStreams(QuicSession* session,
uint32_t max_streams);
// Following two are only for IETF-QUIC, will QUIC_BUG if called for Google
// QUIC.
static void SetMaxOpenIncomingBidirectionalStreams(QuicSession* session,
uint32_t max_streams);
static void SetMaxOpenIncomingUnidirectionalStreams(QuicSession* session,
uint32_t max_streams);
static void SetMaxOpenOutgoingStreams(QuicSession* session,
uint32_t max_streams);
static void SetMaxOpenOutgoingBidirectionalStreams(QuicSession* session,
uint32_t max_streams);
static void SetMaxOpenOutgoingUnidirectionalStreams(QuicSession* session,
uint32_t max_streams);
static QuicCryptoStream* GetMutableCryptoStream(QuicSession* session);
static QuicWriteBlockedList* GetWriteBlockedStreams(QuicSession* session);
static QuicStream* GetOrCreateStream(QuicSession* session,
QuicStreamId stream_id);
static std::map<QuicStreamId, QuicStreamOffset>&
GetLocallyClosedStreamsHighestOffset(QuicSession* session);
static QuicSession::StreamMap& stream_map(QuicSession* session);
static const QuicSession::ClosedStreams& closed_streams(QuicSession* session);
static QuicSession::ZombieStreamMap& zombie_streams(QuicSession* session);
static QuicUnorderedSet<QuicStreamId>* GetDrainingStreams(
QuicSession* session);
static void ActivateStream(QuicSession* session,
std::unique_ptr<QuicStream> stream);
static void RegisterStaticStream(QuicSession* session,
std::unique_ptr<QuicStream> stream);
// Discern the state of a stream. Exactly one of these should be true at a
// time for any stream id > 0 (other than the special streams 1 and 3).
static bool IsStreamClosed(QuicSession* session, QuicStreamId id);
static bool IsStreamCreated(QuicSession* session, QuicStreamId id);
static bool IsStreamAvailable(QuicSession* session, QuicStreamId id);
static QuicStream* GetStream(QuicSession* session, QuicStreamId id);
static bool IsStreamWriteBlocked(QuicSession* session, QuicStreamId id);
static QuicAlarm* GetCleanUpClosedStreamsAlarm(QuicSession* session);
static LegacyQuicStreamIdManager* GetStreamIdManager(QuicSession* session);
static UberQuicStreamIdManager* v99_streamid_manager(QuicSession* session);
static QuicStreamIdManager* v99_bidirectional_stream_id_manager(
QuicSession* session);
static QuicStreamIdManager* v99_unidirectional_stream_id_manager(
QuicSession* session);
static void SendRstStreamInner(QuicSession* session,
QuicStreamId id,
QuicRstStreamErrorCode error,
QuicStreamOffset bytes_written,
bool close_write_side_only);
};
} // namespace test
} // namespace quic
#endif // QUICHE_QUIC_TEST_TOOLS_QUIC_SESSION_PEER_H_