Skip to content

Commit

Permalink
wasm,test: increase coverage on encode/decodeData. (#17292)
Browse files Browse the repository at this point in the history
Signed-off-by: Takeshi Yoneda <[email protected]>
  • Loading branch information
mathetake authored Jul 13, 2021
1 parent f2821a7 commit 4b7389a
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 6 deletions.
4 changes: 2 additions & 2 deletions test/extensions/filters/http/wasm/test_data/test_body_cpp.cc
Original file line number Diff line number Diff line change
Expand Up @@ -57,12 +57,12 @@ FilterDataStatus BodyContext::onBody(WasmBufferType type, size_t buffer_length,
getBufferStatus(type, &size, &flags);
setBuffer(type, size, 0, ".append");
logBody(type);
return FilterDataStatus::Continue;
return FilterDataStatus::StopIterationNoBuffer;

} else if (body_op_ == "ReplaceBody") {
setBuffer(type, 0, buffer_length, "replace");
logBody(type);
return FilterDataStatus::Continue;
return FilterDataStatus::StopIterationAndWatermark;

} else if (body_op_ == "PartialReplaceBody") {
setBuffer(type, 0, 1, "partial.replace.");
Expand Down
22 changes: 18 additions & 4 deletions test/extensions/filters/http/wasm/wasm_filter_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -380,8 +380,15 @@ TEST_P(WasmHttpFilterTest, BodyRequestPrependAndAppendToBody) {
{"x-test-operation", "PrependAndAppendToBody"}};
EXPECT_EQ(Http::FilterHeadersStatus::Continue, filter().decodeHeaders(request_headers, false));
Buffer::OwnedImpl data("hello");
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().decodeData(data, true));
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().encodeData(data, true));
if (std::get<1>(GetParam()) == "rust") {
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().decodeData(data, true));
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().encodeData(data, true));
} else {
// This status is not available in the rust SDK.
// TODO: update all SDKs to the new revision of the spec and update the tests accordingly.
EXPECT_EQ(Http::FilterDataStatus::StopIterationNoBuffer, filter().decodeData(data, true));
EXPECT_EQ(Http::FilterDataStatus::StopIterationNoBuffer, filter().encodeData(data, true));
}
filter().onDestroy();
}

Expand All @@ -394,8 +401,15 @@ TEST_P(WasmHttpFilterTest, BodyRequestReplaceBody) {
{"x-test-operation", "ReplaceBody"}};
EXPECT_EQ(Http::FilterHeadersStatus::Continue, filter().decodeHeaders(request_headers, false));
Buffer::OwnedImpl data("hello");
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().decodeData(data, true));
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().encodeData(data, true));
if (std::get<1>(GetParam()) == "rust") {
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().decodeData(data, true));
EXPECT_EQ(Http::FilterDataStatus::Continue, filter().encodeData(data, true));
} else {
// This status is not available in the rust SDK.
// TODO: update all SDKs to the new revision of the spec and update the tests accordingly.
EXPECT_EQ(Http::FilterDataStatus::StopIterationAndWatermark, filter().decodeData(data, true));
EXPECT_EQ(Http::FilterDataStatus::StopIterationAndWatermark, filter().encodeData(data, true));
}
filter().onDestroy();
}

Expand Down

0 comments on commit 4b7389a

Please sign in to comment.