xref: /aosp_15_r20/external/grpc-grpc/test/cpp/util/cli_call.h (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker //
2*cc02d7e2SAndroid Build Coastguard Worker //
3*cc02d7e2SAndroid Build Coastguard Worker // Copyright 2015 gRPC authors.
4*cc02d7e2SAndroid Build Coastguard Worker //
5*cc02d7e2SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
6*cc02d7e2SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
7*cc02d7e2SAndroid Build Coastguard Worker // You may obtain a copy of the License at
8*cc02d7e2SAndroid Build Coastguard Worker //
9*cc02d7e2SAndroid Build Coastguard Worker //     http://www.apache.org/licenses/LICENSE-2.0
10*cc02d7e2SAndroid Build Coastguard Worker //
11*cc02d7e2SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
12*cc02d7e2SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
13*cc02d7e2SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*cc02d7e2SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
15*cc02d7e2SAndroid Build Coastguard Worker // limitations under the License.
16*cc02d7e2SAndroid Build Coastguard Worker //
17*cc02d7e2SAndroid Build Coastguard Worker //
18*cc02d7e2SAndroid Build Coastguard Worker 
19*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPC_TEST_CPP_UTIL_CLI_CALL_H
20*cc02d7e2SAndroid Build Coastguard Worker #define GRPC_TEST_CPP_UTIL_CLI_CALL_H
21*cc02d7e2SAndroid Build Coastguard Worker 
22*cc02d7e2SAndroid Build Coastguard Worker #include <map>
23*cc02d7e2SAndroid Build Coastguard Worker 
24*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/channel.h>
25*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/completion_queue.h>
26*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/generic/generic_stub.h>
27*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/status.h>
28*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/string_ref.h>
29*cc02d7e2SAndroid Build Coastguard Worker 
30*cc02d7e2SAndroid Build Coastguard Worker namespace grpc {
31*cc02d7e2SAndroid Build Coastguard Worker 
32*cc02d7e2SAndroid Build Coastguard Worker class ClientContext;
33*cc02d7e2SAndroid Build Coastguard Worker 
34*cc02d7e2SAndroid Build Coastguard Worker struct CliArgs {
35*cc02d7e2SAndroid Build Coastguard Worker   double timeout = -1;
36*cc02d7e2SAndroid Build Coastguard Worker };
37*cc02d7e2SAndroid Build Coastguard Worker 
38*cc02d7e2SAndroid Build Coastguard Worker namespace testing {
39*cc02d7e2SAndroid Build Coastguard Worker 
40*cc02d7e2SAndroid Build Coastguard Worker // CliCall handles the sending and receiving of generic messages given the name
41*cc02d7e2SAndroid Build Coastguard Worker // of the remote method. This class is only used by GrpcTool. Its thread-safe
42*cc02d7e2SAndroid Build Coastguard Worker // and thread-unsafe methods should not be used together.
43*cc02d7e2SAndroid Build Coastguard Worker class CliCall final {
44*cc02d7e2SAndroid Build Coastguard Worker  public:
45*cc02d7e2SAndroid Build Coastguard Worker   typedef std::multimap<std::string, std::string> OutgoingMetadataContainer;
46*cc02d7e2SAndroid Build Coastguard Worker   typedef std::multimap<grpc::string_ref, grpc::string_ref>
47*cc02d7e2SAndroid Build Coastguard Worker       IncomingMetadataContainer;
48*cc02d7e2SAndroid Build Coastguard Worker 
49*cc02d7e2SAndroid Build Coastguard Worker   CliCall(const std::shared_ptr<grpc::Channel>& channel,
50*cc02d7e2SAndroid Build Coastguard Worker           const std::string& method, const OutgoingMetadataContainer& metadata,
51*cc02d7e2SAndroid Build Coastguard Worker           CliArgs args);
CliCall(const std::shared_ptr<grpc::Channel> & channel,const std::string & method,const OutgoingMetadataContainer & metadata)52*cc02d7e2SAndroid Build Coastguard Worker   CliCall(const std::shared_ptr<grpc::Channel>& channel,
53*cc02d7e2SAndroid Build Coastguard Worker           const std::string& method, const OutgoingMetadataContainer& metadata)
54*cc02d7e2SAndroid Build Coastguard Worker       : CliCall(channel, method, metadata, CliArgs{}) {}
55*cc02d7e2SAndroid Build Coastguard Worker 
56*cc02d7e2SAndroid Build Coastguard Worker   ~CliCall();
57*cc02d7e2SAndroid Build Coastguard Worker 
58*cc02d7e2SAndroid Build Coastguard Worker   // Perform an unary generic RPC.
59*cc02d7e2SAndroid Build Coastguard Worker   Status Call(const std::string& request, std::string* response,
60*cc02d7e2SAndroid Build Coastguard Worker               IncomingMetadataContainer* server_initial_metadata,
61*cc02d7e2SAndroid Build Coastguard Worker               IncomingMetadataContainer* server_trailing_metadata);
62*cc02d7e2SAndroid Build Coastguard Worker 
63*cc02d7e2SAndroid Build Coastguard Worker   // Send a generic request message in a synchronous manner. NOT thread-safe.
64*cc02d7e2SAndroid Build Coastguard Worker   void Write(const std::string& request);
65*cc02d7e2SAndroid Build Coastguard Worker 
66*cc02d7e2SAndroid Build Coastguard Worker   // Send a generic request message in a synchronous manner. NOT thread-safe.
67*cc02d7e2SAndroid Build Coastguard Worker   void WritesDone();
68*cc02d7e2SAndroid Build Coastguard Worker 
69*cc02d7e2SAndroid Build Coastguard Worker   // Receive a generic response message in a synchronous manner.NOT thread-safe.
70*cc02d7e2SAndroid Build Coastguard Worker   bool Read(std::string* response,
71*cc02d7e2SAndroid Build Coastguard Worker             IncomingMetadataContainer* server_initial_metadata);
72*cc02d7e2SAndroid Build Coastguard Worker 
73*cc02d7e2SAndroid Build Coastguard Worker   // Thread-safe write. Must be used with ReadAndMaybeNotifyWrite. Send out a
74*cc02d7e2SAndroid Build Coastguard Worker   // generic request message and wait for ReadAndMaybeNotifyWrite to finish it.
75*cc02d7e2SAndroid Build Coastguard Worker   void WriteAndWait(const std::string& request);
76*cc02d7e2SAndroid Build Coastguard Worker 
77*cc02d7e2SAndroid Build Coastguard Worker   // Thread-safe WritesDone. Must be used with ReadAndMaybeNotifyWrite. Send out
78*cc02d7e2SAndroid Build Coastguard Worker   // WritesDone for gereneric request messages and wait for
79*cc02d7e2SAndroid Build Coastguard Worker   // ReadAndMaybeNotifyWrite to finish it.
80*cc02d7e2SAndroid Build Coastguard Worker   void WritesDoneAndWait();
81*cc02d7e2SAndroid Build Coastguard Worker 
82*cc02d7e2SAndroid Build Coastguard Worker   // Thread-safe Read. Blockingly receive a generic response message. Notify
83*cc02d7e2SAndroid Build Coastguard Worker   // writes if they are finished when this read is waiting for a resposne.
84*cc02d7e2SAndroid Build Coastguard Worker   bool ReadAndMaybeNotifyWrite(
85*cc02d7e2SAndroid Build Coastguard Worker       std::string* response,
86*cc02d7e2SAndroid Build Coastguard Worker       IncomingMetadataContainer* server_initial_metadata);
87*cc02d7e2SAndroid Build Coastguard Worker 
88*cc02d7e2SAndroid Build Coastguard Worker   // Finish the RPC.
89*cc02d7e2SAndroid Build Coastguard Worker   Status Finish(IncomingMetadataContainer* server_trailing_metadata);
90*cc02d7e2SAndroid Build Coastguard Worker 
peer()91*cc02d7e2SAndroid Build Coastguard Worker   std::string peer() const { return ctx_.peer(); }
92*cc02d7e2SAndroid Build Coastguard Worker 
93*cc02d7e2SAndroid Build Coastguard Worker  private:
94*cc02d7e2SAndroid Build Coastguard Worker   std::unique_ptr<grpc::GenericStub> stub_;
95*cc02d7e2SAndroid Build Coastguard Worker   grpc::ClientContext ctx_;
96*cc02d7e2SAndroid Build Coastguard Worker   std::unique_ptr<grpc::GenericClientAsyncReaderWriter> call_;
97*cc02d7e2SAndroid Build Coastguard Worker   grpc::CompletionQueue cq_;
98*cc02d7e2SAndroid Build Coastguard Worker   gpr_mu write_mu_;
99*cc02d7e2SAndroid Build Coastguard Worker   gpr_cv write_cv_;  // Protected by write_mu_;
100*cc02d7e2SAndroid Build Coastguard Worker   bool write_done_;  // Portected by write_mu_;
101*cc02d7e2SAndroid Build Coastguard Worker };
102*cc02d7e2SAndroid Build Coastguard Worker 
103*cc02d7e2SAndroid Build Coastguard Worker }  // namespace testing
104*cc02d7e2SAndroid Build Coastguard Worker }  // namespace grpc
105*cc02d7e2SAndroid Build Coastguard Worker 
106*cc02d7e2SAndroid Build Coastguard Worker #endif  // GRPC_TEST_CPP_UTIL_CLI_CALL_H
107