forked from envoyproxy/envoy
-
Notifications
You must be signed in to change notification settings - Fork 1
/
integration_stream_decoder.h
90 lines (77 loc) · 3.48 KB
/
integration_stream_decoder.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#pragma once
#include <cstdint>
#include <memory>
#include <string>
#include "envoy/event/dispatcher.h"
#include "envoy/http/codec.h"
#include "envoy/http/header_map.h"
#include "envoy/http/metadata_interface.h"
#include "source/common/common/dump_state_utils.h"
#include "test/test_common/utility.h"
#include "absl/container/node_hash_map.h"
#include "absl/strings/string_view.h"
#include "gtest/gtest.h"
namespace Envoy {
/**
* Stream decoder wrapper used during integration testing.
*/
class IntegrationStreamDecoder : public Http::ResponseDecoder, public Http::StreamCallbacks {
public:
IntegrationStreamDecoder(Event::Dispatcher& dispatcher);
~IntegrationStreamDecoder() override;
const std::string& body() { return body_; }
bool complete() { return saw_end_stream_; }
bool reset() { return saw_reset_; }
Http::StreamResetReason resetReason() { return reset_reason_; }
const Http::ResponseHeaderMap* informationalHeaders() { return continue_headers_.get(); }
const Http::ResponseHeaderMap& headers() { return *headers_; }
const Http::ResponseTrailerMapPtr& trailers() { return trailers_; }
const Http::MetadataMap& metadataMap() { return *metadata_map_; }
uint64_t keyCount(std::string key) { return duplicated_metadata_key_count_[key]; }
uint32_t metadataMapsDecodedCount() const { return metadata_maps_decoded_count_; }
void waitFor1xxHeaders();
void waitForHeaders();
// This function waits until body_ has at least size bytes in it (it might have more). clearBody()
// can be used if the previous body data is not relevant and the test wants to wait for a specific
// amount of new data without considering the existing body size.
void waitForBodyData(uint64_t size);
ABSL_MUST_USE_RESULT testing::AssertionResult
waitForEndStream(std::chrono::milliseconds timeout = TestUtility::DefaultTimeout);
ABSL_MUST_USE_RESULT testing::AssertionResult
waitForReset(std::chrono::milliseconds timeout = TestUtility::DefaultTimeout);
void clearBody() { body_.clear(); }
// Http::StreamDecoder
void decodeData(Buffer::Instance& data, bool end_stream) override;
void decodeMetadata(Http::MetadataMapPtr&& metadata_map) override;
// Http::ResponseDecoder
void decode1xxHeaders(Http::ResponseHeaderMapPtr&& headers) override;
void decodeHeaders(Http::ResponseHeaderMapPtr&& headers, bool end_stream) override;
void decodeTrailers(Http::ResponseTrailerMapPtr&& trailers) override;
void dumpState(std::ostream& os, int indent_level) const override {
DUMP_STATE_UNIMPLEMENTED(DecoderShim);
}
// Http::StreamCallbacks
void onResetStream(Http::StreamResetReason reason,
absl::string_view transport_failure_reason) override;
void onAboveWriteBufferHighWatermark() override {}
void onBelowWriteBufferLowWatermark() override {}
private:
Event::Dispatcher& dispatcher_;
Http::ResponseHeaderMapPtr continue_headers_;
Http::ResponseHeaderMapPtr headers_;
Http::ResponseTrailerMapPtr trailers_;
Http::MetadataMapPtr metadata_map_{new Http::MetadataMap()};
absl::node_hash_map<std::string, uint64_t> duplicated_metadata_key_count_;
bool waiting_for_end_stream_{};
bool saw_end_stream_{};
std::string body_;
uint64_t body_data_waiting_length_{};
bool waiting_for_reset_{};
bool waiting_for_continue_headers_{};
bool waiting_for_headers_{};
bool saw_reset_{};
Http::StreamResetReason reset_reason_{};
uint32_t metadata_maps_decoded_count_{};
};
using IntegrationStreamDecoderPtr = std::unique_ptr<IntegrationStreamDecoder>;
} // namespace Envoy