xref: /aosp_15_r20/external/grpc-grpc/examples/python/timeout/greeter_client.py (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
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"""gRPC Python helloworld.Greeter client with call timeout parameters."""
15*cc02d7e2SAndroid Build Coastguard Worker
16*cc02d7e2SAndroid Build Coastguard Workerimport logging
17*cc02d7e2SAndroid Build Coastguard Worker
18*cc02d7e2SAndroid Build Coastguard Workerimport grpc
19*cc02d7e2SAndroid Build Coastguard Workerimport helloworld_pb2
20*cc02d7e2SAndroid Build Coastguard Workerimport helloworld_pb2_grpc
21*cc02d7e2SAndroid Build Coastguard Worker
22*cc02d7e2SAndroid Build Coastguard Worker
23*cc02d7e2SAndroid Build Coastguard Workerdef unary_call(
24*cc02d7e2SAndroid Build Coastguard Worker    stub: helloworld_pb2_grpc.GreeterStub, request_id: int, message: str
25*cc02d7e2SAndroid Build Coastguard Worker):
26*cc02d7e2SAndroid Build Coastguard Worker    print("call:", request_id)
27*cc02d7e2SAndroid Build Coastguard Worker    try:
28*cc02d7e2SAndroid Build Coastguard Worker        response = stub.SayHello(
29*cc02d7e2SAndroid Build Coastguard Worker            helloworld_pb2.HelloRequest(name=message), timeout=3
30*cc02d7e2SAndroid Build Coastguard Worker        )
31*cc02d7e2SAndroid Build Coastguard Worker        print(f"Greeter client received: {response.message}")
32*cc02d7e2SAndroid Build Coastguard Worker    except grpc.RpcError as rpc_error:
33*cc02d7e2SAndroid Build Coastguard Worker        print(f"Call failed with code: {rpc_error.code()}")
34*cc02d7e2SAndroid Build Coastguard Worker
35*cc02d7e2SAndroid Build Coastguard Worker
36*cc02d7e2SAndroid Build Coastguard Workerdef run():
37*cc02d7e2SAndroid Build Coastguard Worker    with grpc.insecure_channel("localhost:50051") as channel:
38*cc02d7e2SAndroid Build Coastguard Worker        stub = helloworld_pb2_grpc.GreeterStub(channel)
39*cc02d7e2SAndroid Build Coastguard Worker        # Should success
40*cc02d7e2SAndroid Build Coastguard Worker        unary_call(stub, 1, "you")
41*cc02d7e2SAndroid Build Coastguard Worker        # Should fail with DEADLINE_EXCEEDED
42*cc02d7e2SAndroid Build Coastguard Worker        unary_call(stub, 2, "[delay] you")
43*cc02d7e2SAndroid Build Coastguard Worker
44*cc02d7e2SAndroid Build Coastguard Worker
45*cc02d7e2SAndroid Build Coastguard Workerif __name__ == "__main__":
46*cc02d7e2SAndroid Build Coastguard Worker    logging.basicConfig()
47*cc02d7e2SAndroid Build Coastguard Worker    run()
48