QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 1 | // Copyright (c) 2018 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 | #include "net/third_party/quiche/src/quic/core/qpack/qpack_decoder_test_utils.h" |
| 6 | |
| 7 | #include <algorithm> |
| 8 | #include <cstddef> |
| 9 | #include <utility> |
| 10 | |
dschinazi | 580d30b | 2019-04-26 15:05:20 -0700 | [diff] [blame] | 11 | #include "net/third_party/quiche/src/quic/platform/api/quic_test.h" |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 12 | |
| 13 | namespace quic { |
| 14 | namespace test { |
| 15 | |
| 16 | void NoopEncoderStreamErrorDelegate::OnEncoderStreamError( |
| 17 | QuicStringPiece error_message) {} |
| 18 | |
| 19 | void NoopDecoderStreamSenderDelegate::WriteDecoderStreamData( |
| 20 | QuicStringPiece data) {} |
| 21 | |
| 22 | TestHeadersHandler::TestHeadersHandler() |
| 23 | : decoding_completed_(false), decoding_error_detected_(false) {} |
| 24 | |
| 25 | void TestHeadersHandler::OnHeaderDecoded(QuicStringPiece name, |
| 26 | QuicStringPiece value) { |
| 27 | ASSERT_FALSE(decoding_completed_); |
| 28 | ASSERT_FALSE(decoding_error_detected_); |
| 29 | |
| 30 | header_list_.AppendValueOrAddHeader(name, value); |
| 31 | } |
| 32 | |
| 33 | void TestHeadersHandler::OnDecodingCompleted() { |
| 34 | ASSERT_FALSE(decoding_completed_); |
| 35 | ASSERT_FALSE(decoding_error_detected_); |
| 36 | |
| 37 | decoding_completed_ = true; |
| 38 | } |
| 39 | |
| 40 | void TestHeadersHandler::OnDecodingErrorDetected( |
| 41 | QuicStringPiece error_message) { |
| 42 | ASSERT_FALSE(decoding_completed_); |
| 43 | ASSERT_FALSE(decoding_error_detected_); |
| 44 | |
| 45 | decoding_error_detected_ = true; |
| 46 | } |
| 47 | |
| 48 | spdy::SpdyHeaderBlock TestHeadersHandler::ReleaseHeaderList() { |
| 49 | DCHECK(decoding_completed_); |
| 50 | DCHECK(!decoding_error_detected_); |
| 51 | |
| 52 | return std::move(header_list_); |
| 53 | } |
| 54 | |
| 55 | bool TestHeadersHandler::decoding_completed() const { |
| 56 | return decoding_completed_; |
| 57 | } |
| 58 | |
| 59 | bool TestHeadersHandler::decoding_error_detected() const { |
| 60 | return decoding_error_detected_; |
| 61 | } |
| 62 | |
| 63 | void QpackDecode( |
| 64 | QpackDecoder::EncoderStreamErrorDelegate* encoder_stream_error_delegate, |
| 65 | QpackDecoderStreamSender::Delegate* decoder_stream_sender_delegate, |
| 66 | QpackProgressiveDecoder::HeadersHandlerInterface* handler, |
| 67 | const FragmentSizeGenerator& fragment_size_generator, |
| 68 | QuicStringPiece data) { |
| 69 | QpackDecoder decoder(encoder_stream_error_delegate, |
| 70 | decoder_stream_sender_delegate); |
| 71 | auto progressive_decoder = |
bnc | a904b05 | 2019-06-11 11:34:38 -0700 | [diff] [blame] | 72 | decoder.CreateProgressiveDecoder(/* stream_id = */ 1, handler); |
QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 73 | while (!data.empty()) { |
| 74 | size_t fragment_size = std::min(fragment_size_generator(), data.size()); |
| 75 | progressive_decoder->Decode(data.substr(0, fragment_size)); |
| 76 | data = data.substr(fragment_size); |
| 77 | } |
| 78 | progressive_decoder->EndHeaderBlock(); |
| 79 | } |
| 80 | |
| 81 | } // namespace test |
| 82 | } // namespace quic |