Skip to content

Commit

Permalink
http: Deprecate stop_decode_metadata_on_local_reply reloadable flag (#…
Browse files Browse the repository at this point in the history
…34758)

Signed-off-by: Paul Ogilby <[email protected]>
  • Loading branch information
paul-r-gall authored Jun 14, 2024
1 parent 643822d commit 63621d0
Show file tree
Hide file tree
Showing 4 changed files with 4 additions and 48 deletions.
3 changes: 3 additions & 0 deletions changelogs/current.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -240,6 +240,9 @@ removed_config_or_runtime:
- area: jwt
change: |
Removed ``envoy.reloadable_features.token_passed_entirely`` runtime flag and legacy code paths.
- area: http
change: |
Removed ``envoy.reloadable_features.stop_decode_metadata_on_local_reply`` runtime flag and legacy code paths.
new_features:
- area: hot_restart
Expand Down
4 changes: 1 addition & 3 deletions source/common/http/filter_manager.cc
Original file line number Diff line number Diff line change
Expand Up @@ -442,9 +442,7 @@ void ActiveStreamDecoderFilter::drainSavedRequestMetadata() {
}

void ActiveStreamDecoderFilter::handleMetadataAfterHeadersCallback() {
if (parent_.state_.decoder_filter_chain_aborted_ &&
Runtime::runtimeFeatureEnabled(
"envoy.reloadable_features.stop_decode_metadata_on_local_reply")) {
if (parent_.state_.decoder_filter_chain_aborted_) {
// The decoder filter chain has been aborted, possibly due to a local reply. In this case,
// there's no reason to decode saved metadata.
getSavedRequestMetadata()->clear();
Expand Down
1 change: 0 additions & 1 deletion source/common/runtime/runtime_features.cc
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,6 @@ RUNTIME_GUARD(envoy_reloadable_features_send_local_reply_when_no_buffer_and_upst
RUNTIME_GUARD(envoy_reloadable_features_skip_dns_lookup_for_proxied_requests);
RUNTIME_GUARD(envoy_reloadable_features_ssl_transport_failure_reason_format);
RUNTIME_GUARD(envoy_reloadable_features_stateful_session_encode_ttl_in_cookie);
RUNTIME_GUARD(envoy_reloadable_features_stop_decode_metadata_on_local_reply);
RUNTIME_GUARD(envoy_reloadable_features_strict_duration_validation);
RUNTIME_GUARD(envoy_reloadable_features_tcp_tunneling_send_downstream_fin_on_upstream_trailers);
RUNTIME_GUARD(envoy_reloadable_features_test_feature_true);
Expand Down
44 changes: 0 additions & 44 deletions test/common/http/filter_manager_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -742,50 +742,6 @@ TEST_F(FilterManagerTest, MetadataContinueAllFollowedByHeadersLocalReply) {
filter_manager_->destroyFilters();
}

TEST_F(FilterManagerTest, MetadataContinueAllFollowedByHeadersLocalReplyRuntimeFlagOff) {
TestScopedRuntime scoped_runtime;
scoped_runtime.mergeValues(
{{"envoy.reloadable_features.stop_decode_metadata_on_local_reply", "false"}});
initialize();

std::shared_ptr<MockStreamFilter> filter_1(new NiceMock<MockStreamFilter>());

std::shared_ptr<MockStreamFilter> filter_2(new NiceMock<MockStreamFilter>());

EXPECT_CALL(filter_factory_, createFilterChain(_))
.WillRepeatedly(Invoke([&](FilterChainManager& manager) -> bool {
auto decoder_factory = createStreamFilterFactoryCb(filter_1);
manager.applyFilterFactoryCb({"configName1", "filterName1"}, decoder_factory);
decoder_factory = createStreamFilterFactoryCb(filter_2);
manager.applyFilterFactoryCb({"configName2", "filterName2"}, decoder_factory);
return true;
}));
filter_manager_->createFilterChain();

// Decode path:
EXPECT_CALL(*filter_1, decodeHeaders(_, _)).WillOnce(Return(FilterHeadersStatus::StopIteration));
RequestHeaderMapPtr basic_headers{
new TestRequestHeaderMapImpl{{":authority", "host"}, {":path", "/"}, {":method", "GET"}}};
ON_CALL(filter_manager_callbacks_, requestHeaders())
.WillByDefault(Return(makeOptRef(*basic_headers)));

filter_manager_->requestHeadersInitialized();
filter_manager_->decodeHeaders(*basic_headers, false);

EXPECT_CALL(*filter_1, decodeMetadata(_)).WillOnce(Return(FilterMetadataStatus::ContinueAll));
MetadataMap map1 = {{"a", "b"}};
MetadataMap map2 = {{"c", "d"}};
EXPECT_CALL(*filter_2, decodeHeaders(_, _)).WillOnce([&]() {
filter_2->decoder_callbacks_->sendLocalReply(Code::InternalServerError, "bad_headers", nullptr,
absl::nullopt, "bad_headers");
return FilterHeadersStatus::StopIteration;
});
// filter_2 decodes metadata, even though the decoder filter chain has been aborted.
EXPECT_CALL(*filter_2, decodeMetadata(_));
filter_manager_->decodeMetadata(map1);
filter_manager_->destroyFilters();
}

TEST_F(FilterManagerTest, EncodeMetadataSendsLocalReply) {
initialize();

Expand Down

0 comments on commit 63621d0

Please sign in to comment.