diff --git a/test/src/test_client_rpc_17.cpp b/test/src/test_client_rpc_17.cpp index b83d9aac..43d52ec0 100644 --- a/test/src/test_client_rpc_17.cpp +++ b/test/src/test_client_rpc_17.cpp @@ -162,26 +162,20 @@ TEST_CASE_TEMPLATE("Streaming RPC::start returns false on error", RPC, test::Cli test.grpc_context.run(); } -TEST_CASE_FIXTURE(ClientRPCTest, - "UnaryClientRPC::request exception thrown from completion handler rethrows from GrpcContext.run()") +TEST_CASE_FIXTURE( + ClientRPCRequestResponseTest, + "ServerStreamingClientRPC::start exception thrown from completion handler rethrows from GrpcContext.run()") { - CHECK_THROWS_AS(register_and_perform_three_requests( - [&](auto& rpc, auto&, const asio::yield_context& yield) - { - rpc.finish(grpc::Status::OK, yield); - }, - [&](Request& request, Response& response, const asio::yield_context& yield) - { - auto rpc = std::make_unique(grpc_context, test::set_default_deadline); - start_rpc(*rpc, request, response, yield); - auto& r = *rpc; - r.read(response, asio::bind_executor(test::InlineExecutor{}, - [r = std::move(rpc)](bool) - { - throw test::Exception{}; - })); - }), - test::Exception); + server->Shutdown(); + test::ServerStreamingClientRPC rpc{get_executor()}; + rpc.context().set_deadline(test::ten_milliseconds_from_now()); + start_rpc(rpc, request, response, + asio::bind_executor(grpc_context, + [&](bool) + { + throw test::Exception{}; + })); + CHECK_THROWS_AS(grpc_context.run(), test::Exception); } TEST_CASE_TEMPLATE("ClientRPC::read_initial_metadata on cancelled RPC", RPC, test::ClientStreamingClientRPC, diff --git a/test/src/test_server_rpc_20.cpp b/test/src/test_server_rpc_20.cpp index 7abe1c49..8d6a42a7 100644 --- a/test/src/test_server_rpc_20.cpp +++ b/test/src/test_server_rpc_20.cpp @@ -287,7 +287,7 @@ TEST_CASE_FIXTURE(ServerRPCAwaitableTest, std::exception_ptr eptr; agrpc::register_awaitable_request_handler( get_executor(), service, - [&](test::ServerStreamingServerRPC& rpc, test::msg::Request&) -> asio::awaitable + [&](test::ServerStreamingServerRPC&, test::msg::Request&) -> asio::awaitable { throw test::Exception{}; co_return; @@ -542,7 +542,7 @@ TEST_CASE_FIXTURE(ServerRPCAwaitableTest, signal.emit(asio::cancellation_type::total); perform_requests_in_order(just_finish(*this), just_finish(*this, grpc::StatusCode::DEADLINE_EXCEEDED, test::two_hundred_milliseconds_from_now())); - CHECK_THROWS(std::rethrow_exception(eptr)); + CHECK_FALSE(eptr); } #endif #endif \ No newline at end of file diff --git a/test/utils/utils/client_rpc_test.hpp b/test/utils/utils/client_rpc_test.hpp index afbf23c0..a5b87e73 100644 --- a/test/utils/utils/client_rpc_test.hpp +++ b/test/utils/utils/client_rpc_test.hpp @@ -30,6 +30,7 @@ #include #include +#include #if defined(AGRPC_STANDALONE_ASIO) || defined(AGRPC_BOOST_ASIO) #include diff --git a/test/utils/utils/grpc_client_server_test.cpp b/test/utils/utils/grpc_client_server_test.cpp index db9f3160..ea26e25a 100644 --- a/test/utils/utils/grpc_client_server_test.cpp +++ b/test/utils/utils/grpc_client_server_test.cpp @@ -21,11 +21,12 @@ namespace test { GrpcClientServerTest::GrpcClientServerTest() - : server_context_lifetime(std::in_place), server_context(*server_context_lifetime) + : stub(test::v1::Test::NewStub(channel)), + server_context_lifetime(std::in_place), + server_context(*server_context_lifetime) { builder.RegisterService(&service); - this->server = builder.BuildAndStart(); - stub = test::v1::Test::NewStub(this->channel); + server = builder.BuildAndStart(); } GrpcClientServerTest::~GrpcClientServerTest() diff --git a/test/utils/utils/grpc_generic_client_server_test.cpp b/test/utils/utils/grpc_generic_client_server_test.cpp index d183e87d..e04b7895 100644 --- a/test/utils/utils/grpc_generic_client_server_test.cpp +++ b/test/utils/utils/grpc_generic_client_server_test.cpp @@ -20,12 +20,12 @@ namespace test { GrpcGenericClientServerTest::GrpcGenericClientServerTest() - : stub{std::make_unique(this->channel)}, + : stub{std::make_unique(channel)}, server_context_lifetime(std::in_place), server_context(*server_context_lifetime) { builder.RegisterAsyncGenericService(&service); - this->server = builder.BuildAndStart(); + server = builder.BuildAndStart(); } GrpcGenericClientServerTest::~GrpcGenericClientServerTest() diff --git a/test/utils/utils/grpc_generic_client_server_test.hpp b/test/utils/utils/grpc_generic_client_server_test.hpp index c996ab72..1195e51e 100644 --- a/test/utils/utils/grpc_generic_client_server_test.hpp +++ b/test/utils/utils/grpc_generic_client_server_test.hpp @@ -22,7 +22,7 @@ namespace test { -struct GrpcGenericClientServerTest : virtual test::GrpcClientServerTestBase +struct GrpcGenericClientServerTest : test::GrpcClientServerTestBase { grpc::AsyncGenericService service; std::unique_ptr stub;