mirror of https://github.com/grpc/grpc.git
The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
https://grpc.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
2.9 KiB
103 lines
2.9 KiB
// Copyright 2021 gRPC authors. |
|
// |
|
// Licensed under the Apache License, Version 2.0 (the "License"); |
|
// you may not use this file except in compliance with the License. |
|
// You may obtain a copy of the License at |
|
// |
|
// http://www.apache.org/licenses/LICENSE-2.0 |
|
// |
|
// Unless required by applicable law or agreed to in writing, software |
|
// distributed under the License is distributed on an "AS IS" BASIS, |
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
// See the License for the specific language governing permissions and |
|
// limitations under the License. |
|
|
|
#include "src/core/lib/promise/seq.h" |
|
|
|
#include <gtest/gtest.h> |
|
|
|
namespace grpc_core { |
|
|
|
TEST(SeqTest, Immediate) { |
|
EXPECT_EQ(Seq([] { return 3; })(), 3); |
|
} |
|
|
|
TEST(SeqTest, OneThen) { |
|
auto initial = [] { return 3; }; |
|
auto then = [](int i) { return [i]() { return i + 4; }; }; |
|
EXPECT_EQ(Seq(initial, then)(), Poll<int>(7)); |
|
} |
|
|
|
TEST(SeqTest, TwoTypedThens) { |
|
struct A {}; |
|
struct B {}; |
|
struct C {}; |
|
auto initial = [] { return A{}; }; |
|
auto next1 = [](A) { return []() { return B{}; }; }; |
|
auto next2 = [](B) { return []() { return C{}; }; }; |
|
EXPECT_FALSE(absl::holds_alternative<Pending>(Seq(initial, next1, next2)())); |
|
} |
|
|
|
/* This does not compile, but is useful for testing error messages generated |
|
TEST(SeqTest, MisTypedThen) { |
|
struct A {}; |
|
struct B {}; |
|
auto initial = [] { return A{}; }; |
|
auto next = [](B) { return []() { return B{}; }; }; |
|
Seq(initial, next)().take(); |
|
} |
|
*/ |
|
|
|
TEST(SeqTest, TwoThens) { |
|
auto initial = [] { return std::string("a"); }; |
|
auto next1 = [](std::string i) { return [i]() { return i + "b"; }; }; |
|
auto next2 = [](std::string i) { return [i]() { return i + "c"; }; }; |
|
EXPECT_EQ(Seq(initial, next1, next2)(), Poll<std::string>("abc")); |
|
} |
|
|
|
TEST(SeqTest, ThreeThens) { |
|
EXPECT_EQ(Seq([] { return std::string("a"); }, |
|
[](std::string i) { return [i]() { return i + "b"; }; }, |
|
[](std::string i) { return [i]() { return i + "c"; }; }, |
|
[](std::string i) { return [i]() { return i + "d"; }; })(), |
|
Poll<std::string>("abcd")); |
|
} |
|
|
|
struct Big { |
|
int x[256]; |
|
void YesItIsUnused() const {} |
|
}; |
|
|
|
TEST(SeqTest, SaneSizes) { |
|
auto x = Big(); |
|
auto p1 = Seq( |
|
[x] { |
|
x.YesItIsUnused(); |
|
return 1; |
|
}, |
|
[](int) { |
|
auto y = Big(); |
|
return [y]() { |
|
y.YesItIsUnused(); |
|
return 2; |
|
}; |
|
}); |
|
EXPECT_GE(sizeof(p1), sizeof(Big)); |
|
EXPECT_LT(sizeof(p1), 2 * sizeof(Big)); |
|
} |
|
|
|
TEST(SeqIterTest, Accumulate) { |
|
std::vector<int> v{1, 2, 3, 4, 5}; |
|
EXPECT_EQ(SeqIter(v.begin(), v.end(), 0, |
|
[](int cur, int next) { |
|
return [cur, next]() { return cur + next; }; |
|
})(), |
|
Poll<int>(15)); |
|
} |
|
|
|
} // namespace grpc_core |
|
|
|
int main(int argc, char** argv) { |
|
::testing::InitGoogleTest(&argc, argv); |
|
return RUN_ALL_TESTS(); |
|
}
|
|
|