1*cc02d7e2SAndroid Build Coastguard Worker // Copyright 2023 gRPC authors.
2*cc02d7e2SAndroid Build Coastguard Worker //
3*cc02d7e2SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*cc02d7e2SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*cc02d7e2SAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*cc02d7e2SAndroid Build Coastguard Worker //
7*cc02d7e2SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0
8*cc02d7e2SAndroid Build Coastguard Worker //
9*cc02d7e2SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*cc02d7e2SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*cc02d7e2SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*cc02d7e2SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*cc02d7e2SAndroid Build Coastguard Worker // limitations under the License.
14*cc02d7e2SAndroid Build Coastguard Worker
15*cc02d7e2SAndroid Build Coastguard Worker #include <condition_variable>
16*cc02d7e2SAndroid Build Coastguard Worker #include <iostream>
17*cc02d7e2SAndroid Build Coastguard Worker #include <memory>
18*cc02d7e2SAndroid Build Coastguard Worker #include <mutex>
19*cc02d7e2SAndroid Build Coastguard Worker #include <string>
20*cc02d7e2SAndroid Build Coastguard Worker #include <vector>
21*cc02d7e2SAndroid Build Coastguard Worker
22*cc02d7e2SAndroid Build Coastguard Worker #include "absl/flags/flag.h"
23*cc02d7e2SAndroid Build Coastguard Worker #include "absl/flags/parse.h"
24*cc02d7e2SAndroid Build Coastguard Worker #include "absl/strings/str_cat.h"
25*cc02d7e2SAndroid Build Coastguard Worker
26*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/grpcpp.h>
27*cc02d7e2SAndroid Build Coastguard Worker
28*cc02d7e2SAndroid Build Coastguard Worker #ifdef BAZEL_BUILD
29*cc02d7e2SAndroid Build Coastguard Worker #include "examples/protos/helloworld.grpc.pb.h"
30*cc02d7e2SAndroid Build Coastguard Worker #else
31*cc02d7e2SAndroid Build Coastguard Worker #include "helloworld.grpc.pb.h"
32*cc02d7e2SAndroid Build Coastguard Worker #endif
33*cc02d7e2SAndroid Build Coastguard Worker
34*cc02d7e2SAndroid Build Coastguard Worker ABSL_FLAG(std::string, target, "localhost:50051", "Server address");
35*cc02d7e2SAndroid Build Coastguard Worker
36*cc02d7e2SAndroid Build Coastguard Worker using grpc::Channel;
37*cc02d7e2SAndroid Build Coastguard Worker using grpc::ClientContext;
38*cc02d7e2SAndroid Build Coastguard Worker using grpc::Status;
39*cc02d7e2SAndroid Build Coastguard Worker using grpc::StatusCode;
40*cc02d7e2SAndroid Build Coastguard Worker using helloworld::Greeter;
41*cc02d7e2SAndroid Build Coastguard Worker using helloworld::HelloReply;
42*cc02d7e2SAndroid Build Coastguard Worker using helloworld::HelloRequest;
43*cc02d7e2SAndroid Build Coastguard Worker
unaryCall(std::shared_ptr<Channel> channel,std::string label,std::string message,grpc::StatusCode expected_code)44*cc02d7e2SAndroid Build Coastguard Worker void unaryCall(std::shared_ptr<Channel> channel, std::string label,
45*cc02d7e2SAndroid Build Coastguard Worker std::string message, grpc::StatusCode expected_code) {
46*cc02d7e2SAndroid Build Coastguard Worker std::unique_ptr<Greeter::Stub> stub = Greeter::NewStub(channel);
47*cc02d7e2SAndroid Build Coastguard Worker
48*cc02d7e2SAndroid Build Coastguard Worker // Data we are sending to the server.
49*cc02d7e2SAndroid Build Coastguard Worker HelloRequest request;
50*cc02d7e2SAndroid Build Coastguard Worker request.set_name(message);
51*cc02d7e2SAndroid Build Coastguard Worker
52*cc02d7e2SAndroid Build Coastguard Worker // Container for the data we expect from the server.
53*cc02d7e2SAndroid Build Coastguard Worker HelloReply reply;
54*cc02d7e2SAndroid Build Coastguard Worker
55*cc02d7e2SAndroid Build Coastguard Worker // Context for the client. It could be used to convey extra information to
56*cc02d7e2SAndroid Build Coastguard Worker // the server and/or tweak certain RPC behaviors.
57*cc02d7e2SAndroid Build Coastguard Worker ClientContext context;
58*cc02d7e2SAndroid Build Coastguard Worker
59*cc02d7e2SAndroid Build Coastguard Worker // Set 1 second timeout
60*cc02d7e2SAndroid Build Coastguard Worker context.set_deadline(std::chrono::system_clock::now() +
61*cc02d7e2SAndroid Build Coastguard Worker std::chrono::seconds(1));
62*cc02d7e2SAndroid Build Coastguard Worker
63*cc02d7e2SAndroid Build Coastguard Worker // The actual RPC.
64*cc02d7e2SAndroid Build Coastguard Worker std::mutex mu;
65*cc02d7e2SAndroid Build Coastguard Worker std::condition_variable cv;
66*cc02d7e2SAndroid Build Coastguard Worker bool done = false;
67*cc02d7e2SAndroid Build Coastguard Worker Status status;
68*cc02d7e2SAndroid Build Coastguard Worker stub->async()->SayHello(&context, &request, &reply,
69*cc02d7e2SAndroid Build Coastguard Worker [&mu, &cv, &done, &status](Status s) {
70*cc02d7e2SAndroid Build Coastguard Worker status = std::move(s);
71*cc02d7e2SAndroid Build Coastguard Worker std::lock_guard<std::mutex> lock(mu);
72*cc02d7e2SAndroid Build Coastguard Worker done = true;
73*cc02d7e2SAndroid Build Coastguard Worker cv.notify_one();
74*cc02d7e2SAndroid Build Coastguard Worker });
75*cc02d7e2SAndroid Build Coastguard Worker
76*cc02d7e2SAndroid Build Coastguard Worker std::unique_lock<std::mutex> lock(mu);
77*cc02d7e2SAndroid Build Coastguard Worker while (!done) {
78*cc02d7e2SAndroid Build Coastguard Worker cv.wait(lock);
79*cc02d7e2SAndroid Build Coastguard Worker }
80*cc02d7e2SAndroid Build Coastguard Worker
81*cc02d7e2SAndroid Build Coastguard Worker // Act upon its status.
82*cc02d7e2SAndroid Build Coastguard Worker std::cout << "[" << label << "] wanted = " << expected_code
83*cc02d7e2SAndroid Build Coastguard Worker << ", got = " << status.error_code() << std::endl;
84*cc02d7e2SAndroid Build Coastguard Worker }
85*cc02d7e2SAndroid Build Coastguard Worker
main(int argc,char ** argv)86*cc02d7e2SAndroid Build Coastguard Worker int main(int argc, char** argv) {
87*cc02d7e2SAndroid Build Coastguard Worker absl::ParseCommandLine(argc, argv);
88*cc02d7e2SAndroid Build Coastguard Worker // Instantiate the client. It requires a channel, out of which the actual RPCs
89*cc02d7e2SAndroid Build Coastguard Worker // are created. This channel models a connection to an endpoint specified by
90*cc02d7e2SAndroid Build Coastguard Worker // the argument "--target=" which is the only expected argument.
91*cc02d7e2SAndroid Build Coastguard Worker std::string target_str = absl::GetFlag(FLAGS_target);
92*cc02d7e2SAndroid Build Coastguard Worker // We indicate that the channel isn't authenticated (use of
93*cc02d7e2SAndroid Build Coastguard Worker // InsecureChannelCredentials()).
94*cc02d7e2SAndroid Build Coastguard Worker std::shared_ptr<Channel> channel =
95*cc02d7e2SAndroid Build Coastguard Worker grpc::CreateChannel(target_str, grpc::InsecureChannelCredentials());
96*cc02d7e2SAndroid Build Coastguard Worker // Making test calls
97*cc02d7e2SAndroid Build Coastguard Worker unaryCall(channel, "Successful request", "world", grpc::StatusCode::OK);
98*cc02d7e2SAndroid Build Coastguard Worker unaryCall(channel, "Exceeds deadline", "delay",
99*cc02d7e2SAndroid Build Coastguard Worker grpc::StatusCode::DEADLINE_EXCEEDED);
100*cc02d7e2SAndroid Build Coastguard Worker unaryCall(channel, "Successful request with propagated deadline",
101*cc02d7e2SAndroid Build Coastguard Worker "[propagate me]world", grpc::StatusCode::OK);
102*cc02d7e2SAndroid Build Coastguard Worker unaryCall(channel, "Exceeds propagated deadline",
103*cc02d7e2SAndroid Build Coastguard Worker "[propagate me][propagate me]world",
104*cc02d7e2SAndroid Build Coastguard Worker grpc::StatusCode::DEADLINE_EXCEEDED);
105*cc02d7e2SAndroid Build Coastguard Worker return 0;
106*cc02d7e2SAndroid Build Coastguard Worker }
107